/
History.txt
284 lines (219 loc) · 11.5 KB
/
History.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
== 0.9.2 / 20111115
* Removed all references to the version4 API.
* Dropped support for 3.0.x and added support for 3.1.x. The 0mq
community has pretty much voted to abandon the path taken in 3.0
so the 3.1 branch is the API that will be supported.
* Fixed a bug in Poller#delete where it would erroneously return
false even when it successfully deleted a socket. Issue 46.
* All specs pass for 2.1.x API.
* 3 specs fail when run with 3.1 API; these are due to bugs in the
0mq library and are *not* ffi-rzmq bugs.
* Rescue LoadErrors when loading libzmq. Print a warning about
adding libzmq.dll to the Windows PATH for that platform. Print
the search paths where the gem looks for libzmq.
== 0.9.1 / 20111027
* Moved LibC and LibZMQ into the ZMQ module namespace. Necessary to
avoid namespace collisions with other libraries that also use
the constants LibC and/or LibZMQ.
* Fixed a bug where file descriptors registered on Poll were never
returned as readable or writable.
* Added Socket#recv_multipart. This returns the message body and
return address envelope as separate arrays. Only to be used with
XREQ/XREP/DEALER/ROUTER sockets.
== 0.9.0 / 20110930
* Changed the behavior of every method that used to produce exceptions.
The methods now behave more like the C API functions. They return
result codes instead of raising exceptions. Further, the "receive"
methods on Socket now all take an empty string as a buffer to read
the message into.
This is a BREAKING CHANGE and is NOT backward compatible with earlier
releases. I apologize for the inconvenience, but this API will be
much easier to test/spec and maintain. It will also allow for the
production of more logical code.
* Major refactoring of Socket internals so that a single gem can
support libzmq 2.x, 3.x and 4.x APIs without any user intervention.
The correct libzmq version is detected at runtime and used to
configure the Ruby classes to conform to the proper API.
* Added Socket#recvmsgs as a convenience method for receiving a
multipart message into an array of Messages.
* Added support for new 0mq API introduced in the 3.0 branch.
API mostly changed for sending and receiving messages with new
POSIX-compliant send() and recv() functions. The original
functions were renamed sendmsg() and recvmsg().
Additionally, most getsockopt() and setsockopt() calls now use
an int (4 bytes) instead of a mish-mash of 32-bit and 64-bit
values.
For a full list of differences, visit the 0mq wiki page at:
http://www.zeromq.org/docs:3-0-upgrade
* Created a new ext/ directory so that users can copy the libzmq*
library files directly into the gem for easier distribution. This
path is checked *before* the usual system paths.
* Rewrote all examples to use the revised API.
== 0.8.2 / 20110728
* Fixed major bug with Socket#setsockopt when writing 8-byte longs.
* Clarified a bit of logic for non-blocking sends.
* Improved readability of exceptions.
== 0.8.1 / 20110504
* Fixed bug where Socket#setsockopt was using a size from the current
runtime to determine how many bytes to use for HWM, et al. This was
incorrect. All of those socket options require 8 bytes. Discovered
this while getting the code running under mingw on Windows using a
32-bit Ruby runtime.
== 0.8.0 / 20110307
* API change!
Socket#send_message no longer automatically calls
Message#close on behalf of the user. The user is completely
responsible for the lifecycle management of all buffers associated
with the ZMQ::Message objects.
This is a breaking change.
If you want the old behavior (auto-close messages on send) then
use the new Socket#send_and_close method which does as its name
implies.
* Fixed bug with type :size_t on Windows (thank you to arvicco)
== 0.7.3 / 20110304
* Fixed a bug where we had a small memory leak. When closing a socket
I forgot to release a small amount of native memory used as a cache
for doing #getsockopt calls.
* Util.minimum_api? didn't work. Fixed.
* Added ROUTER/DEALER constants to reflect new naming for XREQ/XREP.
XREQ and XREP remain aliased for backward compatibility.
== 0.7.2 / 20110224
* Several minor refactorings to make the code intent clearer and to allow
for better testing. In particular, the error condition checking for
a non-blocking send/recv is much clearer.
== 0.7.1 / 20110130
* Fixed 1.9.1 Binary Encoding bug when UTF8 set as default (Thanks schmurfy)
* Improved rubinius compat for specs
* Improved spec compatibility on linux
== 0.7.0 / 20101222
* Improved performance of calls to Socket#getsockopt. There are usually
a lot of calls passing RCVMORE, so we now cache those buffers instead
of reallocating them every time.
* Updated the docs on Poller#poll to warn about a possible busy-loop
condition.
* Fixed some more specs to conform with the 0mq 2.1 requirement that
all sockets must be closed explicitly otherwise the program may
hang on exit.
== 0.6.1 / 20101127
* API Change!
Moved the #version method from the Util module and made it a class
method instead. Invoke as ZMQ::Util.version. Used for conditionally
enabling certain features based upon the 0mq version that is loaded.
* Preliminary support for the Windows platform. Patches supplied
by arvicco.
* Added support for FD and EVENTS socket options. These were added
in 0mq 2.1.0. Patches + specs supplied by andrewvc.
* Added support for LINGER, RECONNECT_IVL, BACKLOG and
RECOVERY_IVL_MSEC socket options.
* Conditionally re-enable the socket finalizer when we are running
with 0mq 2.1.0 or later.
* Drop support for MRI 1.8.x since the 'ffi' gem has dropped it as a
supported Ruby runtime with its 1.0 release. No action is taken to
prevent running with MRI 1.8.x but it won't be supported.
* Misc. spec fixes. Need more specs!
== 0.6.0 / 20100911
* API Change! Modified ZMQ::Message by removing automatic memory
management. While doing some performance tests I saw that
defining/undefining the finalizer added 15-30% processing
overhead on the latency test. So, I split this functionality
out to a subclass called ZMQ::ManagedMemory. Any existing code
that relies on the default Message class to clean up after itself
will now have a memory leak. Explicitly call #close on these
received messages *unless* they are sent out again. The #send
method automatically closes call on your behalf.
* Rubinius/rbx compatibility! Requires an rbx code pull from git
from 20100911 or later to get the necessary code fixes.
* Modify Message to use the @pointer directly rather than indirectly
via the @struct object. Provides better compatibility for rbx
since rbx does not yet support the FFI pointer protocol for structs
like the FFI gem.
* Modify Message to pass libC's free function for disposing of message
data buffers rather than trying to callback into ruby code to
do the same thing. External thread callbacks into ruby code will
never be supported in rbx; this also improves compatibility and
performance with MRI and JRuby. (In particular, MRI enqueues these
kinds of callbacks and spawns a *new* thread to execute each one.
Avoiding the ruby callback entirely eliminates this extra work
for MRI.)
* Modify FFI wrapper to capture the libC dynamic library to fetch
a pointer to the free function.
* Modify FFI wrapper to remove the FFI::Function callback used
by Message. It's no longer necessary since we now use free
directly.
== 0.5.1 / 20100830
* Works with 0mq 2.0.8 release.
* Removed the socket finalizer. The current 0mq framework cannot
handle the case where zmq_close is called on a socket that was
created from another thread. Therefore, the garbage collection
thread causes the framework to break. Version 2.1 (or later)
should fix this 0mq limitation.
* Misc fixes. See commits.
== 0.5.0 / 20100606
* Updated the bindings to conform to the 0mq 2.0.7 release.
Several parts of the API changed.
* Updated all examples to use the new Context api.
* Added Socket#getsockopt.
* Added a Socket#identity and Socket#identity= method pair to
allow for easy get/put on socket identities. Useful for async
request/reply using XREQ/XREP sockets.
* Added more specs (slowly but surely).
* Support multi-part messages (new as of 2.0.7). I am unsure how
to best support multi-part messages so the Message (and related)
API may change in the future. Added Socket#more_parts?.
* Lots of fixes. Many classes use finalizers to deallocate native
memory when they go out of scope; be sure to use JRuby 1.5.1 or
later to get important finalizer fixes.
== 0.4.1 / 20100511
* I was misusing all of the FFI memory allocator classes. I now
wrap libc and use malloc/free directly for creating buffers
used by libzmq.
== 0.4.0 / 20100510
* Changed the Socket#recv method signature to take an optional
message object as its first argument. This allows the library
user to allocate and pass in their own message object for the
purposes of zero-copy. Original behavior was for the library to
*always* allocate a new message object to receive a message into.
Hopefully this is the last change required.
* Modified the Socket constructor to take an optional hash as its
final argument. It honors two keys; :receiver_klass and
:sender_klass. Passing in a new constant for either (or both) keys
will override the class used by Socket for allocating new
Message objects.
== 0.3.1 / 20100509
* Modified ZMQ::Message so we have both an UnmanagedMessage where
memory management is manual via the #close method, and Message where
memory management is automated via a finalizer method run during
garbage collection.
* Updated ZMQ::Message docs to make it clearer how to use a subclass
and FFI::Struct to lazily access the message buffer. This gets us as
close to zero-copy as possible for performance.
* Fixed a memory leak in Message where the FFI::Struct backing the
C struct was not being freed.
* Tested the FFI code against MRI 1.8.x and 1.9.x. It works!
* Patched a potential problem in LibZMQ::MessageDeallocator. It was
crashing under MRI because it complained that FFI::Pointer did not
have a free method. It now checks for :free before calling it.
Need to investigate this further because it never happened under
JRuby.
* Modified the Socket constructor slightly to allow for using
unmanaged or managed messages.
* Changed the /examples to print a throughput (msgs/s) number upon
completion.
== 0.3.0 / 20100507
* ZMQ::Socket#send and ZMQ::Socket#recv semantics changed
* The official 0mq ruby bindings utilize strings for #send and #recv.
However, to do so requires lots of copying to and from buffers which
greatly impacts performance. These methods now return a ZMQ::Message
object which can be subclassed to do lazy evaluation of the buffer.
* Added ZMQ::Socket#send_string and ZMQ::Socket#recv_string. They
automatically convert the messages to strings just like the official
0mq ruby bindings.
* Fixed bug in ZMQ::Util#error_string
* Split the ZMQ::Message class into two classes. The base class called
UnmanagedMessage requires manual memory management. The Message
class (used by default by Socket) has a finalizer defined to
automatically release memory when the message object gets garbage
collected.
== 0.2.0 / 20100505
* 1 major enhancement
* Birthday!