Luca Boccassi
edc770d680
Problem: HWM always boosted by 1
...
Solution: initialise *hwmboost to -1 instead of 1, and use it only if
it's >= 0. The socket option code checks anyway that the
user-provided value is >= 0 so there is no risk of clashing. The
documentation also specifies that it has to be >= 0.
2017-01-10 11:40:14 +00:00
Luca Boccassi
9f1ba60f50
Problem: modifying pipe from different thread is not safe
...
Solution: revert change from #2299 to avoid bugs while we look for an
alternative and thread-safe solution
2017-01-10 11:38:02 +00:00
Luca Boccassi
598befc1f8
Merge pull request #2299 from laplaceyang/pr_set_hwm_after_connect
...
Problem: set hwm after connect lead to infinite hwm
2017-01-09 08:34:12 +00:00
laplaceyang
5adcb83509
Problem: set hwm after connect lead to infinite hwm
2017-01-09 12:34:40 +08:00
Constantin Rack
77e1792cd8
Merge pull request #2298 from bluca/spec_uuid
...
Problem: spec file still depends on libuuid
2017-01-08 12:10:21 +01:00
Luca Boccassi
ce735c44ef
Problem: spec file still depends on libuuid
...
Solution: remove the dependency as it's not been needed for a while
2017-01-07 22:25:36 +00:00
Constantin Rack
81bbd2b72d
Merge pull request #2296 from bluca/asciidoc-base
...
Problem: debian packages do not build manpages
2017-01-07 19:39:36 +01:00
Luca Boccassi
e37936616d
Problem: debian packages do not build manpages
...
Solution: build-depend on asciidoc and xmlto
2017-01-07 16:10:08 +00:00
Luca Boccassi
9dbbd69480
Merge pull request #2295 from JohanMabille/cmake_win_install
...
Cmake win install
2017-01-07 01:51:30 +01:00
Johan Mabille
e258890f67
INSTALLATION instructions
2017-01-07 00:47:22 +01:00
Johan Mabille
7c709e5466
cmake install config file
2017-01-07 00:21:06 +01:00
Johan Mabille
e95d23198f
CPack option and .txt files installation dir
2017-01-06 14:29:56 +01:00
Luca Boccassi
e80db0e8e5
Merge pull request #2294 from JohanMabille/cmake_precompiled
...
Windows cmake build fixed
2017-01-06 11:10:41 +01:00
Johan Mabille
2d749a066c
Windows cmake build fixed
2017-01-06 10:52:20 +01:00
Constantin Rack
ceb6be7751
Merge pull request #2292 from bluca/osx_sigpipe
...
Problem: peer can close connection before SO_NOSIGPIPE is set
2017-01-04 20:28:51 +01:00
Luca Boccassi
31a3a06828
Problem: peer can close connection before SO_NOSIGPIPE is set
...
Solution: setsockopt returns EINVAL if the connection was closed by
the peer after the accept returned a valid socket. This is a valid
network error and should not cause an assert.
To handle this we have to extract the setsockopt from the stream
engine, as there's no clean way to return an error from the
constructor. Instead, try to set this option before creating the
engine in the callers, and return immediately as if the accept
had failed to avoid churn. Do the same for the connect calls by
setting the option in open_socket, so that the option for that
case is set even before connecting, so there's no possible race
condition.
Since this has to be done in 4 places (tcp/ipc listener, socks
connecter and open_socket) add an utility function in ip.cpp.
Fixes #1442
2017-01-04 17:34:33 +00:00
Constantin Rack
d532f2e4d8
Merge pull request #2290 from bluca/doc_proxy_eintr
...
Problem: zmq_proxy* may return EINTR other than ETERM
2017-01-03 21:21:11 +01:00
Constantin Rack
17ef8c6793
Merge pull request #2289 from bluca/windoze_includes_test
...
Problem:capitalized include filenames trip mingw
2017-01-03 21:20:46 +01:00
Luca Boccassi
28c7abf821
Problem: zmq_proxy* may return EINTR other than ETERM
...
Solution: mention this in the documentation
2017-01-03 15:34:08 +01:00
Luca Boccassi
7e186432cb
Problem:capitalized include filenames trip mingw
...
Solution: use lowercase
2017-01-03 14:59:57 +01:00
Luca Boccassi
dce4d06b71
Merge pull request #2288 from paddor/master
...
fix typos
2017-01-03 12:49:34 +01:00
Patrik Wenger
1b3df75b87
fix typos
2017-01-03 12:45:33 +01:00
Luca Boccassi
ec2ba8a997
Merge pull request #2283 from vtellier/master
...
Fixed issue #2227 second part
2017-01-01 19:29:09 +01:00
Vincent Tellier
ea7e03a7ff
Fixed issue #2286 by documentation
...
tests/README.md explicitly indicates to check the libzmq.lib path in
CMakeLists.txt.
2017-01-01 19:08:28 +01:00
Vincent Tellier
7e36db07b1
Handshake events null pointer fix
...
The mechanism is instanciated during the handshake itself, when and
error happen before this, the error method shall work anyway.
An error handling with a NULL mechanism means the handshake fail, so the
handshake failure event is also raised in this case.
2017-01-01 19:08:28 +01:00
Vincent Tellier
ffb31dcadd
Fixed issue #2227 second part
...
- removed the previously added encryption_error, less changes less bug
- handshake fail is now signaled when an error happen while the
mechanism is still hanshaking
2017-01-01 19:08:28 +01:00
Constantin Rack
ee98e7dca0
Merge pull request #2287 from bluca/hurd_ipv6_tos
...
Problem: build fails on GNU/Hurd as it does not support IPV6_TCLASS
2017-01-01 17:06:31 +01:00
Luca Boccassi
efc0e94291
Problem: build fails on GNU/Hurd as it does not support IPV6_TCLASS
...
Solution: check if IPV6_TCLASS is defined so that when Hurd adds
support it will just work. Also it will avoid tripping over this on
other similar legacy systems.
2017-01-01 16:23:27 +01:00
Constantin Rack
c38fde00a0
Merge pull request #2285 from bluca/bump_versions
...
Problem: 4.2.1 is out, time to bump versions
2016-12-31 18:25:36 +01:00
Luca Boccassi
7c0ded93af
Problem: 4.2.1 is out, time to bump versions
...
Solution: add new changelog entry, bump library version in zmq.h and
bump ABI version in configure.ac and CMakeLists.txt
2016-12-31 16:26:41 +01:00
Luca Boccassi
7005f22726
Bugfix release 4.2.1
...
Finalize changelog and bump ABI revision
v4.2.1
2016-12-31 15:55:48 +01:00
Kevin Sapper
086bb890c5
Merge pull request #2282 from bluca/event_test
...
Problems: test_monitor failing, DRAFT events leaking when draft APIs are disabled
2016-12-31 14:13:45 +01:00
Luca Boccassi
3f3601e855
Problem: handshake events not tested with curve
...
Solution: check that the expected handshake success or failure events
are triggered in the curve security unit test
2016-12-31 01:31:37 +01:00
Luca Boccassi
d50b5b80fd
Problem: NEWS entry for ctx option does not point to docs
...
Solution: fix it
2016-12-30 23:53:20 +01:00
Luca Boccassi
fc748ec799
Problem: new monitor events not mentioned in NEWS
...
Solution: add an entry
2016-12-30 23:52:27 +01:00
Luca Boccassi
200649fd57
Problem: new handshake event monitoring undocumented
...
Solution: add them to the event monitor manpage
2016-12-30 23:40:22 +01:00
Luca Boccassi
2afba0085f
Problem: documentation does not warn about ZMQ_EVENT_ALL and new events
...
Solution: add a note pointing out that when new events are added the
ZMQ_EVENT_ALL mask will start returning them, so applications that
can't handle that transparently should not use it and instead pick
only the event types they want.
Creating a new event type and having monitors with ZMQ_EVENT_ALL
return them will not be considered a backward incompatible change
even though the flow of events will change.
2016-12-30 23:27:56 +01:00
Luca Boccassi
c0e2bc4ef9
Problem: new DRAFT monitor events returned even without --enable-draft
...
Solution: wrap the event triggering in the DRAFT ifdef as well as the
defines. This ensures that the event are returned only if the
library was built with DRAFTs enabled.
Also update the test case to expect the new events since it uses
the catch-all mask. Although the sequence of event is different and
this might be considered as an API breakage, using the catch-all
ZMQ_EVENT_ALL mask implies that, well, all events are monitored so
it's normal that new ones will be added.
Users that don't want this kind of behaviour to change can simply
monitor only the event that they care about.
2016-12-30 23:21:14 +01:00
Luca Boccassi
0ebed80dc1
Merge pull request #2281 from vtellier/master
...
Code formatting + reverted hard error handshake fail
2016-12-30 21:00:17 +01:00
Vincent Tellier
48bc75e8a1
Code formatting + reverted hard error handshake fail
...
- Moved new events in draft section + added to zmq_draft.h
- Removed the remainning tabs
- Reverted the hard error (back to soft error) in curve_server.cpp
=> The feature doesn't works anymore
2016-12-30 18:34:33 +01:00
Luca Boccassi
0ad600c7de
Merge pull request #2280 from vtellier/master
...
Fixed issue #2227
2016-12-30 17:15:18 +01:00
Vincent Tellier
b6e9e0c2d3
Fixed issue #2227
...
Added two new monitoring events:
- ZMQ_EVENT_HANDSHAKE_SUCCEED is raised once the encryption handshake succeed
- ZMQ_EVENT_HANDSHAKE_FAILED is raised when it failed
Both events are raised on server and client side.
2016-12-30 16:26:42 +01:00
Constantin Rack
64b07d8132
Merge pull request #2278 from bluca/msg_t_size_draft
2016-12-29 21:48:39 +01:00
Luca Boccassi
8c22ba246c
Problem: bug fixes not mentioned in NEWS file
...
Solution: add most relevant bug fixes since 4.2.0
2016-12-29 21:07:39 +01:00
Luca Boccassi
113feb60a2
Problem: ZMQ_MSG_T_SIZE draft but not in DRAFT section
...
Solution: move it there, add it to src/zmq_draft.h and clarify in the
documentation and in the NEWS file that this option is not yet stable
2016-12-29 21:07:39 +01:00
Luca Boccassi
715f87fec7
Merge pull request #2277 from bluca/automake_1.14
...
Problem: debian build fails with automake < 1.14
2016-12-28 16:36:58 +01:00
Luca Boccassi
47c7d8ee50
Problem: debian build fails with automake < 1.14
...
Solution: create config subdir as a workaround if building the
packages with automake < 1.14
2016-12-28 00:55:17 +01:00
Constantin Rack
ef88b8c760
Merge pull request #2276 from bluca/sodium_pkg
2016-12-27 16:28:08 +01:00
Luca Boccassi
bbae5d0f9a
Problem: dpkg-query might fail in CI build and fail the build
...
Solution: rework the bash test to avoid build failures as intended
and make it an easier one-liner
2016-12-27 14:45:45 +01:00
Constantin Rack
b2a2bb8609
Merge pull request #2275 from bluca/travis_pkg
2016-12-27 12:51:19 +01:00
Luca Boccassi
b1137b7672
Problem: documentation build not tested on Travis
...
Solution: install asciidoc and xmlto in the libsodium build run, since
it already refreshes APT to download other packages, so the delay is
smaller
2016-12-27 12:20:18 +01:00
Luca Boccassi
822def9b2b
Problem: Travis rebuilds libsodium every time
...
Solution: use packages on Ubuntu and brews on OSX. The packages and
the brews are always kept up to date, so it's no use to rebuild the
libsodium stable branch manually everytime.
2016-12-27 11:48:38 +01:00
Luca Boccassi
a1220b7fd4
Problem: Travis OSX workaround for libtool no longer needed
...
Solution: Revert "Problem: Travis CI OSX builds are broken"
This reverts commit 531b3bf7c3ed5f29760c89b7152a2c85a4a9d8bd.
2016-12-27 11:28:09 +01:00
Luca Boccassi
1f86019e3f
Problem: Travis installs packages when not needed
...
Solution: narrow down the matrix to install valgrind and lcov only
for the test runs that use them.
CMake is part of the default image so no need to install it at all.
2016-12-27 11:27:33 +01:00
Constantin Rack
5871ea5df8
Merge pull request #2274 from bluca/cloexec
2016-12-26 20:18:12 +01:00
Luca Boccassi
06055a7b74
Problem: cmake does not run test_zmq_poll_fd
...
Solution: add it to the list
2016-12-26 19:20:09 +01:00
Luca Boccassi
6e708ce144
Problem: socketpair leaks file on fork+exec
...
Solution: if available, call socketpair with SOCK_CLOEXEC flag to
make the process close the socket on fork+exec
2016-12-26 19:13:02 +01:00
Luca Boccassi
f287c7a2aa
Problem: eventfd leaks socket on fork+exec
...
Solution: if available, use eventfd with EFD_CLOEXEC flag to make
the process close the socket on fork+exec
2016-12-26 19:08:27 +01:00
Luca Boccassi
211898d243
Problem: epoll leaks socket on fork+exec
...
Solution: if available, use epoll_create1 with EPOLL_CLOEXEC flag to
make the process close the socket on fork+exec
2016-12-26 19:08:27 +01:00
Constantin Rack
16439e42d2
Merge pull request #2272 from bluca/document_read_after_free
2016-12-26 15:24:44 +01:00
Constantin Rack
d68e2e018e
Merge pull request #2273 from bluca/docs
2016-12-26 15:12:40 +01:00
Luca Boccassi
3dc016cab3
Problem: no documentation for ZMQ_SOCKS_PROXY
...
Solution: add paragraphs to zmq_get/setsockopt man pages
2016-12-26 14:54:58 +01:00
Luca Boccassi
baf32a1985
Problem: no documentation for zmq_curve_public
...
Solution: add manpage
2016-12-26 14:54:58 +01:00
Luca Boccassi
a06f97d73a
Problem: fix for read-after-free not documented
...
Solution: add a comment as it's easy to miss and very tempting to
"optimize"
2016-12-25 18:01:55 +01:00
Luca Boccassi
dc39ceb347
Merge pull request #2268 from imkos/master
...
Mingw32 Compile
2016-12-22 13:55:03 +01:00
Kos
43941052a9
add link libsodium.a
2016-12-22 14:25:00 +08:00
Kos
edad90f770
mingw32 fix
2016-12-22 09:35:49 +08:00
Luca Boccassi
fe3756defa
Merge pull request #2266 from Cziken/master
...
Problem: Duplicated code
2016-12-19 18:07:37 +01:00
Wojciech Kula
ee72493e14
Problem: Duplicated code
...
Solution: set_curve_key method in options_t struct with little
improvement in switch-case block
2016-12-19 12:13:14 +01:00
Constantin Rack
7a8180ece7
Merge pull request #2265 from bluca/contribution_notice_github
...
Problem: contributing guidelines unclear for new devs
2016-12-18 16:52:15 +01:00
Luca Boccassi
e6b1f56131
Problem: contributing guidelines unclear for new devs
...
Solution: port Github PR template from CZMQ
2016-12-18 11:46:08 +00:00
Constantin Rack
2dec320b22
Merge pull request #2263 from bluca/revert_curve_break
2016-12-16 18:12:37 +01:00
Luca Boccassi
48e9e24726
Problem: #2262 broke curve
...
Solution: Revert "Problem: Duplicated code"
This reverts commit 022eeaf33d50f8a1515a28ffb8c8cafd843ca064.
2016-12-16 16:50:17 +00:00
Constantin Rack
2aa09d34ff
Merge pull request #2262 from Cziken/master
...
Problem: Duplicated code
2016-12-16 17:32:27 +01:00
Wojciech Kula
022eeaf33d
Problem: Duplicated code
...
Solution: set_curve_key method in options_t struct with little
improvement in switch-case block
2016-12-16 17:09:53 +01:00
Cziken
d514bb598a
Fixed handling of WSAEWOULDBLOCK to be generic ( #2260 )
...
* Fixed handling of WSAEWOULDBLOCK to be generic
I don't know what was the intention of this early if statement but
now this is properly evaluated in wsa_error_no function if this is
performance issue I suggest moving evaluating this error code to the
beginning of wsa_error_no.
* Fixed handling of WSAEWOULDBLOCK to be generic
Introduced default pointer to const char * and overrides this as NULL
if function is called by zmq::wsa_error()
* Fixed handling of WSAEWOULDBLOCK to be generic
Introduced default pointer to const char * and overrides this as NULL
if function is called by zmq::wsa_error()
2016-12-16 15:51:00 +01:00
Luca Boccassi
2b565088d0
Merge pull request #2257 from minrk/check-event
...
zmq_poll: only compare FD when neither item is a zmq socket
2016-12-15 14:20:46 +01:00
Min RK
0abdc28c84
only compare FD when neither item is a zmq socket
2016-12-15 14:05:40 +01:00
Luca Boccassi
1910ef8d3e
Merge pull request #2256 from laplaceyang/pr_zmq4_pub_with_zmtp_v1_sub
...
fix bug zmq4.x PUB msg to ZMTP1.0 SUB server
2016-12-15 14:02:50 +01:00
Min RK
02a6079968
Merge pull request #2255 from bluca/poll_fd_testcase
...
Problem: no mixed FD and zmq socket zmq_poll test
2016-12-15 13:39:20 +01:00
laplaceyang
8e8fdcc9ed
fix bug zmq4.x PUB msg to ZMTP1.0 SUB server
2016-12-15 20:29:58 +08:00
Luca Boccassi
272d340c1f
Problem: no mixed FD and zmq socket zmq_poll test
...
Solution: add one
2016-12-15 12:03:48 +00:00
Luca Boccassi
f9d231437a
Merge pull request #2251 from hnwyllmm/master
...
misuse of 'close'
2016-12-13 12:43:07 +01:00
Laughing
a4e448d586
misuse of 'close'
...
use 'pollset_destroy' instead of 'close' to release pollset_fd
2016-12-13 11:09:01 +08:00
Constantin Rack
9052862619
Merge pull request #2250 from bluca/poll_regression
...
Problem: check for item.fd causes zloop_poller regression
2016-12-11 07:51:31 +01:00
Luca Boccassi
72176d5fbe
Problem: check for item.fd causes zloop_poller regression
...
Solution: fix the check for the socket.
This regression happens when using zloop with zmq_pollitem_it with
only file descriptors registerted through zloop_poller.
2016-12-10 23:49:18 +00:00
Luca Boccassi
c47e017bdd
Merge pull request #2249 from pavel-pimenov/fix-v817
...
"%" -> '%'
2016-12-10 16:01:38 +01:00
pavel.pimenov
4d6fbe17e0
"%" -> '%'
2016-12-10 17:27:42 +03:00
Luca Boccassi
39947d55c7
Merge pull request #2248 from pavel-pimenov/fix-precompiled
...
Add #include "precompiled.hpp"
2016-12-10 14:57:14 +01:00
pavel.pimenov
eff42fa321
Add #include "precompiled.hpp"
2016-12-10 16:44:51 +03:00
Constantin Rack
f64d3ad1e7
Merge pull request #2247 from bluca/trusty_unwind
...
Problem: there is no libunwind-dev on Ubuntu 14.04LTS
2016-12-09 20:57:01 +01:00
Luca Boccassi
379028fbd9
Problem: there is no libunwind-dev on Ubuntu 14.04LTS
...
Solution: depend on libunwind-dev | libunwind8-dev | libunwind7-dev
2016-12-09 18:42:19 +00:00
Luca Boccassi
ad4a1bd0f3
Merge pull request #2245 from anass-b/builds-vs2017
...
Build support for VS2017, Windows SDK 10.0.14393.0, toolset v141
2016-12-09 10:41:07 +01:00
Anass Bouassaba
ad045512b9
Build support for VS2017, Windows SDK 10.0.14393.0, toolset v141
2016-12-09 09:21:11 +01:00
Luca Boccassi
d4076578a3
Merge pull request #2244 from rotty/wip/fix-mstcpip-include
...
Fix #include case for <mstcpip.h>
2016-12-08 16:50:03 +01:00
Andreas Rottmann
365ca8595d
Fix #include case for <mstcpip.h>
...
On native Windows, the file system is case-insensitive, so this this
doesn't matter there.
However, when compiling on a case-sensitive filesystem, such as when
cross-compiling from a Unixoid using mingw, we have to use the case
the file is supplied with, which is all lowercase.
2016-12-08 16:35:44 +01:00
Constantin Rack
519940d07c
Merge pull request #2241 from bluca/aix_test
...
Problem: test_stream_exceeds_buffer fails to build on AIX
2016-12-07 05:46:34 +01:00
Luca Boccassi
dcec022358
Problem: test_stream_exceeds_buffer does not build on AIX
...
Solution: add missing includes
2016-12-06 20:34:10 +00:00
Luca Boccassi
8325355d73
Problem: test_stream_exceeds_buffer has redundant includes
...
Solution: remove them as they are already in testutil.hpp
2016-12-06 20:33:46 +00:00
Constantin Rack
5e03ad6d87
Merge pull request #2240 from bluca/aix_poll
...
Problem: 4.2.0 won't compile on AIX 7.1
2016-12-06 19:34:20 +01:00