multi_json 1.5.0 → 1.12.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: a225eae18c744a8c77819d37dbacdd8147dcdfab
4
+ data.tar.gz: 9cb4b5e29fcf1feef6a1c1841c2d8ee4bc735d46
5
+ SHA512:
6
+ metadata.gz: cab3829af47fac93c9ac09666e8eff4ba707b4f86d989abb03bb3e7329744e753290208c103c7fc8592cc87aef33d98cd01c0c5745f8de5faf8b52782d0ea22f
7
+ data.tar.gz: 9eb391a648d7addd9135f08ab673b5127c69f3af6c2d2f77099652a966ea3adc8c022ba48b5346111252b0b7b2a26e931f0d92f39d6a0fa32ce60432191fa69d
checksums.yaml.gz.sig ADDED
Binary file
data/CHANGELOG.md ADDED
@@ -0,0 +1,245 @@
1
+ 1.12.1
2
+ ------
3
+
4
+ * [Prevent meory leak in OptionsCache](https://github.com/intridea/multi_json/commit/aa7498199ad272f3d4a13750d7c568a66047e2ee)
5
+
6
+ 1.12.0
7
+ ------
8
+
9
+ * [Introduce global options cache to improve peroformance](https://github.com/intridea/multi_json/commit/7aaef2a1bc2b83c95e4208b12dad5d1d87ff20a6)
10
+
11
+ 1.11.2
12
+ ------
13
+
14
+ * [Only pass one argument to JrJackson when two is not supported](https://github.com/intridea/multi_json/commit/e798fa517c817fc706982d3f3c61129b6651d601)
15
+
16
+ 1.11.1
17
+ ------
18
+
19
+ * [Dump method passes options throught for JrJackson adapter](https://github.com/intridea/multi_json/commit/3c730fd12135c3e7bf212f878958004908f13909)
20
+
21
+ 1.11.0
22
+ ------
23
+
24
+ * [Make all adapters read IO object before load](https://github.com/intridea/multi_json/commit/167f559e18d4efee05e1f160a2661d16dbb215d4)
25
+
26
+ 1.10.1
27
+ ------
28
+ * [Explicitly require stringio for Gson adapter](https://github.com/intridea/multi_json/commit/623ec8142d4a212fa0db763bb71295789a119929)
29
+ * [Do not read StringIO object before passing it to JrJackson](https://github.com/intridea/multi_json/commit/a6dc935df08e7b3d5d701fbb9298384c96df0fde)
30
+
31
+ 1.10.0
32
+ ------
33
+ * [Performance tweaks](https://github.com/intridea/multi_json/commit/58724acfed31866d079eaafb1cd824e341ade287)
34
+
35
+ 1.9.3
36
+ -----
37
+ * [Convert indent option to Fixnum before passing to Oj](https://github.com/intridea/multi_json/commit/826fc5535b863b74fc9f981dfdda3e26f1ee4e5b)
38
+
39
+ 1.9.2
40
+ -----
41
+ * [Enable use_to_json option for Oj adapter by default](https://github.com/intridea/multi_json/commit/76a4aaf697b10bbabd5d535d83cf1149efcfe5c7)
42
+
43
+ 1.9.1
44
+ -----
45
+ * [Remove unused LoadError file](https://github.com/intridea/multi_json/commit/65dedd84d59baeefc25c477fedf0bbe85e7ce2cd)
46
+
47
+ 1.9.0
48
+ ----
49
+ * [Rename LoadError to ParseError](https://github.com/intridea/multi_json/commit/4abb98fe3a90b2a7b3d1594515c8a06042b4a27d)
50
+ * [Adapter load failure throws AdapterError instead of ArgumentError](https://github.com/intridea/multi_json/commit/4da612b617bd932bb6fa1cc4c43210327f98f271)
51
+
52
+ 1.8.4
53
+ -----
54
+ * [Make Gson adapter explicitly read StringIO object](https://github.com/intridea/multi_json/commit/b58b498747ff6e94f41488c971b2a30a98760ef2)
55
+
56
+ 1.8.3
57
+ -----
58
+ * [Make JrJackson explicitly read StringIO objects](https://github.com/intridea/multi_json/commit/e1f162d5b668e5e4db5afa175361a601a8aa2b05)
59
+ * [Prevent calling #downcase on alias symbols](https://github.com/intridea/multi_json/commit/c1cf075453ce0110f7decc4f906444b1233bb67c)
60
+
61
+ 1.8.2
62
+ -----
63
+ * [Downcase adapter string name for OS compatibility](https://github.com/intridea/multi_json/commit/b8e15a032247a63f1410d21a18add05035f3fa66)
64
+
65
+ 1.8.1
66
+ -----
67
+ * [Let the adapter handle strings with invalid encoding](https://github.com/intridea/multi_json/commit/6af2bf87b89f44eabf2ae9ca96779febc65ea94b)
68
+
69
+ 1.8.0
70
+ -----
71
+ * [Raise MultiJson::LoadError on blank input](https://github.com/intridea/multi_json/commit/c44f9c928bb25fe672246ad394b3e5b991be32e6)
72
+
73
+ 1.7.9
74
+ -----
75
+ * [Explicitly require json gem code even when constant is defined](https://github.com/intridea/multi_json/commit/36f7906c66477eb4b55b7afeaa3684b6db69eff2)
76
+
77
+ 1.7.8
78
+ -----
79
+ * [Reorder JrJackson before json_gem](https://github.com/intridea/multi_json/commit/315b6e460b6e4dcdb6c82e04e4be8ee975d395da)
80
+ * [Update vendored OkJson to version 43](https://github.com/intridea/multi_json/commit/99a6b662f6ef4036e3ee94d7eb547fa72fb2ab50)
81
+
82
+ 1.7.7
83
+ -----
84
+ * [Fix options caching issues](https://github.com/intridea/multi_json/commit/a3f14c3661688c5927638fa6088c7b46a67e875e)
85
+
86
+ 1.7.6
87
+ -----
88
+ * [Bring back MultiJson::VERSION constant](https://github.com/intridea/multi_json/commit/31b990c2725e6673bf8ce57540fe66b57a751a72)
89
+
90
+ 1.7.5
91
+ -----
92
+ * [Fix warning '*' interpreted as argument prefix](https://github.com/intridea/multi_json/commit/b698962c7f64430222a1f06430669706a47aff89)
93
+ * [Remove stdlib warning](https://github.com/intridea/multi_json/commit/d06eec6b7996ac8b4ff0e2229efd835379b0c30f)
94
+
95
+ 1.7.4
96
+ -----
97
+ * [Cache options for better performance](https://github.com/intridea/multi_json/commit/8a26ee93140c4bed36194ed9fb887a1b6919257b)
98
+
99
+ 1.7.3
100
+ -----
101
+ * [Require json/ext to ensure extension version gets loaded for json_gem](https://github.com/intridea/multi_json/commit/942686f7e8597418c6f90ee69e1d45242fac07b1)
102
+ * [Rename JrJackson](https://github.com/intridea/multi_json/commit/078de7ba8b6035343c3e96b4767549e9ec43369a)
103
+ * [Prefer JrJackson to JSON gem if present](https://github.com/intridea/multi_json/commit/af8bd9799a66855f04b3aff1c488485950cec7bf)
104
+ * [Print a warning if outdated gem versions are used](https://github.com/intridea/multi_json/commit/e7438e7ba2be0236cfa24c2bb9ad40ee821286d1)
105
+ * [Loosen required_rubygems_version for compatibility with Ubuntu 10.04](https://github.com/intridea/multi_json/commit/59fad014e8fe41dbc6f09485ea0dc21fc42fd7a7)
106
+
107
+ 1.7.2
108
+ -----
109
+ * [Rename Jrjackson adapter to JrJackson](https://github.com/intridea/multi_json/commit/b36dc915fc0e6548cbad06b5db6f520e040c9c8b)
110
+ * [Implement jrjackson -> jr_jackson alias for back-compatability](https://github.com/intridea/multi_json/commit/aa50ab8b7bb646b8b75d5d65dfeadae8248a4f10)
111
+ * [Update vendored OkJson module](https://github.com/intridea/multi_json/commit/30a3f474e17dd86a697c3fab04f468d1a4fd69d7)
112
+
113
+ 1.7.1
114
+ -----
115
+ * [Fix capitalization of JrJackson class](https://github.com/intridea/multi_json/commit/5373a5e38c647f02427a0477cb8e0e0dafad1b8d)
116
+
117
+ 1.7.0
118
+ -----
119
+ * [Add load_options/dump_options to MultiJson](https://github.com/intridea/multi_json/commit/a153956be6b0df06ea1705ce3c1ff0b5b0e27ea5)
120
+ * [MultiJson does not modify arguments](https://github.com/intridea/multi_json/commit/58525b01c4c2f6635ba2ac13d6fd987b79f3962f)
121
+ * [Enable quirks_mode by default for json_gem/json_pure adapters](https://github.com/intridea/multi_json/commit/1fd4e6635c436515b7d7d5a0bee4548de8571520)
122
+ * [Add JrJackson adapter](https://github.com/intridea/multi_json/commit/4dd86fa96300aaaf6d762578b9b31ea82adb056d)
123
+ * [Raise ArgumentError on bad adapter input](https://github.com/intridea/multi_json/commit/911a3756bdff2cb5ac06497da3fa3e72199cb7ad)
124
+
125
+ 1.6.1
126
+ -----
127
+ * [Revert "Use JSON.generate instead of #to_json"](https://github.com/intridea/multi_json/issues/86)
128
+
129
+ 1.6.0
130
+ -----
131
+ * [Add gson.rb support](https://github.com/intridea/multi_json/pull/71)
132
+ * [Add MultiJson.default_options](https://github.com/intridea/multi_json/pull/70)
133
+ * [Add MultiJson.with_adapter](https://github.com/intridea/multi_json/pull/67)
134
+ * [Stringify all possible keys for ok_json](https://github.com/intridea/multi_json/pull/66)
135
+ * [Use JSON.generate instead of #to_json](https://github.com/intridea/multi_json/issues/73)
136
+ * [Alias `MultiJson::DecodeError` to `MultiJson::LoadError`](https://github.com/intridea/multi_json/pull/79)
137
+
138
+ 1.5.1
139
+ -----
140
+ * [Do not allow Oj or JSON to create symbols by searching for classes](https://github.com/intridea/multi_json/commit/193e28cf4dc61b6e7b7b7d80f06f74c76df65c41)
141
+
142
+ 1.5.0
143
+ -----
144
+ * [Add `MultiJson.with_adapter` method](https://github.com/intridea/multi_json/commit/d14c5d28cae96557a0421298621b9499e1f28104)
145
+ * [Stringify all possible keys for `ok_json`](https://github.com/intridea/multi_json/commit/73998074058e1e58c557ffa7b9541d486d6041fa)
146
+
147
+ 1.4.0
148
+ -----
149
+ * [Allow `load`/`dump` of JSON fragments](https://github.com/intridea/multi_json/commit/707aae7d48d39c85b38febbd2c210ba87f6e4a36)
150
+
151
+ 1.3.7
152
+ -----
153
+ * [Fix rescue clause for MagLev](https://github.com/intridea/multi_json/commit/39abdf50199828c50e85b2ce8f8ba31fcbbc9332)
154
+ * [Remove unnecessary check for string version of options key](https://github.com/intridea/multi_json/commit/660101b70e962b3c007d0b90d45944fa47d13ec4)
155
+ * [Explicitly set default adapter when adapter is set to `nil` or `false`](https://github.com/intridea/multi_json/commit/a9e587d5a63eafb4baee9fb211265e4dd96a26bc)
156
+ * [Fix Oj `ParseError` mapping for Oj 1.4.0](https://github.com/intridea/multi_json/commit/7d9045338cc9029401c16f3c409d54ce97f275e2)
157
+
158
+ 1.3.6
159
+ -----
160
+ * [Allow adapter-specific options to be passed through to Oj](https://github.com/intridea/multi_json/commit/d0e5feeebcba0bc69400dd203a295f5c30971223)
161
+
162
+ 1.3.5
163
+ -----
164
+ * [Add pretty support to Oj adapter](https://github.com/intridea/multi_json/commit/0c8f75f03020c53bcf4c6be258faf433d24b2c2b)
165
+
166
+ 1.3.4
167
+ -----
168
+ * [Use `class << self` instead of `module_function` to create aliases](https://github.com/intridea/multi_json/commit/ba1451c4c48baa297e049889be241a424cb05980)
169
+
170
+ 1.3.3
171
+ -----
172
+ * [Remove deprecation warnings](https://github.com/intridea/multi_json/commit/36b524e71544eb0186826a891bcc03b2820a008f)
173
+
174
+ 1.3.2
175
+ -----
176
+ * [Add ability to use adapter per call](https://github.com/intridea/multi_json/commit/106bbec469d5d0a832bfa31fffcb8c0f0cdc9bd3)
177
+ * [Add and deprecate `default_engine` method](https://github.com/intridea/multi_json/commit/fc3df0c7a3e2ab9ce0c2c7e7617a4da97dd13f6e)
178
+
179
+ 1.3.1
180
+ -----
181
+ * [Only warn once for each instance a deprecated method is called](https://github.com/intridea/multi_json/commit/e21d6eb7da74b3f283995c1d27d5880e75f0ae84)
182
+
183
+ 1.3.0
184
+ -----
185
+ * [Implement `load`/`dump`; deprecate `decode`/`encode`](https://github.com/intridea/multi_json/commit/e90fd6cb1b0293eb0c73c2f4eb0f7a1764370216)
186
+ * [Rename engines to adapters](https://github.com/intridea/multi_json/commit/ae7fd144a7949a9c221dcaa446196ec23db908df)
187
+
188
+ 1.2.0
189
+ -----
190
+ * [Add support for Oj](https://github.com/intridea/multi_json/commit/acd06b233edabe6c44f226873db7b49dab560c60)
191
+
192
+ 1.1.0
193
+ -----
194
+ * [`NSJSONSerialization` support for MacRuby](https://github.com/intridea/multi_json/commit/f862e2fc966cac8867fe7da3997fc76e8a6cf5d4)
195
+
196
+ 1.0.4
197
+ -----
198
+ * [Set data context to `DecodeError` exception](https://github.com/intridea/multi_json/commit/19ddafd44029c6681f66fae2a0f6eabfd0f85176)
199
+ * [Allow `ok_json` to fallback to `to_json`](https://github.com/intridea/multi_json/commit/c157240b1193b283d06d1bd4d4b5b06bcf3761f8)
200
+ * [Add warning when using `ok_json`](https://github.com/intridea/multi_json/commit/dd4b68810c84f826fb98f9713bfb29ab96888d57)
201
+ * [Options can be passed to an engine on encode](https://github.com/intridea/multi_json/commit/e0a7ff5d5ff621ffccc61617ed8aeec5816e81f7)
202
+
203
+ 1.0.3
204
+ -----
205
+ * [`Array` support for `stringify_keys`](https://github.com/intridea/multi_json/commit/644d1c5c7c7f6a27663b11668527b346094e38b9)
206
+ * [`Array` support for `symbolize_keys`](https://github.com/intridea/multi_json/commit/c885377d47a2aa39cb0d971fea78db2d2fa479a7)
207
+
208
+ 1.0.2
209
+ -----
210
+ * [Allow encoding of rootless JSON when `ok_json` is used](https://github.com/intridea/multi_json/commit/d1cde7de97cb0f6152aef8daf14037521cdce8c6)
211
+
212
+ 1.0.1
213
+ -----
214
+ * [Correct an issue with `ok_json` not being returned as the default engine](https://github.com/intridea/multi_json/commit/d33c141619c54cccd770199694da8fd1bd8f449d)
215
+
216
+ 1.0.0
217
+ -----
218
+ * [Remove `ActiveSupport::JSON` support](https://github.com/intridea/multi_json/commit/c2f4140141d785a24b3f56e58811b0e561b37f6a)
219
+ * [Fix `@engine` ivar warning](https://github.com/intridea/multi_json/commit/3b978a8995721a8dffedc3b75a7f49e5494ec553)
220
+ * [Only `rescue` from parsing errors during decoding, not any `StandardError`](https://github.com/intridea/multi_json/commit/391d00b5e85294d42d41347605d8d46b4a7f66cc)
221
+ * [Rename `okjson` engine and vendored lib to `ok_json`](https://github.com/intridea/multi_json/commit/5bd1afc977a8208ddb0443e1d57cb79665c019f1)
222
+ * [Add `StringIO` support to `json` gem and `ok_json`](https://github.com/intridea/multi_json/commit/1706b11568db7f50af451fce5f4d679aeb3bbe8f)
223
+
224
+ 0.0.5
225
+ -----
226
+ * [Trap all JSON decoding errors; raise `MultiJson::DecodeError`](https://github.com/intridea/multi_json/commit/dea9a1aef6dd1212aa1e5a37ab1669f9b045b732)
227
+
228
+ 0.0.4
229
+ -----
230
+ * [Fix default_engine check for `json` gem](https://github.com/intridea/multi_json/commit/caced0c4e8c795922a109ebc00c3c4fa8635bed8)
231
+ * [Make requirement mapper an `Array` to preserve order in Ruby versions < 1.9](https://github.com/intridea/multi_json/commit/526f5f29a42131574a088ad9bbb43d7f48439b2c)
232
+
233
+ 0.0.3
234
+ -----
235
+ * [Improve defaulting and documentation](https://github.com/sferik/twitter/commit/3a0e41b9e4b0909201045fa47704b78c9d949b73)
236
+
237
+ 0.0.2
238
+ -----
239
+
240
+ * [Rename to `multi_json`](https://github.com/sferik/twitter/commit/461ab89ce071c8c9fabfc183581e0ec523788b62)
241
+
242
+ 0.0.1
243
+ -----
244
+
245
+ * [Initial commit](https://github.com/sferik/twitter/commit/518c21ab299c500527491e6c049ab2229e22a805)
data/CONTRIBUTING.md ADDED
@@ -0,0 +1,46 @@
1
+ ## Contributing
2
+ In the spirit of [free software][free-sw], **everyone** is encouraged to help
3
+ improve this project.
4
+
5
+ [free-sw]: http://www.fsf.org/licensing/essays/free-sw.html
6
+
7
+ Here are some ways *you* can contribute:
8
+
9
+ * by using alpha, beta, and prerelease versions
10
+ * by reporting bugs
11
+ * by suggesting new features
12
+ * by writing or editing documentation
13
+ * by writing specifications
14
+ * by writing code (**no patch is too small**: fix typos, add comments, clean up
15
+ inconsistent whitespace)
16
+ * by refactoring code
17
+ * by closing [issues][]
18
+ * by reviewing patches
19
+
20
+ [issues]: https://github.com/intridea/multi_json/issues
21
+
22
+ ## Submitting an Issue
23
+ We use the [GitHub issue tracker][issues] to track bugs and features. Before
24
+ submitting a bug report or feature request, check to make sure it hasn't
25
+ already been submitted. When submitting a bug report, please include a [Gist][]
26
+ that includes a stack trace and any details that may be necessary to reproduce
27
+ the bug, including your gem version, Ruby version, and operating system.
28
+ Ideally, a bug report should include a pull request with failing specs.
29
+
30
+ [gist]: https://gist.github.com/
31
+
32
+ ## Submitting a Pull Request
33
+ 1. [Fork the repository.][fork]
34
+ 2. [Create a topic branch.][branch]
35
+ 3. Add specs for your unimplemented feature or bug fix.
36
+ 4. Run `bundle exec rake spec`. If your specs pass, return to step 3.
37
+ 5. Implement your feature or bug fix.
38
+ 6. Run `bundle exec rake spec`. If your specs fail, return to step 5.
39
+ 7. Run `open coverage/index.html`. If your changes are not completely covered
40
+ by your tests, return to step 3.
41
+ 8. Add, commit, and push your changes.
42
+ 9. [Submit a pull request.][pr]
43
+
44
+ [fork]: http://help.github.com/fork-a-repo/
45
+ [branch]: http://learn.github.com/p/branching.html
46
+ [pr]: http://help.github.com/send-pull-requests/
data/LICENSE.md CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2010 Michael Bleigh, Josh Kalderimis, Erik Michaels-Ober, and Intridea, Inc.
1
+ Copyright (c) 2010-2013 Michael Bleigh, Josh Kalderimis, Erik Michaels-Ober, Pavel Pravosud
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
data/README.md CHANGED
@@ -1,24 +1,50 @@
1
- # MultiJSON [![Build Status](https://secure.travis-ci.org/intridea/multi_json.png?branch=master)][travis] [![Dependency Status](https://gemnasium.com/intridea/multi_json.png?travis)][gemnasium]
1
+ # MultiJSON
2
2
 
3
+ [![Gem Version](http://img.shields.io/gem/v/multi_json.svg)][gem]
4
+ [![Build Status](http://travis-ci.org/intridea/multi_json.svg)][travis]
5
+ [![Dependency Status](http://img.shields.io/gemnasium/intridea/multi_json.svg)][gemnasium]
6
+ [![Code Climate](http://img.shields.io/codeclimate/github/intridea/multi_json.svg)][codeclimate]
7
+
8
+ [gem]: https://rubygems.org/gems/multi_json
3
9
  [travis]: http://travis-ci.org/intridea/multi_json
4
10
  [gemnasium]: https://gemnasium.com/intridea/multi_json
11
+ [codeclimate]: https://codeclimate.com/github/intridea/multi_json
5
12
 
6
13
  Lots of Ruby libraries parse JSON and everyone has their favorite JSON coder.
7
14
  Instead of choosing a single JSON coder and forcing users of your library to be
8
15
  stuck with it, you can use MultiJSON instead, which will simply choose the
9
16
  fastest available JSON coder. Here's how to use it:
10
17
 
11
- require 'multi_json'
18
+ ```ruby
19
+ require 'multi_json'
20
+
21
+ MultiJson.load('{"abc":"def"}') #=> {"abc" => "def"}
22
+ MultiJson.load('{"abc":"def"}', :symbolize_keys => true) #=> {:abc => "def"}
23
+ MultiJson.dump({:abc => 'def'}) # convert Ruby back to JSON
24
+ MultiJson.dump({:abc => 'def'}, :pretty => true) # encoded in a pretty form (if supported by the coder)
25
+ ```
26
+
27
+ When loading invalid JSON, MultiJson will throw a `MultiJson::ParseError`. `MultiJson::DecodeError` and `MultiJson::LoadError` are aliases for backwards compatibility.
12
28
 
13
- MultiJson.load('{"abc":"def"}') #=> {"abc" => "def"}
14
- MultiJson.load('{"abc":"def"}', :symbolize_keys => true) #=> {:abc => "def"}
15
- MultiJson.dump({:abc => 'def'}) # convert Ruby back to JSON
16
- MultiJson.dump({:abc => 'def'}, :pretty => true) # encoded in a pretty form (if supported by the coder)
29
+ ```ruby
30
+ begin
31
+ MultiJson.load('{invalid json}')
32
+ rescue MultiJson::ParseError => exception
33
+ exception.data # => "{invalid json}"
34
+ exception.cause # => JSON::ParserError: 795: unexpected token at '{invalid json}'
35
+ end
36
+ ```
37
+
38
+ `ParseError` instance has `cause` reader which contains the original exception.
39
+ It also has `data` reader with the input that caused the problem.
17
40
 
18
41
  The `use` method, which sets the MultiJson adapter, takes either a symbol or a
19
42
  class (to allow for custom JSON parsers) that responds to both `.load` and `.dump`
20
43
  at the class level.
21
44
 
45
+ When MultiJson fails to load the specified adapter, it'll throw `MultiJson::AdapterError`
46
+ which inherits from `ArgumentError`.
47
+
22
48
  MultiJSON tries to have intelligent defaulting. That is, if you have any of the
23
49
  supported engines already loaded, it will utilize them before attempting to
24
50
  load any. When loading, libraries are ordered by speed. First Oj, then Yajl,
@@ -34,6 +60,8 @@ MultiJSON falls back to [OkJson][], a simple, vendorable JSON parser.
34
60
  * [JSON](https://github.com/flori/json) The default JSON gem with C-extensions (ships with Ruby 1.9)
35
61
  * [JSON Pure](https://github.com/flori/json) A Ruby variant of the JSON gem
36
62
  * [NSJSONSerialization](https://developer.apple.com/library/ios/#documentation/Foundation/Reference/NSJSONSerialization_Class/Reference/Reference.html) Wrapper for Apple's NSJSONSerialization in the Cocoa Framework (MacRuby only)
63
+ * [gson.rb](https://github.com/avsej/gson.rb) A Ruby wrapper for google-gson library (JRuby only)
64
+ * [JrJackson](https://github.com/guyboertje/jrjackson) JRuby wrapper for Jackson (JRuby only)
37
65
  * [OkJson][okjson] A simple, vendorable JSON parser
38
66
 
39
67
  ## Supported Ruby Versions
@@ -43,6 +71,10 @@ implementations:
43
71
  * Ruby 1.8.7
44
72
  * Ruby 1.9.2
45
73
  * Ruby 1.9.3
74
+ * Ruby 2.0.0
75
+ * Ruby 2.1
76
+ * Ruby 2.2.4
77
+ * Ruby 2.3.1
46
78
  * [JRuby][]
47
79
  * [Rubinius][]
48
80
  * [MacRuby][] (not tested on Travis CI)
@@ -51,8 +83,7 @@ implementations:
51
83
  [rubinius]: http://rubini.us/
52
84
  [macruby]: http://www.macruby.org/
53
85
 
54
- If something doesn't work on one of these interpreters, it should be considered
55
- a bug.
86
+ If something doesn't work on one of these interpreters, it's a bug.
56
87
 
57
88
  This library may inadvertently work (or seem to work) on other Ruby
58
89
  implementations, however support will only be provided for the versions listed
@@ -61,9 +92,9 @@ above.
61
92
  If you would like this library to support another Ruby version, you may
62
93
  volunteer to be a maintainer. Being a maintainer entails making sure all tests
63
94
  run and pass on that implementation. When something breaks on your
64
- implementation, you will be personally responsible for providing patches in a
65
- timely fashion. If critical issues for a particular implementation exist at the
66
- time of a major release, support for that Ruby version may be dropped.
95
+ implementation, you will be responsible for providing patches in a timely
96
+ fashion. If critical issues for a particular implementation exist at the time
97
+ of a major release, support for that Ruby version may be dropped.
67
98
 
68
99
  ## Versioning
69
100
 
@@ -76,13 +107,15 @@ introduced with new major versions. As a result of this policy, you can (and
76
107
  should) specify a dependency on this gem using the [Pessimistic Version
77
108
  Constraint][pvc] with two digits of precision. For example:
78
109
 
79
- spec.add_dependency 'multi_json', '~> 1.0'
110
+ ```ruby
111
+ spec.add_dependency 'multi_json', '~> 1.0'
112
+ ```
80
113
 
81
114
  [semver]: http://semver.org/
82
115
  [pvc]: http://docs.rubygems.org/read/chapter/16#page74
83
116
 
84
117
  ## Copyright
85
- Copyright (c) 2010 Michael Bleigh, Josh Kalderimis, Erik Michaels-Ober, and Intridea, Inc.
86
- See [LICENSE][] for details.
118
+ Copyright (c) 2010-2013 Michael Bleigh, Josh Kalderimis, Erik Michaels-Ober,
119
+ and Pavel Pravosud. See [LICENSE][] for details.
87
120
 
88
- [license]: https://github.com/intridea/multi_json/blob/master/LICENSE.md
121
+ [license]: LICENSE.md
@@ -0,0 +1,49 @@
1
+ require 'singleton'
2
+ require 'multi_json/options'
3
+
4
+ module MultiJson
5
+ class Adapter
6
+ extend Options
7
+ include Singleton
8
+
9
+ class << self
10
+ def defaults(action, value)
11
+ metaclass = class << self; self; end
12
+
13
+ metaclass.instance_eval do
14
+ define_method("default_#{action}_options") { value }
15
+ end
16
+ end
17
+
18
+ def load(string, options = {})
19
+ fail self::ParseError if blank?(string)
20
+ string = string.read if string.respond_to?(:read)
21
+ instance.load(string, cached_load_options(options))
22
+ end
23
+
24
+ def dump(object, options = {})
25
+ instance.dump(object, cached_dump_options(options))
26
+ end
27
+
28
+ private
29
+
30
+ def blank?(input)
31
+ input.nil? || /\A\s*\z/ === input
32
+ rescue ArgumentError # invalid byte sequence in UTF-8
33
+ false
34
+ end
35
+
36
+ def cached_dump_options(options)
37
+ OptionsCache.fetch(:dump, options) do
38
+ dump_options(options).merge(MultiJson.dump_options(options)).merge!(options)
39
+ end
40
+ end
41
+
42
+ def cached_load_options(options)
43
+ OptionsCache.fetch(:load, options) do
44
+ load_options(options).merge(MultiJson.load_options(options)).merge!(options)
45
+ end
46
+ end
47
+ end
48
+ end
49
+ end
@@ -0,0 +1,15 @@
1
+ module MultiJson
2
+ class AdapterError < ArgumentError
3
+ attr_reader :cause
4
+
5
+ def self.build(original_exception)
6
+ message = "Did not recognize your adapter specification (#{original_exception.message})."
7
+ new(message).tap do |exception|
8
+ exception.instance_eval do
9
+ @cause = original_exception
10
+ set_backtrace original_exception.backtrace
11
+ end
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,20 @@
1
+ require 'gson'
2
+ require 'stringio'
3
+ require 'multi_json/adapter'
4
+
5
+ module MultiJson
6
+ module Adapters
7
+ # Use the gson.rb library to dump/load.
8
+ class Gson < Adapter
9
+ ParseError = ::Gson::DecodeError
10
+
11
+ def load(string, options = {})
12
+ ::Gson::Decoder.new(options).decode(string)
13
+ end
14
+
15
+ def dump(object, options = {})
16
+ ::Gson::Encoder.new(options).encode(object)
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,25 @@
1
+ require 'jrjackson' unless defined?(::JrJackson)
2
+ require 'multi_json/adapter'
3
+
4
+ module MultiJson
5
+ module Adapters
6
+ # Use the jrjackson.rb library to dump/load.
7
+ class JrJackson < Adapter
8
+ ParseError = ::JrJackson::ParseError
9
+
10
+ def load(string, options = {}) #:nodoc:
11
+ ::JrJackson::Json.load(string, options)
12
+ end
13
+
14
+ if ::JrJackson::Json.method(:dump).arity == 1
15
+ def dump(object, _)
16
+ ::JrJackson::Json.dump(object)
17
+ end
18
+ else
19
+ def dump(object, options = {})
20
+ ::JrJackson::Json.dump(object, options)
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
@@ -1,25 +1,23 @@
1
+ require 'multi_json/adapter'
2
+
1
3
  module MultiJson
2
4
  module Adapters
3
- module JsonCommon
5
+ class JsonCommon < Adapter
6
+ defaults :load, :create_additions => false, :quirks_mode => true
4
7
 
5
- def load(string, options={})
6
- string = string.read if string.respond_to?(:read)
7
- ::JSON.parse(string, :symbolize_names => options[:symbolize_keys], :quirks_mode => true)
8
- end
8
+ def load(string, options = {})
9
+ if string.respond_to?(:force_encoding)
10
+ string = string.dup.force_encoding(::Encoding::ASCII_8BIT)
11
+ end
9
12
 
10
- def dump(object, options={})
11
- object.to_json(process_options(options))
13
+ options[:symbolize_names] = true if options.delete(:symbolize_keys)
14
+ ::JSON.parse(string, options)
12
15
  end
13
16
 
14
- protected
15
-
16
- def process_options(options={})
17
- return options if options.empty?
18
- opts = {}
19
- opts.merge!(JSON::PRETTY_STATE_PROTOTYPE.to_h) if options.delete(:pretty)
20
- opts.merge!(options)
17
+ def dump(object, options = {})
18
+ options.merge!(::JSON::PRETTY_STATE_PROTOTYPE.to_h) if options.delete(:pretty)
19
+ object.to_json(options)
21
20
  end
22
-
23
21
  end
24
22
  end
25
23
  end
@@ -1,12 +1,11 @@
1
- require 'json' unless defined?(::JSON)
1
+ require 'json/ext'
2
2
  require 'multi_json/adapters/json_common'
3
3
 
4
4
  module MultiJson
5
5
  module Adapters
6
6
  # Use the JSON gem to dump/load.
7
- class JsonGem
7
+ class JsonGem < JsonCommon
8
8
  ParseError = ::JSON::ParserError
9
- extend JsonCommon
10
9
  end
11
10
  end
12
11
  end
@@ -1,12 +1,11 @@
1
- require 'json/pure' unless defined?(::JSON)
1
+ require 'json/pure'
2
2
  require 'multi_json/adapters/json_common'
3
3
 
4
4
  module MultiJson
5
5
  module Adapters
6
6
  # Use JSON pure to dump/load.
7
- class JsonPure
7
+ class JsonPure < JsonCommon
8
8
  ParseError = ::JSON::ParserError
9
- extend JsonCommon
10
9
  end
11
10
  end
12
11
  end
@@ -6,29 +6,27 @@ module MultiJson
6
6
  class Nsjsonserialization < MultiJson::Adapters::OkJson
7
7
  ParseError = ::MultiJson::OkJson::Error
8
8
 
9
- def self.load(string, options={})
10
- string = string.read if string.respond_to?(:read)
9
+ def load(string, options = {})
11
10
  data = string.dataUsingEncoding(NSUTF8StringEncoding)
12
- object = NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingMutableContainers | NSJSONReadingMutableLeaves, error: nil)
11
+ object = NSJSONSerialization.JSONObjectWithData(data, :options => NSJSONReadingMutableContainers | NSJSONReadingMutableLeaves, :error => nil)
13
12
  if object
14
13
  object = symbolize_keys(object) if options[:symbolize_keys]
15
14
  object
16
15
  else
17
- super(string, options={})
16
+ super(string, options)
18
17
  end
19
18
  end
20
19
 
21
- def self.dump(object, options={})
20
+ def dump(object, options = {})
22
21
  pretty = options[:pretty] ? NSJSONWritingPrettyPrinted : 0
23
22
  object = object.as_json if object.respond_to?(:as_json)
24
23
  if NSJSONSerialization.isValidJSONObject(object)
25
- data = NSJSONSerialization.dataWithJSONObject(object, options: pretty, error: nil)
26
- NSMutableString.alloc.initWithData(data, encoding: NSUTF8StringEncoding)
24
+ data = NSJSONSerialization.dataWithJSONObject(object, :options => pretty, :error => nil)
25
+ NSMutableString.alloc.initWithData(data, :encoding => NSUTF8StringEncoding)
27
26
  else
28
27
  super(object, options)
29
28
  end
30
29
  end
31
-
32
30
  end
33
31
  end
34
32
  end