restify 2.0.1 → 2.0.2
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 +4 -4
- data/CHANGELOG.md +8 -0
- data/lib/restify/relation.rb +6 -2
- data/lib/restify/version.rb +1 -1
- data/spec/restify/relation_spec.rb +54 -1
- data/vendor/bundle/ruby/3.4.0/bundler/gems/my-rubocop-3bcd2110ca87/LICENSE +21 -0
- data/vendor/bundle/ruby/3.4.0/bundler/gems/my-rubocop-3bcd2110ca87/README.md +23 -0
- data/vendor/bundle/ruby/3.4.0/gems/activesupport-8.0.2/CHANGELOG.md +255 -0
- data/vendor/bundle/ruby/3.4.0/gems/activesupport-8.0.2/MIT-LICENSE +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/activesupport-8.0.2/README.rdoc +40 -0
- data/vendor/bundle/ruby/3.4.0/gems/addressable-2.8.7/CHANGELOG.md +301 -0
- data/vendor/bundle/ruby/3.4.0/gems/addressable-2.8.7/LICENSE.txt +202 -0
- data/vendor/bundle/ruby/3.4.0/gems/addressable-2.8.7/README.md +121 -0
- data/vendor/bundle/ruby/3.4.0/gems/base64-0.2.0/LICENSE.txt +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/base64-0.2.0/README.md +48 -0
- data/vendor/bundle/ruby/3.4.0/gems/benchmark-0.4.0/README.md +138 -0
- data/vendor/bundle/ruby/3.4.0/gems/bigdecimal-3.1.9/LICENSE +56 -0
- data/vendor/bundle/ruby/3.4.0/gems/concurrent-ruby-1.3.5/CHANGELOG.md +603 -0
- data/vendor/bundle/ruby/3.4.0/gems/concurrent-ruby-1.3.5/LICENSE.txt +21 -0
- data/vendor/bundle/ruby/3.4.0/gems/concurrent-ruby-1.3.5/README.md +407 -0
- data/vendor/bundle/ruby/3.4.0/gems/connection_pool-2.5.3/LICENSE +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/connection_pool-2.5.3/README.md +167 -0
- data/vendor/bundle/ruby/3.4.0/gems/drb-2.2.1/LICENSE.txt +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/ethon-0.16.0/CHANGELOG.md +375 -0
- data/vendor/bundle/ruby/3.4.0/gems/ethon-0.16.0/LICENSE +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/ethon-0.16.0/README.md +118 -0
- data/vendor/bundle/ruby/3.4.0/gems/ffi-1.17.2-x86_64-linux-gnu/CHANGELOG.md +473 -0
- data/vendor/bundle/ruby/3.4.0/gems/ffi-1.17.2-x86_64-linux-gnu/LICENSE +24 -0
- data/vendor/bundle/ruby/3.4.0/gems/ffi-1.17.2-x86_64-linux-gnu/LICENSE.SPECS +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/ffi-1.17.2-x86_64-linux-gnu/README.md +137 -0
- data/vendor/bundle/ruby/3.4.0/gems/hitimes-3.1.0/LICENSE.txt +16 -0
- data/vendor/bundle/ruby/3.4.0/gems/hitimes-3.1.0/README.md +187 -0
- data/vendor/bundle/ruby/3.4.0/gems/i18n-1.14.7/MIT-LICENSE +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/i18n-1.14.7/README.md +127 -0
- data/vendor/bundle/ruby/3.4.0/gems/little-plugger-1.1.4/README.rdoc +53 -0
- data/vendor/bundle/ruby/3.4.0/gems/logger-1.7.0/README.md +104 -0
- data/vendor/bundle/ruby/3.4.0/gems/logging-2.4.0/LICENSE +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/logging-2.4.0/README.md +140 -0
- data/vendor/bundle/ruby/3.4.0/gems/minitest-5.25.5/README.rdoc +842 -0
- data/vendor/bundle/ruby/3.4.0/gems/msgpack-1.8.0/ChangeLog +368 -0
- data/vendor/bundle/ruby/3.4.0/gems/msgpack-1.8.0/LICENSE +177 -0
- data/vendor/bundle/ruby/3.4.0/gems/msgpack-1.8.0/README.md +302 -0
- data/vendor/bundle/ruby/3.4.0/gems/multi_json-1.15.0/CHANGELOG.md +275 -0
- data/vendor/bundle/ruby/3.4.0/gems/multi_json-1.15.0/LICENSE.md +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/multi_json-1.15.0/README.md +121 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-api-1.5.0/CHANGELOG.md +193 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-api-1.5.0/LICENSE +201 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-api-1.5.0/README.md +68 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-common-0.22.0/CHANGELOG.md +98 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-common-0.22.0/LICENSE +201 -0
- data/vendor/bundle/ruby/3.4.0/gems/opentelemetry-common-0.22.0/README.md +62 -0
- data/vendor/bundle/ruby/3.4.0/gems/public_suffix-6.0.2/CHANGELOG.md +498 -0
- data/vendor/bundle/ruby/3.4.0/gems/public_suffix-6.0.2/LICENSE.txt +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/public_suffix-6.0.2/README.md +222 -0
- data/vendor/bundle/ruby/3.4.0/gems/rack-3.1.15/CHANGELOG.md +1146 -0
- data/vendor/bundle/ruby/3.4.0/gems/rack-3.1.15/MIT-LICENSE +20 -0
- data/vendor/bundle/ruby/3.4.0/gems/rack-3.1.15/README.md +355 -0
- data/vendor/bundle/ruby/3.4.0/gems/rake-13.2.1/MIT-LICENSE +21 -0
- data/vendor/bundle/ruby/3.4.0/gems/rake-13.2.1/README.rdoc +155 -0
- data/vendor/bundle/ruby/3.4.0/gems/rake-release-1.3.0/LICENSE +21 -0
- data/vendor/bundle/ruby/3.4.0/gems/rake-release-1.3.0/README.md +107 -0
- data/vendor/bundle/ruby/3.4.0/gems/securerandom-0.4.1/README.md +72 -0
- data/vendor/bundle/ruby/3.4.0/gems/typhoeus-1.4.1/CHANGELOG.md +410 -0
- data/vendor/bundle/ruby/3.4.0/gems/typhoeus-1.4.1/LICENSE +22 -0
- data/vendor/bundle/ruby/3.4.0/gems/typhoeus-1.4.1/README.md +588 -0
- data/vendor/bundle/ruby/3.4.0/gems/tzinfo-2.0.6/LICENSE +19 -0
- data/vendor/bundle/ruby/3.4.0/gems/tzinfo-2.0.6/README.md +406 -0
- data/vendor/bundle/ruby/3.4.0/gems/uri-1.0.3/README.md +55 -0
- metadata +66 -4
- data/doc/file.README.html +0 -192
@@ -0,0 +1,302 @@
|
|
1
|
+
# MessagePack
|
2
|
+
|
3
|
+
[MessagePack](http://msgpack.org) is an efficient binary serialization format.
|
4
|
+
It lets you exchange data among multiple languages like JSON but it's faster and smaller.
|
5
|
+
For example, small integers (like flags or error code) are encoded into a single byte,
|
6
|
+
and typical short strings only require an extra byte in addition to the strings themselves.
|
7
|
+
|
8
|
+
If you ever wished to use JSON for convenience (storing an image with metadata) but could
|
9
|
+
not for technical reasons (binary data, size, speed...), MessagePack is a perfect replacement.
|
10
|
+
|
11
|
+
```ruby
|
12
|
+
require 'msgpack'
|
13
|
+
msg = [1,2,3].to_msgpack #=> "\x93\x01\x02\x03"
|
14
|
+
MessagePack.unpack(msg) #=> [1,2,3]
|
15
|
+
```
|
16
|
+
|
17
|
+
Add msgpack to your Gemfile to install with Bundler:
|
18
|
+
|
19
|
+
```ruby
|
20
|
+
# Gemfile
|
21
|
+
gem 'msgpack'
|
22
|
+
```
|
23
|
+
|
24
|
+
Or, use RubyGems to install:
|
25
|
+
|
26
|
+
gem install msgpack
|
27
|
+
|
28
|
+
Or, build msgpack-ruby and install from a checked-out msgpack-ruby repository:
|
29
|
+
|
30
|
+
bundle
|
31
|
+
rake
|
32
|
+
gem install --local pkg/msgpack
|
33
|
+
|
34
|
+
|
35
|
+
## Use cases
|
36
|
+
|
37
|
+
* Create REST API returing MessagePack using Rails + [RABL](https://github.com/nesquena/rabl)
|
38
|
+
* Store objects efficiently serialized by msgpack on memcached or Redis
|
39
|
+
* In fact Redis supports msgpack in [EVAL-scripts](https://redis.io/docs/latest/commands/eval/)
|
40
|
+
* Upload data in efficient format from mobile devices such as smartphones
|
41
|
+
* MessagePack works on iPhone/iPad and Android. See also [Objective-C](https://github.com/msgpack/msgpack-objectivec) and [Java](https://github.com/msgpack/msgpack-java) implementations
|
42
|
+
* Design a portable protocol to communicate with embedded devices
|
43
|
+
* Check also [Fluentd](https://www.fluentd.org) which is a log collector which uses msgpack for the log format (they say it uses JSON but actually it's msgpack, which is compatible with JSON)
|
44
|
+
* Exchange objects between software components written in different languages
|
45
|
+
* You'll need a flexible but efficient format so that components exchange objects while keeping compatibility
|
46
|
+
|
47
|
+
## Portability
|
48
|
+
|
49
|
+
MessagePack for Ruby should run on x86, ARM, PowerPC, SPARC and other CPU architectures.
|
50
|
+
|
51
|
+
And it works with MRI (CRuby) and Rubinius.
|
52
|
+
Patches to improve portability are highly welcomed.
|
53
|
+
|
54
|
+
|
55
|
+
## Serializing objects
|
56
|
+
|
57
|
+
Use `MessagePack.pack` or `to_msgpack`:
|
58
|
+
|
59
|
+
```ruby
|
60
|
+
require 'msgpack'
|
61
|
+
msg = MessagePack.pack(obj) # or
|
62
|
+
msg = obj.to_msgpack
|
63
|
+
File.binwrite('mydata.msgpack', msg)
|
64
|
+
```
|
65
|
+
|
66
|
+
### Streaming serialization
|
67
|
+
|
68
|
+
Packer provides advanced API to serialize objects in streaming style:
|
69
|
+
|
70
|
+
```ruby
|
71
|
+
# serialize a 2-element array [e1, e2]
|
72
|
+
pk = MessagePack::Packer.new(io)
|
73
|
+
pk.write_array_header(2).write(e1).write(e2).flush
|
74
|
+
```
|
75
|
+
|
76
|
+
See [API reference](http://ruby.msgpack.org/MessagePack/Packer.html) for details.
|
77
|
+
|
78
|
+
## Deserializing objects
|
79
|
+
|
80
|
+
Use `MessagePack.unpack`:
|
81
|
+
|
82
|
+
```ruby
|
83
|
+
require 'msgpack'
|
84
|
+
msg = File.binread('mydata.msgpack')
|
85
|
+
obj = MessagePack.unpack(msg)
|
86
|
+
```
|
87
|
+
|
88
|
+
### Streaming deserialization
|
89
|
+
|
90
|
+
Unpacker provides advanced API to deserialize objects in streaming style:
|
91
|
+
|
92
|
+
```ruby
|
93
|
+
# deserialize objects from an IO
|
94
|
+
u = MessagePack::Unpacker.new(io)
|
95
|
+
u.each do |obj|
|
96
|
+
# ...
|
97
|
+
end
|
98
|
+
```
|
99
|
+
|
100
|
+
or event-driven style which works well with EventMachine:
|
101
|
+
|
102
|
+
```ruby
|
103
|
+
# event-driven deserialization
|
104
|
+
def on_read(data)
|
105
|
+
@u ||= MessagePack::Unpacker.new
|
106
|
+
@u.feed_each(data) {|obj|
|
107
|
+
# ...
|
108
|
+
}
|
109
|
+
end
|
110
|
+
```
|
111
|
+
|
112
|
+
See [API reference](http://ruby.msgpack.org/MessagePack/Unpacker.html) for details.
|
113
|
+
|
114
|
+
## Serializing and deserializing symbols
|
115
|
+
|
116
|
+
By default, symbols are serialized as strings:
|
117
|
+
|
118
|
+
```ruby
|
119
|
+
packed = :symbol.to_msgpack # => "\xA6symbol"
|
120
|
+
MessagePack.unpack(packed) # => "symbol"
|
121
|
+
```
|
122
|
+
|
123
|
+
This can be customized by registering an extension type for them:
|
124
|
+
|
125
|
+
```ruby
|
126
|
+
MessagePack::DefaultFactory.register_type(0x00, Symbol)
|
127
|
+
|
128
|
+
# symbols now survive round trips
|
129
|
+
packed = :symbol.to_msgpack # => "\xc7\x06\x00symbol"
|
130
|
+
MessagePack.unpack(packed) # => :symbol
|
131
|
+
```
|
132
|
+
|
133
|
+
The extension type for symbols is configurable like any other extension type.
|
134
|
+
For example, to customize how symbols are packed you can just redefine
|
135
|
+
Symbol#to_msgpack_ext. Doing this gives you an option to prevent symbols from
|
136
|
+
being serialized altogether by throwing an exception:
|
137
|
+
|
138
|
+
```ruby
|
139
|
+
class Symbol
|
140
|
+
def to_msgpack_ext
|
141
|
+
raise "Serialization of symbols prohibited"
|
142
|
+
end
|
143
|
+
end
|
144
|
+
|
145
|
+
MessagePack::DefaultFactory.register_type(0x00, Symbol)
|
146
|
+
|
147
|
+
[1, :symbol, 'string'].to_msgpack # => RuntimeError: Serialization of symbols prohibited
|
148
|
+
```
|
149
|
+
|
150
|
+
## Serializing and deserializing Time instances
|
151
|
+
|
152
|
+
There are the timestamp extension type in MessagePack,
|
153
|
+
but it is not registered by default.
|
154
|
+
|
155
|
+
To map Ruby's Time to MessagePack's timestamp for the default factory:
|
156
|
+
|
157
|
+
```ruby
|
158
|
+
MessagePack::DefaultFactory.register_type(
|
159
|
+
MessagePack::Timestamp::TYPE, # or just -1
|
160
|
+
Time,
|
161
|
+
packer: MessagePack::Time::Packer,
|
162
|
+
unpacker: MessagePack::Time::Unpacker
|
163
|
+
)
|
164
|
+
```
|
165
|
+
|
166
|
+
See [API reference](http://ruby.msgpack.org/) for details.
|
167
|
+
|
168
|
+
## Extension Types
|
169
|
+
|
170
|
+
Packer and Unpacker support [Extension types of MessagePack](https://github.com/msgpack/msgpack/blob/master/spec.md#types-extension-type).
|
171
|
+
|
172
|
+
```ruby
|
173
|
+
# register how to serialize custom class at first
|
174
|
+
pk = MessagePack::Packer.new(io)
|
175
|
+
pk.register_type(0x01, MyClass1, :to_msgpack_ext) # equal to pk.register_type(0x01, MyClass)
|
176
|
+
pk.register_type(0x02, MyClass2){|obj| obj.how_to_serialize() } # blocks also available
|
177
|
+
|
178
|
+
# almost same API for unpacker
|
179
|
+
uk = MessagePack::Unpacker.new()
|
180
|
+
uk.register_type(0x01, MyClass1, :from_msgpack_ext)
|
181
|
+
uk.register_type(0x02){|data| MyClass2.create_from_serialized_data(data) }
|
182
|
+
```
|
183
|
+
|
184
|
+
`MessagePack::Factory` is to create packer and unpacker which have same extension types.
|
185
|
+
|
186
|
+
```ruby
|
187
|
+
factory = MessagePack::Factory.new
|
188
|
+
factory.register_type(0x01, MyClass1) # same with next line
|
189
|
+
factory.register_type(0x01, MyClass1, packer: :to_msgpack_ext, unpacker: :from_msgpack_ext)
|
190
|
+
pk = factory.packer(options_for_packer)
|
191
|
+
uk = factory.unpacker(options_for_unpacker)
|
192
|
+
```
|
193
|
+
|
194
|
+
For `MessagePack.pack` and `MessagePack.unpack`, default packer/unpacker refer `MessagePack::DefaultFactory`. Call `MessagePack::DefaultFactory.register_type` to enable types process globally.
|
195
|
+
|
196
|
+
```ruby
|
197
|
+
MessagePack::DefaultFactory.register_type(0x03, MyClass3)
|
198
|
+
MessagePack.unpack(data_with_ext_typeid_03) #=> MyClass3 instance
|
199
|
+
```
|
200
|
+
|
201
|
+
Alternatively, extension types can call the packer or unpacker recursively to generate the extension data:
|
202
|
+
|
203
|
+
```ruby
|
204
|
+
Point = Struct.new(:x, :y)
|
205
|
+
factory = MessagePack::Factory.new
|
206
|
+
factory.register_type(
|
207
|
+
0x01,
|
208
|
+
Point,
|
209
|
+
packer: ->(point, packer) {
|
210
|
+
packer.write(point.x)
|
211
|
+
packer.write(point.y)
|
212
|
+
},
|
213
|
+
unpacker: ->(unpacker) {
|
214
|
+
x = unpacker.read
|
215
|
+
y = unpacker.read
|
216
|
+
Point.new(x, y)
|
217
|
+
},
|
218
|
+
recursive: true,
|
219
|
+
)
|
220
|
+
factory.load(factory.dump(Point.new(12, 34))) # => #<struct Point x=12, y=34>
|
221
|
+
```
|
222
|
+
|
223
|
+
## Pooling
|
224
|
+
|
225
|
+
Creating `Packer` and `Unpacker` objects is expensive. For best performance it is preferable to re-use these objects.
|
226
|
+
|
227
|
+
`MessagePack::Factory#pool` makes that easier:
|
228
|
+
|
229
|
+
```ruby
|
230
|
+
factory = MessagePack::Factory.new
|
231
|
+
factory.register_type(
|
232
|
+
0x01,
|
233
|
+
Point,
|
234
|
+
packer: ->(point, packer) {
|
235
|
+
packer.write(point.x)
|
236
|
+
packer.write(point.y)
|
237
|
+
},
|
238
|
+
unpacker: ->(unpacker) {
|
239
|
+
x = unpacker.read
|
240
|
+
y = unpacker.read
|
241
|
+
Point.new(x, y)
|
242
|
+
},
|
243
|
+
recursive: true,
|
244
|
+
)
|
245
|
+
pool = factory.pool(5) # The pool size should match the number of threads expected to use the factory concurrently.
|
246
|
+
|
247
|
+
pool.load(pool.dump(Point.new(12, 34))) # => #<struct Point x=12, y=34>
|
248
|
+
```
|
249
|
+
|
250
|
+
## Buffer API
|
251
|
+
|
252
|
+
MessagePack for Ruby provides a buffer API so that you can read or write data by hand, not via Packer or Unpacker API.
|
253
|
+
|
254
|
+
This [MessagePack::Buffer](http://ruby.msgpack.org/MessagePack/Buffer.html) is backed with a fixed-length shared memory pool which is very fast for small data (<= 4KB),
|
255
|
+
and has zero-copy capability which significantly affects performance to handle large binary data.
|
256
|
+
|
257
|
+
## How to build and run tests
|
258
|
+
|
259
|
+
Before building msgpack, you need to install bundler and dependencies.
|
260
|
+
|
261
|
+
gem install bundler
|
262
|
+
bundle install
|
263
|
+
|
264
|
+
Then, you can run the tasks as follows:
|
265
|
+
|
266
|
+
### Build
|
267
|
+
|
268
|
+
bundle exec rake build
|
269
|
+
|
270
|
+
### Run tests
|
271
|
+
|
272
|
+
bundle exec rake spec
|
273
|
+
|
274
|
+
### Generating docs
|
275
|
+
|
276
|
+
bundle exec rake doc
|
277
|
+
|
278
|
+
## How to build -java rubygems
|
279
|
+
|
280
|
+
To build -java gems for JRuby, run:
|
281
|
+
|
282
|
+
rake build:java
|
283
|
+
|
284
|
+
If this directory has Gemfile.lock (generated with MRI), remove it beforehand.
|
285
|
+
|
286
|
+
## Updating documents
|
287
|
+
|
288
|
+
Online documentation (https://ruby.msgpack.org) is generated from the gh-pages branch.
|
289
|
+
To update documents in gh-pages branch:
|
290
|
+
|
291
|
+
bundle exec rake doc
|
292
|
+
git checkout gh-pages
|
293
|
+
cp doc/* ./ -a
|
294
|
+
|
295
|
+
## Copyright
|
296
|
+
|
297
|
+
* Author
|
298
|
+
* Sadayuki Furuhashi <frsyuki@gmail.com>
|
299
|
+
* Copyright
|
300
|
+
* Copyright (c) 2008-2015 Sadayuki Furuhashi
|
301
|
+
* License
|
302
|
+
* Apache License, Version 2.0
|
@@ -0,0 +1,275 @@
|
|
1
|
+
1.14.2
|
2
|
+
------
|
3
|
+
|
4
|
+
* [Improve detection of json_gem adapter](https://github.com/intridea/multi_json/commit/62d54019b17ebf83b28c8deb871a02a122e7d9cf)
|
5
|
+
|
6
|
+
1.14.1
|
7
|
+
------
|
8
|
+
|
9
|
+
* [Fix a warning in Ruby 2.7](https://github.com/intridea/multi_json/commit/26a94ab8c78a394cc237e2ea292c1de4f6ed30d7)
|
10
|
+
|
11
|
+
1.14.0
|
12
|
+
------
|
13
|
+
|
14
|
+
* [Support Oj 3.x gem](https://github.com/intridea/multi_json/commit/5d8febdbebc428882811b90d514f3628617a61d5)
|
15
|
+
|
16
|
+
1.13.1
|
17
|
+
------
|
18
|
+
|
19
|
+
* [Fix missing stdlib set dependency in oj adapter](https://github.com/intridea/multi_json/commit/c4ff66e7bee6fb4f45e54429813d7fada1c152b8)
|
20
|
+
|
21
|
+
1.13.0
|
22
|
+
-----
|
23
|
+
|
24
|
+
* [Make Oj adapter handle JSON::ParseError correctly](https://github.com/intridea/multi_json/commit/275e3ffd8169797c510d23d9ef5b8b07e64c3b42)
|
25
|
+
|
26
|
+
1.12.2
|
27
|
+
------
|
28
|
+
|
29
|
+
* [Renew gem certificate](https://github.com/intridea/multi_json/commit/57922d898c6eb587cc9a28ba5724c11e81724700)
|
30
|
+
|
31
|
+
1.12.1
|
32
|
+
------
|
33
|
+
|
34
|
+
* [Prevent memory leak in OptionsCache](https://github.com/intridea/multi_json/commit/aa7498199ad272f3d4a13750d7c568a66047e2ee)
|
35
|
+
|
36
|
+
1.12.0
|
37
|
+
------
|
38
|
+
|
39
|
+
* [Introduce global options cache to improve peroformance](https://github.com/intridea/multi_json/commit/7aaef2a1bc2b83c95e4208b12dad5d1d87ff20a6)
|
40
|
+
|
41
|
+
1.11.2
|
42
|
+
------
|
43
|
+
|
44
|
+
* [Only pass one argument to JrJackson when two is not supported](https://github.com/intridea/multi_json/commit/e798fa517c817fc706982d3f3c61129b6651d601)
|
45
|
+
|
46
|
+
1.11.1
|
47
|
+
------
|
48
|
+
|
49
|
+
* [Dump method passes options throught for JrJackson adapter](https://github.com/intridea/multi_json/commit/3c730fd12135c3e7bf212f878958004908f13909)
|
50
|
+
|
51
|
+
1.11.0
|
52
|
+
------
|
53
|
+
|
54
|
+
* [Make all adapters read IO object before load](https://github.com/intridea/multi_json/commit/167f559e18d4efee05e1f160a2661d16dbb215d4)
|
55
|
+
|
56
|
+
1.10.1
|
57
|
+
------
|
58
|
+
* [Explicitly require stringio for Gson adapter](https://github.com/intridea/multi_json/commit/623ec8142d4a212fa0db763bb71295789a119929)
|
59
|
+
* [Do not read StringIO object before passing it to JrJackson](https://github.com/intridea/multi_json/commit/a6dc935df08e7b3d5d701fbb9298384c96df0fde)
|
60
|
+
|
61
|
+
1.10.0
|
62
|
+
------
|
63
|
+
* [Performance tweaks](https://github.com/intridea/multi_json/commit/58724acfed31866d079eaafb1cd824e341ade287)
|
64
|
+
|
65
|
+
1.9.3
|
66
|
+
-----
|
67
|
+
* [Convert indent option to Fixnum before passing to Oj](https://github.com/intridea/multi_json/commit/826fc5535b863b74fc9f981dfdda3e26f1ee4e5b)
|
68
|
+
|
69
|
+
1.9.2
|
70
|
+
-----
|
71
|
+
* [Enable use_to_json option for Oj adapter by default](https://github.com/intridea/multi_json/commit/76a4aaf697b10bbabd5d535d83cf1149efcfe5c7)
|
72
|
+
|
73
|
+
1.9.1
|
74
|
+
-----
|
75
|
+
* [Remove unused LoadError file](https://github.com/intridea/multi_json/commit/65dedd84d59baeefc25c477fedf0bbe85e7ce2cd)
|
76
|
+
|
77
|
+
1.9.0
|
78
|
+
----
|
79
|
+
* [Rename LoadError to ParseError](https://github.com/intridea/multi_json/commit/4abb98fe3a90b2a7b3d1594515c8a06042b4a27d)
|
80
|
+
* [Adapter load failure throws AdapterError instead of ArgumentError](https://github.com/intridea/multi_json/commit/4da612b617bd932bb6fa1cc4c43210327f98f271)
|
81
|
+
|
82
|
+
1.8.4
|
83
|
+
-----
|
84
|
+
* [Make Gson adapter explicitly read StringIO object](https://github.com/intridea/multi_json/commit/b58b498747ff6e94f41488c971b2a30a98760ef2)
|
85
|
+
|
86
|
+
1.8.3
|
87
|
+
-----
|
88
|
+
* [Make JrJackson explicitly read StringIO objects](https://github.com/intridea/multi_json/commit/e1f162d5b668e5e4db5afa175361a601a8aa2b05)
|
89
|
+
* [Prevent calling #downcase on alias symbols](https://github.com/intridea/multi_json/commit/c1cf075453ce0110f7decc4f906444b1233bb67c)
|
90
|
+
|
91
|
+
1.8.2
|
92
|
+
-----
|
93
|
+
* [Downcase adapter string name for OS compatibility](https://github.com/intridea/multi_json/commit/b8e15a032247a63f1410d21a18add05035f3fa66)
|
94
|
+
|
95
|
+
1.8.1
|
96
|
+
-----
|
97
|
+
* [Let the adapter handle strings with invalid encoding](https://github.com/intridea/multi_json/commit/6af2bf87b89f44eabf2ae9ca96779febc65ea94b)
|
98
|
+
|
99
|
+
1.8.0
|
100
|
+
-----
|
101
|
+
* [Raise MultiJson::LoadError on blank input](https://github.com/intridea/multi_json/commit/c44f9c928bb25fe672246ad394b3e5b991be32e6)
|
102
|
+
|
103
|
+
1.7.9
|
104
|
+
-----
|
105
|
+
* [Explicitly require json gem code even when constant is defined](https://github.com/intridea/multi_json/commit/36f7906c66477eb4b55b7afeaa3684b6db69eff2)
|
106
|
+
|
107
|
+
1.7.8
|
108
|
+
-----
|
109
|
+
* [Reorder JrJackson before json_gem](https://github.com/intridea/multi_json/commit/315b6e460b6e4dcdb6c82e04e4be8ee975d395da)
|
110
|
+
* [Update vendored OkJson to version 43](https://github.com/intridea/multi_json/commit/99a6b662f6ef4036e3ee94d7eb547fa72fb2ab50)
|
111
|
+
|
112
|
+
1.7.7
|
113
|
+
-----
|
114
|
+
* [Fix options caching issues](https://github.com/intridea/multi_json/commit/a3f14c3661688c5927638fa6088c7b46a67e875e)
|
115
|
+
|
116
|
+
1.7.6
|
117
|
+
-----
|
118
|
+
* [Bring back MultiJson::VERSION constant](https://github.com/intridea/multi_json/commit/31b990c2725e6673bf8ce57540fe66b57a751a72)
|
119
|
+
|
120
|
+
1.7.5
|
121
|
+
-----
|
122
|
+
* [Fix warning '*' interpreted as argument prefix](https://github.com/intridea/multi_json/commit/b698962c7f64430222a1f06430669706a47aff89)
|
123
|
+
* [Remove stdlib warning](https://github.com/intridea/multi_json/commit/d06eec6b7996ac8b4ff0e2229efd835379b0c30f)
|
124
|
+
|
125
|
+
1.7.4
|
126
|
+
-----
|
127
|
+
* [Cache options for better performance](https://github.com/intridea/multi_json/commit/8a26ee93140c4bed36194ed9fb887a1b6919257b)
|
128
|
+
|
129
|
+
1.7.3
|
130
|
+
-----
|
131
|
+
* [Require json/ext to ensure extension version gets loaded for json_gem](https://github.com/intridea/multi_json/commit/942686f7e8597418c6f90ee69e1d45242fac07b1)
|
132
|
+
* [Rename JrJackson](https://github.com/intridea/multi_json/commit/078de7ba8b6035343c3e96b4767549e9ec43369a)
|
133
|
+
* [Prefer JrJackson to JSON gem if present](https://github.com/intridea/multi_json/commit/af8bd9799a66855f04b3aff1c488485950cec7bf)
|
134
|
+
* [Print a warning if outdated gem versions are used](https://github.com/intridea/multi_json/commit/e7438e7ba2be0236cfa24c2bb9ad40ee821286d1)
|
135
|
+
* [Loosen required_rubygems_version for compatibility with Ubuntu 10.04](https://github.com/intridea/multi_json/commit/59fad014e8fe41dbc6f09485ea0dc21fc42fd7a7)
|
136
|
+
|
137
|
+
1.7.2
|
138
|
+
-----
|
139
|
+
* [Rename Jrjackson adapter to JrJackson](https://github.com/intridea/multi_json/commit/b36dc915fc0e6548cbad06b5db6f520e040c9c8b)
|
140
|
+
* [Implement jrjackson -> jr_jackson alias for back-compatability](https://github.com/intridea/multi_json/commit/aa50ab8b7bb646b8b75d5d65dfeadae8248a4f10)
|
141
|
+
* [Update vendored OkJson module](https://github.com/intridea/multi_json/commit/30a3f474e17dd86a697c3fab04f468d1a4fd69d7)
|
142
|
+
|
143
|
+
1.7.1
|
144
|
+
-----
|
145
|
+
* [Fix capitalization of JrJackson class](https://github.com/intridea/multi_json/commit/5373a5e38c647f02427a0477cb8e0e0dafad1b8d)
|
146
|
+
|
147
|
+
1.7.0
|
148
|
+
-----
|
149
|
+
* [Add load_options/dump_options to MultiJson](https://github.com/intridea/multi_json/commit/a153956be6b0df06ea1705ce3c1ff0b5b0e27ea5)
|
150
|
+
* [MultiJson does not modify arguments](https://github.com/intridea/multi_json/commit/58525b01c4c2f6635ba2ac13d6fd987b79f3962f)
|
151
|
+
* [Enable quirks_mode by default for json_gem/json_pure adapters](https://github.com/intridea/multi_json/commit/1fd4e6635c436515b7d7d5a0bee4548de8571520)
|
152
|
+
* [Add JrJackson adapter](https://github.com/intridea/multi_json/commit/4dd86fa96300aaaf6d762578b9b31ea82adb056d)
|
153
|
+
* [Raise ArgumentError on bad adapter input](https://github.com/intridea/multi_json/commit/911a3756bdff2cb5ac06497da3fa3e72199cb7ad)
|
154
|
+
|
155
|
+
1.6.1
|
156
|
+
-----
|
157
|
+
* [Revert "Use JSON.generate instead of #to_json"](https://github.com/intridea/multi_json/issues/86)
|
158
|
+
|
159
|
+
1.6.0
|
160
|
+
-----
|
161
|
+
* [Add gson.rb support](https://github.com/intridea/multi_json/pull/71)
|
162
|
+
* [Add MultiJson.default_options](https://github.com/intridea/multi_json/pull/70)
|
163
|
+
* [Add MultiJson.with_adapter](https://github.com/intridea/multi_json/pull/67)
|
164
|
+
* [Stringify all possible keys for ok_json](https://github.com/intridea/multi_json/pull/66)
|
165
|
+
* [Use JSON.generate instead of #to_json](https://github.com/intridea/multi_json/issues/73)
|
166
|
+
* [Alias `MultiJson::DecodeError` to `MultiJson::LoadError`](https://github.com/intridea/multi_json/pull/79)
|
167
|
+
|
168
|
+
1.5.1
|
169
|
+
-----
|
170
|
+
* [Do not allow Oj or JSON to create symbols by searching for classes](https://github.com/intridea/multi_json/commit/193e28cf4dc61b6e7b7b7d80f06f74c76df65c41)
|
171
|
+
|
172
|
+
1.5.0
|
173
|
+
-----
|
174
|
+
* [Add `MultiJson.with_adapter` method](https://github.com/intridea/multi_json/commit/d14c5d28cae96557a0421298621b9499e1f28104)
|
175
|
+
* [Stringify all possible keys for `ok_json`](https://github.com/intridea/multi_json/commit/73998074058e1e58c557ffa7b9541d486d6041fa)
|
176
|
+
|
177
|
+
1.4.0
|
178
|
+
-----
|
179
|
+
* [Allow `load`/`dump` of JSON fragments](https://github.com/intridea/multi_json/commit/707aae7d48d39c85b38febbd2c210ba87f6e4a36)
|
180
|
+
|
181
|
+
1.3.7
|
182
|
+
-----
|
183
|
+
* [Fix rescue clause for MagLev](https://github.com/intridea/multi_json/commit/39abdf50199828c50e85b2ce8f8ba31fcbbc9332)
|
184
|
+
* [Remove unnecessary check for string version of options key](https://github.com/intridea/multi_json/commit/660101b70e962b3c007d0b90d45944fa47d13ec4)
|
185
|
+
* [Explicitly set default adapter when adapter is set to `nil` or `false`](https://github.com/intridea/multi_json/commit/a9e587d5a63eafb4baee9fb211265e4dd96a26bc)
|
186
|
+
* [Fix Oj `ParseError` mapping for Oj 1.4.0](https://github.com/intridea/multi_json/commit/7d9045338cc9029401c16f3c409d54ce97f275e2)
|
187
|
+
|
188
|
+
1.3.6
|
189
|
+
-----
|
190
|
+
* [Allow adapter-specific options to be passed through to Oj](https://github.com/intridea/multi_json/commit/d0e5feeebcba0bc69400dd203a295f5c30971223)
|
191
|
+
|
192
|
+
1.3.5
|
193
|
+
-----
|
194
|
+
* [Add pretty support to Oj adapter](https://github.com/intridea/multi_json/commit/0c8f75f03020c53bcf4c6be258faf433d24b2c2b)
|
195
|
+
|
196
|
+
1.3.4
|
197
|
+
-----
|
198
|
+
* [Use `class << self` instead of `module_function` to create aliases](https://github.com/intridea/multi_json/commit/ba1451c4c48baa297e049889be241a424cb05980)
|
199
|
+
|
200
|
+
1.3.3
|
201
|
+
-----
|
202
|
+
* [Remove deprecation warnings](https://github.com/intridea/multi_json/commit/36b524e71544eb0186826a891bcc03b2820a008f)
|
203
|
+
|
204
|
+
1.3.2
|
205
|
+
-----
|
206
|
+
* [Add ability to use adapter per call](https://github.com/intridea/multi_json/commit/106bbec469d5d0a832bfa31fffcb8c0f0cdc9bd3)
|
207
|
+
* [Add and deprecate `default_engine` method](https://github.com/intridea/multi_json/commit/fc3df0c7a3e2ab9ce0c2c7e7617a4da97dd13f6e)
|
208
|
+
|
209
|
+
1.3.1
|
210
|
+
-----
|
211
|
+
* [Only warn once for each instance a deprecated method is called](https://github.com/intridea/multi_json/commit/e21d6eb7da74b3f283995c1d27d5880e75f0ae84)
|
212
|
+
|
213
|
+
1.3.0
|
214
|
+
-----
|
215
|
+
* [Implement `load`/`dump`; deprecate `decode`/`encode`](https://github.com/intridea/multi_json/commit/e90fd6cb1b0293eb0c73c2f4eb0f7a1764370216)
|
216
|
+
* [Rename engines to adapters](https://github.com/intridea/multi_json/commit/ae7fd144a7949a9c221dcaa446196ec23db908df)
|
217
|
+
|
218
|
+
1.2.0
|
219
|
+
-----
|
220
|
+
* [Add support for Oj](https://github.com/intridea/multi_json/commit/acd06b233edabe6c44f226873db7b49dab560c60)
|
221
|
+
|
222
|
+
1.1.0
|
223
|
+
-----
|
224
|
+
* [`NSJSONSerialization` support for MacRuby](https://github.com/intridea/multi_json/commit/f862e2fc966cac8867fe7da3997fc76e8a6cf5d4)
|
225
|
+
|
226
|
+
1.0.4
|
227
|
+
-----
|
228
|
+
* [Set data context to `DecodeError` exception](https://github.com/intridea/multi_json/commit/19ddafd44029c6681f66fae2a0f6eabfd0f85176)
|
229
|
+
* [Allow `ok_json` to fallback to `to_json`](https://github.com/intridea/multi_json/commit/c157240b1193b283d06d1bd4d4b5b06bcf3761f8)
|
230
|
+
* [Add warning when using `ok_json`](https://github.com/intridea/multi_json/commit/dd4b68810c84f826fb98f9713bfb29ab96888d57)
|
231
|
+
* [Options can be passed to an engine on encode](https://github.com/intridea/multi_json/commit/e0a7ff5d5ff621ffccc61617ed8aeec5816e81f7)
|
232
|
+
|
233
|
+
1.0.3
|
234
|
+
-----
|
235
|
+
* [`Array` support for `stringify_keys`](https://github.com/intridea/multi_json/commit/644d1c5c7c7f6a27663b11668527b346094e38b9)
|
236
|
+
* [`Array` support for `symbolize_keys`](https://github.com/intridea/multi_json/commit/c885377d47a2aa39cb0d971fea78db2d2fa479a7)
|
237
|
+
|
238
|
+
1.0.2
|
239
|
+
-----
|
240
|
+
* [Allow encoding of rootless JSON when `ok_json` is used](https://github.com/intridea/multi_json/commit/d1cde7de97cb0f6152aef8daf14037521cdce8c6)
|
241
|
+
|
242
|
+
1.0.1
|
243
|
+
-----
|
244
|
+
* [Correct an issue with `ok_json` not being returned as the default engine](https://github.com/intridea/multi_json/commit/d33c141619c54cccd770199694da8fd1bd8f449d)
|
245
|
+
|
246
|
+
1.0.0
|
247
|
+
-----
|
248
|
+
* [Remove `ActiveSupport::JSON` support](https://github.com/intridea/multi_json/commit/c2f4140141d785a24b3f56e58811b0e561b37f6a)
|
249
|
+
* [Fix `@engine` ivar warning](https://github.com/intridea/multi_json/commit/3b978a8995721a8dffedc3b75a7f49e5494ec553)
|
250
|
+
* [Only `rescue` from parsing errors during decoding, not any `StandardError`](https://github.com/intridea/multi_json/commit/391d00b5e85294d42d41347605d8d46b4a7f66cc)
|
251
|
+
* [Rename `okjson` engine and vendored lib to `ok_json`](https://github.com/intridea/multi_json/commit/5bd1afc977a8208ddb0443e1d57cb79665c019f1)
|
252
|
+
* [Add `StringIO` support to `json` gem and `ok_json`](https://github.com/intridea/multi_json/commit/1706b11568db7f50af451fce5f4d679aeb3bbe8f)
|
253
|
+
|
254
|
+
0.0.5
|
255
|
+
-----
|
256
|
+
* [Trap all JSON decoding errors; raise `MultiJson::DecodeError`](https://github.com/intridea/multi_json/commit/dea9a1aef6dd1212aa1e5a37ab1669f9b045b732)
|
257
|
+
|
258
|
+
0.0.4
|
259
|
+
-----
|
260
|
+
* [Fix default_engine check for `json` gem](https://github.com/intridea/multi_json/commit/caced0c4e8c795922a109ebc00c3c4fa8635bed8)
|
261
|
+
* [Make requirement mapper an `Array` to preserve order in Ruby versions < 1.9](https://github.com/intridea/multi_json/commit/526f5f29a42131574a088ad9bbb43d7f48439b2c)
|
262
|
+
|
263
|
+
0.0.3
|
264
|
+
-----
|
265
|
+
* [Improve defaulting and documentation](https://github.com/sferik/twitter/commit/3a0e41b9e4b0909201045fa47704b78c9d949b73)
|
266
|
+
|
267
|
+
0.0.2
|
268
|
+
-----
|
269
|
+
|
270
|
+
* [Rename to `multi_json`](https://github.com/sferik/twitter/commit/461ab89ce071c8c9fabfc183581e0ec523788b62)
|
271
|
+
|
272
|
+
0.0.1
|
273
|
+
-----
|
274
|
+
|
275
|
+
* [Initial commit](https://github.com/sferik/twitter/commit/518c21ab299c500527491e6c049ab2229e22a805)
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright (c) 2010-2013 Michael Bleigh, Josh Kalderimis, Erik Michaels-Ober, Pavel Pravosud
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|