diff --git a/AUTHORS b/AUTHORS index e69de29b..13f0076e 100644 --- a/AUTHORS +++ b/AUTHORS @@ -0,0 +1,38 @@ +Contributors +============ + +Alexej Lotz +Barak Amar +Conrad D. Steenberg +Dhruva Krishnamurthy +Dirk O. Kaar +Erich Heine +Frank Denis +George Neill +Martin Hurton +Martin Lucina +Martin Sustrik +Matus Hamorsky +Pavel Gushcha +Pavol Malosek +Steven McCoy +Tamara Kustarova +Terry Wilson + +Credits +======= + +Aamir Mohammad +Alexander Majorov +Bernd Schumacher +Brett Cameron +Carsten Dinkelmann +David Bahi +Evgueny Khartchenko +Frank Vanden Berghen +John Apps +Markus Fischer +Matt Muggeridge +Paulo Henrique Silva +Peter Lemenkov +Robert Zhang diff --git a/COPYING.LESSER b/COPYING.LESSER new file mode 100644 index 00000000..3f7b8b1e --- /dev/null +++ b/COPYING.LESSER @@ -0,0 +1,166 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. + diff --git a/ChangeLog b/ChangeLog index e69de29b..db116105 100644 --- a/ChangeLog +++ b/ChangeLog @@ -0,0 +1,231 @@ +Version 2.0-alpha1 + +Large scale refactoring of the code and new socket-like API. + +Version 1.0.1 + +ZMQ-289 Return -1 from bind when remote object is not registered in zmq_server +ZMQ-288 Return -1 from create_exchange /queue when object can not be created +ZMQ-287 Disabling receiving messages from queue +ZMQ-286 create handle_t class with == and != operators +ZMQ-285 multiple listeners listening on the same machine with UDP encap. +ZMQ-284 mask function inaccessible via Java on Windows +ZMQ-283 Lua binding for 0MQ +ZMQ-282 Cannot send message containing zero byte via Ruby +ZMQ-281 Publisher restart fails on PGM and Win/Linux +ZMQ-280 Broken build using MSVC 2005 +ZMQ-278 Load-balancing exchange doesn't load balance +ZMQ-277 TCL binding +ZMQ-276 Check for pkg-config in autogen.sh script +ZMQ-275 Check for eventfd by running test program during ./configure +ZMQ-274 can not compile estimate_cpu_freq with PERF_CPU_FREQUENCY set +ZMQ-273 gcc (GCC) 4.4.0: invalid conversion from const char* to char* +ZMQ-272 make sure message content is created properly + +Version 1.0.0 + +ZMQ-271 Build OpenPGM with 0MQ build system +ZMQ-270 0MQ windows pgm support +ZMQ-269 Constness is better for the zmq_send data_ argument +ZMQ-267 assert in api_thread.cpp:384: void zmq::api_thread_t::process_command +ZMQ-266 Memory coruption in api_thread_t::create +ZMQ-265 Missing librbzmq.vcproj file +ZMQ-264 Java examples can not be run on OpenVMS +ZMQ-263 Warning preventing compilation of chat example +ZMQ-262 CLONE -QNX port -- working in 6.4.0? +ZMQ-261 add --with-rubydir configure option +ZMQ-260 syntax error caught by gcc 4.4 +ZMQ-253 Allow to establish arbitrary AMQP wiring on connection startup +ZMQ-249 Handle EAGAIN and EWOULDBLOCK as the same error +ZMQ-248 Call in/out events directly from I/O thread +ZMQ-247 Move physical thread from poller to individual I/O threads +ZMQ-240 Pack Java classes into a .jar +ZMQ-239 make --with-clr imply --with-c +ZMQ-237 Java extension not working with Win32 package +ZMQ-235 JAVA build fails if PATH is not set to JDK/bin +ZMQ-228 Make java documentation via JavaDoc +ZMQ-226 Move Jzmq to org.zmq package +ZMQ-204 Use non-blocking accept +ZMQ-130 Optimise mux_t for large number of idle connections + +Version 0.6.1 + +ZMQ-254: Race condition in pipe_t::writer_terminated +ZMQ-255: Python perf tests broken +ZMQ-257: pgm build fails: various declared errors +ZMQ-259: Ruby extension for libzmq + +Version 0.6 + +ZMQ-73: Redesign MT throughput test +ZMQ-102: Move load-balancing functionality from 0.3.3 branch to the trunk +ZMQ-136: Check I/O threads for rm_fd(x) followed by add_fd(x) behavior +ZMQ-138: Avoid exporting 0MQ symbols from libs using 0MQ on Windows +ZMQ-147: Python app hang-up, unresponsive to Ctrl+C +ZMQ-164: Add reconnection functionality to PGM +ZMQ-166: Slow down the reconnection process +ZMQ-176: Update examples to reflect the auto-reconnect feature +ZMQ-179: Implement OS-agnostic time measurement +ZMQ-180: What happens if queue is full & disconnection occurs? +ZMQ-183: Change OpenPGM to PGM in build options +ZMQ-185: Move msg_store to the trunk +ZMQ-186: Write an example to demonstrate load-balancing +ZMQ-187: Declaring same object (exchange, queue) twice doesn't fail +ZMQ-188: Schemas used by global object URIs don't conform to RFC3986 +ZMQ-190: Compile libdnzmq with /clr support (no old syntax) +ZMQ-193: Reconnect on Solaris platform not working +ZMQ-194: Let sender use RDTSC mechanism for command throttling in MSVC build +ZMQ-195: Failure during fg +ZMQ-196: System out of sockets after number of reconnections +ZMQ-197: Offload signal handling from I/O threads +ZMQ-198: Timers can never expire +ZMQ-199: Make receive in libczmq zero-copy +ZMQ-200: Virtualise global locator +ZMQ-202: Check out SCTP support on QNX +ZMQ-203: Add auto-reconnect to AMQP engine +ZMQ-205: Check handling of async errors on a socket +ZMQ-206: Make zmq_server not to drop the endpoint info on service disconnect +ZMQ-207: zmq_server should be able to read endpoint info from XML file +ZMQ-210: Switch perf tests to load-balancing mode +ZMQ-211: Port Data Dam functionality to Win32 +ZMQ-212: Integrate add and inc in atomic_counter into a single function +ZMQ-213: When 0MQ infrastructure is terminated, sockets are not closed correctly +ZMQ-215: Java on Win32 platform not stopping in case of assertion +ZMQ-217: zmq_server can be crashed by incorect input data +ZMQ-218: C# integration not working anymore +ZMQ-219: Change .NET extesnsion to use CamelCase +ZMQ-220: Check whether individual APIs conforms to API guidelines document +ZMQ-221: Allow to create global object w/o specifying the location +ZMQ-222: SPARC code for atomic_counter broken +ZMQ-223: Rename czmq/jzmq/dnzmq etc. to simple "zmq" +ZMQ-225: Application fails when it's connected from telnet + +Version 0.5 + +ZMQ-17: look at pgm_transport_set_recv_only and ...send_only +ZMQ-26: Allow for "any" network interface +ZMQ-31: Implement SCTP support +ZMQ-45: Normalise API vs. I/O thread +ZMQ-78: Make connection establishment asynchronous +ZMQ-79: Refactor handling of broken connections +ZMQ-100: Move flow control and queue limits from 0.3.3 branch to the trunk +ZMQ-101: Move reconnection functionality from 0.3.3 branch to the trunk +ZMQ-112: build via cmake (makefile generator) +ZMQ-115: Identify SPARC V9 microarc and/or availability of CAS instruction +ZMQ-116: Implement .NET extension +ZMQ-129: Make engine_source part of the polling object +ZMQ-139: /dev/poll introduces latency on Solaris +ZMQ-144: Investigate latency impact of using eventfd instead of socketpair on Linux +ZMQ-146: Check whether i386 and x86_64 in atomic_ptr can be unified +ZMQ-148: Change watermarks from int to uint64_t +ZMQ-149: Virtualise creation of 0MQ connections +ZMQ-150: Negative numbers in unsigned type in atomic_counter +ZMQ-151: Modify build system to build SCTP extension +ZMQ-152: Merge BP/PGM functionality into the trunk +ZMQ-153: compiler warnings on solaris +ZMQ-155: Build libzmq with sctp support witch cmake +ZMQ-160: Get rid of create functions in engines +ZMQ-162: CMakeLists.txt files not updated with latest changes +ZMQ-165: Implement reconnection notifications +ZMQ-169: Return queue id from receive function in libpyzmq +ZMQ-171: Add AMQP support to 0MQ +ZMQ-173: Throughput test should accept 2 interface specifications +ZMQ-174: When application is killed on Win32, zmq_server fails +ZMQ-175: Chatroom example doesn't pass messages after reconnection +ZMQ-177: Update language extensions to take advantage of auto-reconnect +ZMQ-181: Rafactor the code to support multiple notification types + +Version 0.4 + +ZMQ-21: Clean up the command passing code +ZMQ-36: autogen/configure fails on Solaris +ZMQ-39: Check whether using CAS for btsr and izte on x86 platform improves latency +ZMQ-40: Check autogen on FreeBSD +ZMQ-41: Check autogen on OS X +ZMQ-43: Use +m instead of memory in atomic operations +ZMQ-46: Get rid of administrative pseudo-thread +ZMQ-63: -mcpu=v9 CPPFLAG should be used only at sparc achitecture +ZMQ-64: gcc 3.4.3 on opensolaris complains about -mcpu flag +ZMQ-65: No error report when host name resolving fails +ZMQ-66: Several files use atoi without including stdlib.h +ZMQ-69: Make stdint.hpp hand-written rather than generated +ZMQ-71: Virtualise thread management +ZMQ-72: Remove platform.hpp +ZMQ-74: Implement win32 version of tcp_socket and tcp_listener +ZMQ-75: Virtualise mutexes +ZMQ-76: Implement win32 version of ysemaphore_t +ZMQ-80: Virtualise polling mechanisms +ZMQ-81: Implement 'select' polling mechanism +ZMQ-82: Rename i_context to i_thread +ZMQ-83: "Resource temporarily unavailable" when running on 266MHz box +ZMQ-84: zmq_server stops to respond +ZMQ-89: Make i_pollable derived from i_engine +ZMQ-94: Report error when malloc fails +ZMQ-95: Add /dev/poll method of polling +ZMQ-96: Add support for kqueue method of polling +ZMQ-97: OpenBSD port +ZMQ-98: QNX port +ZMQ-99: use pyexec_LTLIBRARIES primary for libpyzmq +ZMQ-103: Use non blocking sockets +ZMQ-106: memory leak when sending message from Java +ZMQ-111: Get rid of speculative operations +ZMQ-113: Windows compiler (_MSC_VER 1310) doesn't support strncpy_s function +ZMQ-117: select_thread doesn't implement rm_fd function +ZMQ-119: select thread fails on shudown +ZMQ-121: Fix all I/O threads to handle rm_fd correctly +ZMQ-124: include gaurd is wrong +ZMQ-126: Refactor I/O threads implementation to avoid duplication of common functionality. +ZMQ-131: select_thread fails on Windows +ZMQ-132: Pointer to poller_t is used before it is fully initialised +ZMQ-134: Thread management in constructors/destructors +ZMQ-135: Move retired list to the polling strategy-specific object +ZMQ-137: Assertion fails at bp_engine, line 132, error_handler is not set + +Version 0.3.2 + +ZMQ-54: Test programs are compiled with --rpath + +Version 0.3.1 + +ZMQ-25: Allow to use network interface name instead of IP address +ZMQ-29: Implement speculative write to socket +ZMQ-33: Assign ports to global objects automatically +ZMQ-34: Message size of zero causes application to hang up +ZMQ-42: Change locators to deal with a single object type +ZMQ-44: Some of the objects have non-functional auto-generated copy constructors +ZMQ-47: Camera example is broken +ZMQ-48: Sender fails when receiver disconnects +ZMQ-50: Warning in chat example +ZMQ-51: Make it possible to use single include (zmq.hpp) for client apps +ZMQ-53: Segmentation fault when binding to non-existent queue +ZMQ-55: raw_message_init (data,size,ffn) allocates more memory than needed +ZMQ-56: zmq_server fails if too many apps disconnect abruptly +ZMQ-58: Implement C binding for 0MQ +ZMQ-59: Implement Java binding for 0MQ +ZMQ-60: Implement Python binding for 0MQ +ZMQ-62: Write man pages + +Version 0.3 + +ZMQ-1: poll_thread hangs in destructor +ZMQ-4: Missing -D_REENTRANT command line parameter while compiling 0MQ +ZMQ-5: Check for buffer overflows in AMQP/0-9 marshaller/unmarshaller +ZMQ-6: Allow dynamic adding of engines to poll_thread +ZMQ-7: Implement dynamic assignment of engine IDs to engines +ZMQ-9: Implement event batching in ysocketpair +ZMQ-10: Remove remaining references to HAVE_CONFIG_H from the code +ZMQ-11: Move 'alive' flag to the dispatcher +ZMQ-12: Move dispatcher signalers into a separate array +ZMQ-13: Allow up to 63 threads on x86_64 platform +ZMQ-14: Implement new type of lock-free pipe +ZMQ-15: Implement an infrastructure to pass arbitrary commands between threads +ZMQ-16: missing stats_raw_den.R, stats_raw_lat.R in dist package +ZMQ-20: Sync problem with ypollset/atomic_bitmap +ZMQ-24: Redundant poll +ZMQ-30: Implement epoll suport +ZMQ-37: Identify SPARC V9 microarc and/or availability of CAS instruction + +Version 0.2 + +ZMQ-2: Failure when mutexes are used atomic_uint32 +ZMQ-3: socket hangup at OS X diff --git a/README b/README index e69de29b..f71ef900 100644 --- a/README +++ b/README @@ -0,0 +1,4 @@ +This is the 0MQ project. More information is available at +http://www.zeromq.org + +Please read INSTALL for installation instructions.