Ian Barber
3db9bf31b3
Merge pull request #363 from AlexBio/fix_nosigpipe_check
...
Check if SO_NOSIGPIPE is defined
2012-06-06 06:29:41 -07:00
Alessandro Ghedini
4bd78bb4cf
Check if SO_NOSIGPIPE is defined
2012-06-06 15:08:00 +02:00
Alessandro Ghedini
271ced98cf
Remove unused variable which causes build to fail with -Werror
2012-06-06 15:06:13 +02:00
Ian Barber
f611c57c48
Merge pull request #362 from hintjens/master
...
Bumped version for next release (3.3.0)
2012-06-05 23:47:36 -07:00
Pieter Hintjens
e5bb5a60f4
Bumped version to 3.3.0
2012-06-06 06:57:43 +02:00
Ian Barber
336f72720a
The previous code to block the socket from receiving on that pipe during a disconnect was vulnerable to a race condition. This code calls with the terminate functions of both ends of the pipe - I believe this should be safer. This required storing a pointer to the socket end of the pipe
2012-06-05 21:44:23 +01:00
Ian Barber
5008f385ba
When detaching a pipe, as well as checking the delay on connect sockopt is set, also ensure that the protocol is not pgm or epgm as we are not implementing the functionality for multicase types
2012-06-05 18:41:38 +01:00
Ian Barber
4d4674e088
Merge pull request #360 from vortechs2000/fix_hpux
...
Fix build on HPUX 11iv3
2012-06-05 10:33:34 -07:00
Ian Barber
09d18e4b3c
Merge branch 'master' of https://github.com/zeromq/libzmq
2012-06-05 18:32:15 +01:00
Pieter Hintjens
f8b79f888f
Merge pull request #361 from vortechs2000/fix_aix7
...
Fix up build on AIX7
2012-06-05 09:38:38 -07:00
Pieter Hintjens
897b6b58ea
Merge pull request #359 from vortechs2000/fix_older_linux_gcc
...
Fix build on RHEL5 and SLES10
2012-06-05 09:11:25 -07:00
AJ Lewis
97c48ccda6
Fix build on HPUX 11iv3
...
The socket length variable for getsockname and accept must be an
(int *) instead of a (socklen_t *) on HPUX.
Signed-off-by: AJ Lewis <aj.lewis@quantum.com>
2012-06-05 09:44:02 -05:00
AJ Lewis
3687789f9d
Fix build on RHEL5 and SLES10
...
GCC 4.1.2 on RHEL5 and SLES10 don't like not having a newline at the
end of a source file, and error out if it's missing.
Signed-off-by: AJ Lewis <aj.lewis@quantum.com>
2012-06-05 09:22:22 -05:00
AJ Lewis
616bcf9fc2
Fix up build on AIX7
...
Copy logic from zmq.cpp into device.cpp for getting poll.h included.
Ensure that zmq.h is included *after* poll.h in both zmq.cpp and
device.cpp.
Signed-off-by: AJ Lewis <aj.lewis@quantum.com>
2012-06-05 09:15:37 -05:00
Ian Barber
09956dee93
Restoring comment for clarity
2012-06-04 11:41:20 +01:00
Ian Barber
ace7c99b91
Removing unnecessary outpipe values that had been used for reconnecting existing pipes - no longer needed when using a pipe term for the delay_attach situation.
2012-06-04 11:40:14 +01:00
Ian Barber
55cbdfcf26
Fix incorrect whitespace in if statement
2012-06-04 10:31:30 +01:00
Ian Barber
29f8d9ca15
Remove unnecessary extra test in pipe assertion - now we are terminating pipes we don't need to allow the case in which a pipe is rebound to the same sink
2012-06-04 10:29:44 +01:00
Ian Barber
c13f1d52ff
On the advice of Martin Hurton, removed the new command type and just terminated the pipe in a reconnect situation, and notified the socket of the same. This handles the blocking properly, but at the cost of potentially losing in flight messages. However, this is a reasonable trade off given how much simpler it makes the patch.
2012-06-04 10:27:16 +01:00
Ian Barber
1566091bc6
Rebinding on reconnection to allow for the pipe blocking will set the event sink again, which will cause an assert to be triggered. I have modified that to allow for setting the same sink to be OK. I believe this should be ok - on termination, if a pipe hasn't reconnected, it would just attempt to be erased from the pipes list again, which is reasonable
2012-06-03 23:27:02 +01:00
Ian Barber
0b3478d6ec
Fix whitespace in test
2012-06-03 23:11:08 +01:00
Ian Barber
b5ace39e2a
Fix condition so that PGM and EPGM sockets always create pipes immediately, even if delay_attach_on_connect is set. This allows passing through the icanhasall flag, and is realistic given the fact those protocols should be able to connect immediately
2012-06-03 23:01:24 +01:00
Ian Barber
6f6466f088
Fix a number of whitespace issues in various parts of the code, add validation to most calls on the test and take a first stab at implementing the reconnection pipe blocking.
...
It didn't seem straightforward to use any of the existing process calls, so I have added a new command to command_t and friends called detach. This instructs the socket_base to remove the pipe from it's pipe list. The session base stores a copy of the outpipe, and will resend the bind command on reconnection. This should allow balancing again.
2012-06-03 22:57:47 +01:00
Ian Barber
06485d9200
Remove the extra outpipe handling as the session is quite capable of delaying the creation of the pipe until the connection has happened. Simply don't build the pipe, and let it do that automatically.
2012-06-03 22:05:36 +01:00
Ian Barber
297af95451
And another typo on the same comment
2012-06-03 21:38:41 +01:00
Ian Barber
b79aaaf473
Remove extra brackets as suggested by Martin H, and fix up a comment which was missing a word
2012-06-03 21:34:41 +01:00
Ian Barber
f687a2989b
Merge branch 'master' of https://github.com/zeromq/libzmq
2012-06-01 21:49:07 +01:00
Ian Barber
98ef56039e
Merge pull request #358 from steve-o/issue-320-author
...
Issue 320 author
2012-06-01 10:10:44 -07:00
Steven McCoy
0f58a98b3e
Merge branch 'issue-320' of https://github.com/steve-o/libzmq into issue-320-author
2012-06-01 13:03:19 -04:00
Douglas Young
320684ef39
Return error on invalid PGM url instead of raising assertion (Douglas Young).
...
Fix Win32 build.
2012-06-01 13:02:29 -04:00
Ian Barber
fe3fb419fe
After speaking with Ben Gray and the discussion on the mailing list, this is an attempt to create a sockopt to allow connecting pipes to not immediately be available for traffic. The problem is in a PUSH to many PULL situation, where there is a connect to a PULL which is not there. This connect will immediately create a pipe (unlike bind), and traffic will be load balanced to that pipe. This means if there is a persistently unavailable end point then the traffic will queue until HWM is hit, and older messages will be lost.
...
This patch adds a sockopt ZMQ_DELAY_ATTACH_ON_CONNECT, which if set to 1 will attempt to preempt this behavior. It does this by extending the use of the session_base to include in the outbound as well as the inbound pipe, and only associates the pipe with the socket once it receives the connected callback via a process_attach message. This works, and a test has been added to show so, but may introduce unexpected complications. The shutdown logic in this class has become marginally more awkward because of this, requiring the session to serve as the sink for both pipes if shutdown occurs with a still-connecting pipe in place. It is also possible there could be issues around flushing the messages, but as I could not directly think how to create such an issue I have not written any code with regards to that.
The documentation has been updated to reflect the change, but please do check over the code and test and review.
2012-06-01 17:58:19 +01:00
Pieter Hintjens
c28af41ca4
Merge pull request #356 from hurtonm/code_cleanup
...
lb: code cleanup
2012-05-31 07:29:55 -07:00
Pieter Hintjens
bc150de81e
Merge pull request #355 from hurtonm/fq_lb_fix
...
Prevent connection starvation
2012-05-31 07:29:22 -07:00
Martin Hurton
89ff277bec
lb: code cleanup
2012-05-31 15:59:59 +02:00
Martin Hurton
2973eaf446
Prevent connection starvation
...
When removing a pipe from the lb or fq component,
make sure we do not remove another pipe from the active set.
2012-05-31 15:35:45 +02:00
Pieter Hintjens
4e7be102f4
Merge pull request #354 from steve-o/issue-320
...
Return error on invalid PGM url instead of raising assertion.
2012-05-31 01:19:22 -07:00
Steven McCoy
13976a3d65
Return error on invalid PGM url instead of raising assertion.
...
Fix Win32 build.
2012-05-30 20:52:19 -04:00
Pieter Hintjens
32befeb0a6
Merge pull request #353 from steve-o/master
...
Fix title on zmq_disconnect manpage.
2012-05-30 09:59:55 -07:00
Steven McCoy
75df0194bf
Fix title on zmq_disconnect manpage.
2012-05-30 12:53:53 -04:00
Pieter Hintjens
1adb7b1017
Merge pull request #352 from hurtonm/issue_370
...
Fix issue #370
2012-05-29 13:29:58 -07:00
Martin Hurton
7fe45af30f
Fix issue #370
...
The patch extends the internal session's API with the reset method.
This method is used to reset a session's state so that it can
handle a new connection.
2012-05-29 22:10:51 +02:00
Pieter Hintjens
f7bd543c36
Merge pull request #351 from hurtonm/code_cleanup
...
Code cleanup
2012-05-28 14:34:57 -07:00
Martin Hurton
24b79c7e0b
Prefer errno_assert/alloc_assert to zmq_assert
2012-05-28 23:17:03 +02:00
Martin Hurton
013967681d
fq: code cleanup
2012-05-28 22:01:37 +02:00
Pieter Hintjens
8152502f69
Merge pull request #350 from hurtonm/issue_369
...
Fix issue #369
2012-05-28 08:39:20 -07:00
Martin Hurton
130dfc5b5f
Fix issue #369
...
The bug was that after reconnect, the session did not
handle identity messages properly.
2012-05-28 17:08:27 +02:00
Ian Barber
e30e48c23e
Merge pull request #349 from hintjens/master
...
Fixed zmq_poll.txt manpage for issue #361
2012-05-28 02:16:29 -07:00
Pieter Hintjens
2ab12efe11
Fixing issue #361
2012-05-28 11:01:21 +02:00
Pieter Hintjens
3a76d246a8
Merge pull request #348 from hurtonm/code_cleanup
...
Code cleanup
2012-05-28 00:47:26 -07:00
Martin Hurton
d0b9005ef0
Don't assume SOCKET_ERROR is -1 on Windows
2012-05-27 23:38:33 +02:00
Martin Hurton
ac53f1a728
Remove unnecessary casts
2012-05-27 23:38:16 +02:00
Martin Hurton
e0534643fa
Simplify error handling in tcp_connecter
2012-05-27 23:38:16 +02:00
Martin Hurton
13ef1e4f26
Make wsa_error_to_errno pure function
2012-05-27 16:10:19 +02:00
Martin Hurton
a8f9a0d891
Use zmq_assert rather then assert
2012-05-27 15:31:59 +02:00
Martin Hurton
52ed4cdccf
Remove dead code
2012-05-27 15:18:38 +02:00
Martin Hurton
7cfd03ba72
Remove unplug from i_engine interface
2012-05-27 15:18:38 +02:00
Pieter Hintjens
5db30fe991
Merge pull request #347 from methodmissing/monitor-doc-fails
...
Fix too long underline in zmq_ctx_set_monitor() docs
2012-05-24 06:45:27 -07:00
Lourens Naudé
b85ff17822
Fix too long underline in monitor docs
2012-05-24 09:39:48 +01:00
Pieter Hintjens
74af2f9402
Merge pull request #346 from methodmissing/monitor-regressions
...
Rename monitor documentation source file to match zmq_ctx_set_monitor() API
2012-05-23 07:21:41 -07:00
Lourens Naudé
400f6f3863
Rename monitor documentation source file to match zmq_ctx_set_monitor() API
2012-05-23 01:35:22 +01:00
Pieter Hintjens
22b4388e29
Merge pull request #345 from methodmissing/monitor-regressions
...
Moves the monitoring infrastructure to a global zmq_ctx_set_monitor () API to avoid strict aliasing issues with function pointers and socket options.
2012-05-22 16:18:54 -07:00
Lourens Naudé
1e92ee0a0e
Oust last remaning ZMQ_MONITOR reference from NEWS as well
2012-05-22 23:45:15 +01:00
Lourens Naudé
adf7a7ade1
Merge branch 'master' into monitor-regressions
2012-05-22 23:35:30 +01:00
Lourens Naudé
991b7fcc04
Rename zmq_monitor to zmq_ctx_set_monitor for compat with existing context specific APIs
2012-05-22 20:15:18 +01:00
Lourens Naudé
04f0e7f26e
Documentation for zmq_monitor
2012-05-22 20:08:02 +01:00
Ian Barber
20152a6e3e
Merge pull request #344 from hintjens/master
...
Fixed bogus reference to zmq_ctx_put
2012-05-22 07:31:28 -07:00
Pieter Hintjens
604456a8b0
Man page for zmq_ctx_new had error, fixed
2012-05-21 15:59:55 -05:00
Lourens Naudé
f27c02d01e
Change context monitor_event prototype to accept a va_list instead
2012-05-21 21:22:16 +01:00
Lourens Naudé
4767159f39
Initial stab at a context level monitor callback and registration API
2012-05-21 20:47:11 +01:00
Pieter Hintjens
7cb19fbf1c
Merge pull request #343 from jimenezrick/master
...
Doc improvement: document interface omission in zmq_pgm.txt
2012-05-21 06:00:02 -07:00
Pieter Hintjens
65b6351e4a
Merge pull request #342 from ipechorin/master
...
Solaris/SunCC build fix: could not find a match for std::multimap<...>::insert(std::pair<...,...>)
2012-05-21 05:59:32 -07:00
Ricardo Catalinas Jiménez
0e053e3478
Doc improvement: document interface omission in zmq_pgm.txt
...
The PGM transport supports the omission of the network interface to
select the default one like:
announce.connect("epgm://eth0;239.255.128.46:64646"); // Use eth0
announce.connect("epgm://239.255.128.46:64646"); // Use the default
Also, mention C++ in the additional community bindings of 0MQ in
zmq.txt.
2012-05-21 14:06:34 +02:00
Lourens Naudé
e13b3723b8
Rename type zmq_monitor_fn -> zmq_monitor for a more natural callback definition API (zmq_monitor type, monitor.function callback)
2012-05-20 18:27:59 +01:00
Lourens Naudé
06cce15479
Change zmq_monitor_fn type to cast between pointer-to-object and pointer-to-function in a more standards compliant way
2012-05-20 18:22:13 +01:00
Ivan Pechorin
d25dce9df9
Solaris/SunCC build fix: could not find a match for std::multimap<...>::insert(std::pair<...,...>)
2012-05-20 13:34:08 +02:00
Pieter Hintjens
5ef63318f8
Merge pull request #341 from kennytm/master
...
Allow the ZMQ_MONITOR code compilable on gcc 4.7 on Linux.
2012-05-13 06:39:16 -07:00
KennyTM~
c995de6584
Allow the ZMQ_MONITOR code compilable on gcc 4.7 on Linux.
...
The current ZMQ_MONITOR code does not compile in gcc 4.7, as -pedantic
and -Werror are enabled, and ISO C++ doesn't allow casting between
normal pointers (void*) and function pointers, as pedantically their
size could be different. This caused the library not compilable. This
commit workaround the problem by introducing one more indirection, i.e.
instead of calling
(void *)listener
which is an error, we have to use
*(void **)&listener
which is an undefined behavior :) but works on most platforms
Also, `optval_ = monitor` will not set the parameter in getsockopt(),
and the extra casting caused the LHS to be an rvalue which again makes
the code not compilable. The proper way is to pass a pointer of function
pointer and assign with indirection, i.e. `*optval_ = monitor`.
Also, fixed an asciidoc error in zmq_getsockopt.txt because the `~~~~`
is too long.
2012-05-13 20:49:05 +08:00
Pieter Hintjens
89d5054e59
Merge pull request #340 from methodmissing/events
...
Expose a ZMQ_MONITOR socket option to register a callback for notification of state changes in socket state ( stream engine, tcp and ipc transport only )
2012-05-11 15:18:50 -07:00
Lourens Naudé
d0461752ff
Merge branch 'master' into events
2012-05-11 22:08:17 +01:00
Pieter Hintjens
70b067ecc6
Merge pull request #339 from ianbarber/master
...
Add disconnect and unbind documentation
2012-05-11 06:23:58 -07:00
Ian Barber
e65d228f4f
gitignore endpoint test and add docs for unbind and disconnect
2012-05-11 14:17:45 +01:00
Ian Barber
c7af07cc77
Merge pull request #336 from mauri-melato/master
...
Fix #366 - On Windows, preventing sockets to be inherited by child processes.
2012-05-08 06:42:12 -07:00
Ian Barber
d087548286
Merge pull request #338 from hurtonm/code_cleanup
...
Simplify encoder's loop
2012-05-08 06:41:22 -07:00
Martin Hurton
641943944d
Simplify encoder's loop
2012-05-08 14:23:05 +02:00
Ian Barber
80e8baaff4
Merge pull request #337 from hurtonm/issue_268
...
Fix issue #268
2012-05-08 02:25:16 -07:00
Martin Hurton
3d93c1af5b
Fix issue #268
...
This patch fixes a bug in the message encoder which was
responsible for computing incorrect message offset.
The bug affected PGM receiver making it unable to
decode inital messages.
2012-05-08 09:44:45 +02:00
unknown
5fe6ddfda3
On Windows, preventing sockets to be inherited by child processes.
2012-05-07 15:46:55 +02:00
Pieter Hintjens
5dc44a63d6
Merge pull request #335 from jdc8/master
...
Fix for issue 355 and fix for compile error with Visual C++ 2008
2012-05-06 03:07:35 -07:00
Jos Decoster
37e4a38eb5
Fix compile error with Visual C++ 2008
...
File decoder.cpp does not compile with Visual C++ 2008:
1>c:\tmp\libzmq\src\decoder.cpp(117) : warning C4003: not enough actual parameters for macro 'max'
1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2589: '(' : illegal token on right side of '::'
1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2059: syntax error : '::'
1>c:\tmp\libzmq\src\decoder.cpp(117) : error C2143: syntax error : missing ';' before '{'
This error is caused by the precense of a macro 'max' when including
'windows.h'. To solve this problem, the preprocessor macro /DNOMINMAX must
be specified.
2012-05-05 23:56:49 +02:00
Jos Decoster
68c1be8bf6
Fix for issue 355. Added missing source files dealer.cpp, device,cpp and router.cpp. Removed source files no longer present: xrep.cpp and xreq.cpp
2012-05-05 23:37:14 +02:00
Lourens Naudé
c38aecdc50
Merge branch 'master' into events
2012-05-04 02:35:22 +01:00
Lourens Naudé
5c6f72c17c
ZMQ_MONITOR socket option registers a callback / event sink for changes in socket state
2012-05-04 02:32:46 +01:00
Pieter Hintjens
47dbd4aa96
Merge pull request #334 from ianbarber/master
...
Async connect error handling
2012-05-03 06:08:02 -07:00
Ian Barber
1075005b50
Patch from Mato that fixes a subtle connect bug: EAGAIN was being used as a translation value for EINPROGRESS, thus
...
shadowing a real EAGAIN return value from the OS. This caused later
assertions of "Invalid argument" in stream_engine.cpp when it attempted to
use a socket which was not connected.
I also add EINTR to mean EINPROGRESS, as per the POSIX and FreeBSD
documentation which specifies that a connect() call interrupted due to a
signal will complete asynchronously.
Signed-off-by: Martin Lucina <martin@lucina.net>
2012-05-03 13:24:12 +01:00
Pieter Hintjens
f497aae8df
Merge pull request #333 from hurtonm/fix_decoder_to_properly_handle_large_messages
...
Fix decoder to properly handle large messages
2012-04-29 22:33:31 -07:00
Pieter Hintjens
36bfaaabe6
Merge pull request #332 from hurtonm/fix_issue_264
...
Fix issue #264
2012-04-29 22:33:16 -07:00
Pieter Hintjens
9098f4d655
Merge pull request #331 from hurtonm/code_cleanup
...
socket_base: process_unplug () is not used, remove it
2012-04-29 22:32:57 -07:00
Pieter Hintjens
dd3eb08d33
Merge pull request #330 from hurtonm/pair_socket_rejects_additional_connections
...
Do not crash when multiple peers connect to PAIR socket
2012-04-29 22:32:39 -07:00
Martin Hurton
d84709497e
Do not crash when multiple peers connect to PAIR socket
...
When more then one peer connected to a ZMQ_PAIR socket,
an application aborted due to assertion failure.
This patch changes the ZMQ_PAIR socket behaviour so that
it rejects any further connection requests.
2012-04-30 01:08:23 +02:00
Martin Hurton
5227f676f4
Fix decoder to properly handle large messages
...
The decoder did not properly decode large messages
on systems where sizeof (size_t) < sizeof (uint64_t).
2012-04-29 18:07:03 +02:00