mirror of
https://github.com/zeromq/libzmq.git
synced 2025-03-17 08:34:00 +00:00
Merge pull request #31 from hintjens/master
Backported fixes for libzmq-39 and other patches.
This commit is contained in:
commit
f745e4ce64
@ -107,7 +107,6 @@ int zmq::ctx_t::terminate ()
|
|||||||
// restarted.
|
// restarted.
|
||||||
bool restarted = terminating;
|
bool restarted = terminating;
|
||||||
terminating = true;
|
terminating = true;
|
||||||
slot_sync.unlock ();
|
|
||||||
|
|
||||||
// First attempt to terminate the context.
|
// First attempt to terminate the context.
|
||||||
if (!restarted) {
|
if (!restarted) {
|
||||||
@ -115,13 +114,12 @@ int zmq::ctx_t::terminate ()
|
|||||||
// First send stop command to sockets so that any blocking calls
|
// First send stop command to sockets so that any blocking calls
|
||||||
// can be interrupted. If there are no sockets we can ask reaper
|
// can be interrupted. If there are no sockets we can ask reaper
|
||||||
// thread to stop.
|
// thread to stop.
|
||||||
slot_sync.lock ();
|
|
||||||
for (sockets_t::size_type i = 0; i != sockets.size (); i++)
|
for (sockets_t::size_type i = 0; i != sockets.size (); i++)
|
||||||
sockets [i]->stop ();
|
sockets [i]->stop ();
|
||||||
if (sockets.empty ())
|
if (sockets.empty ())
|
||||||
reaper->stop ();
|
reaper->stop ();
|
||||||
slot_sync.unlock ();
|
|
||||||
}
|
}
|
||||||
|
slot_sync.unlock();
|
||||||
|
|
||||||
// Wait till reaper thread closes all the sockets.
|
// Wait till reaper thread closes all the sockets.
|
||||||
command_t cmd;
|
command_t cmd;
|
||||||
|
@ -225,6 +225,8 @@ int zmq::router_t::xsend (msg_t *msg_)
|
|||||||
current_out->terminate (false);
|
current_out->terminate (false);
|
||||||
int rc = msg_->close ();
|
int rc = msg_->close ();
|
||||||
errno_assert (rc == 0);
|
errno_assert (rc == 0);
|
||||||
|
rc = msg_->init ();
|
||||||
|
errno_assert (rc == 0);
|
||||||
current_out = NULL;
|
current_out = NULL;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ noinst_PROGRAMS = test_system \
|
|||||||
test_term_endpoint \
|
test_term_endpoint \
|
||||||
test_monitor \
|
test_monitor \
|
||||||
test_router_mandatory \
|
test_router_mandatory \
|
||||||
|
test_router_raw_empty \
|
||||||
test_probe_router \
|
test_probe_router \
|
||||||
test_stream \
|
test_stream \
|
||||||
test_disconnect_inproc \
|
test_disconnect_inproc \
|
||||||
@ -64,6 +65,7 @@ test_last_endpoint_SOURCES = test_last_endpoint.cpp
|
|||||||
test_term_endpoint_SOURCES = test_term_endpoint.cpp
|
test_term_endpoint_SOURCES = test_term_endpoint.cpp
|
||||||
test_monitor_SOURCES = test_monitor.cpp
|
test_monitor_SOURCES = test_monitor.cpp
|
||||||
test_router_mandatory_SOURCES = test_router_mandatory.cpp
|
test_router_mandatory_SOURCES = test_router_mandatory.cpp
|
||||||
|
test_router_raw_empty_SOURCES = test_router_raw_empty.cpp
|
||||||
test_probe_router_SOURCES = test_probe_router.cpp
|
test_probe_router_SOURCES = test_probe_router.cpp
|
||||||
test_stream_SOURCES = test_stream.cpp
|
test_stream_SOURCES = test_stream.cpp
|
||||||
test_disconnect_inproc_SOURCES = test_disconnect_inproc.cpp
|
test_disconnect_inproc_SOURCES = test_disconnect_inproc.cpp
|
||||||
|
@ -33,7 +33,7 @@ int main (void)
|
|||||||
assert (zmq_ctx_get (ctx, ZMQ_IPV6) == 0);
|
assert (zmq_ctx_get (ctx, ZMQ_IPV6) == 0);
|
||||||
|
|
||||||
rc = zmq_ctx_set (ctx, ZMQ_IPV6, true);
|
rc = zmq_ctx_set (ctx, ZMQ_IPV6, true);
|
||||||
assert (zmq_ctx_get (ctx, ZMQ_IPV6) == true);
|
assert (zmq_ctx_get (ctx, ZMQ_IPV6) == 1);
|
||||||
|
|
||||||
void *router = zmq_socket (ctx, ZMQ_ROUTER);
|
void *router = zmq_socket (ctx, ZMQ_ROUTER);
|
||||||
int ipv6;
|
int ipv6;
|
||||||
|
65
tests/test_router_raw_empty.cpp
Normal file
65
tests/test_router_raw_empty.cpp
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
/*
|
||||||
|
Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
|
||||||
|
|
||||||
|
This file is part of 0MQ.
|
||||||
|
|
||||||
|
0MQ is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
0MQ is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "testutil.hpp"
|
||||||
|
|
||||||
|
int main (void) {
|
||||||
|
setup_test_environment();
|
||||||
|
void *ctx = zmq_ctx_new();
|
||||||
|
assert(ctx);
|
||||||
|
|
||||||
|
void *router = zmq_socket(ctx, ZMQ_ROUTER);
|
||||||
|
assert(router);
|
||||||
|
void *dealer = zmq_socket(ctx, ZMQ_DEALER);
|
||||||
|
assert(dealer);
|
||||||
|
|
||||||
|
int one=1;
|
||||||
|
int rc = zmq_setsockopt(router, ZMQ_ROUTER_RAW, &one, sizeof(int));
|
||||||
|
assert(rc >= 0);
|
||||||
|
rc = zmq_setsockopt(router, ZMQ_ROUTER_MANDATORY, &one, sizeof(int));
|
||||||
|
assert(rc >= 0);
|
||||||
|
|
||||||
|
rc = zmq_bind(router, "tcp://127.0.0.1:5555");
|
||||||
|
rc = zmq_connect(dealer, "tcp://127.0.0.1:5555");
|
||||||
|
zmq_send(dealer, "", 0, 0);
|
||||||
|
|
||||||
|
|
||||||
|
zmq_msg_t ident, empty;
|
||||||
|
zmq_msg_init(&ident);
|
||||||
|
rc = zmq_msg_recv(&ident, router, 0);
|
||||||
|
assert(rc >= 0);
|
||||||
|
rc = zmq_msg_init_data(&empty, (void*)"", 0, NULL, NULL);
|
||||||
|
assert(rc >= 0);
|
||||||
|
|
||||||
|
rc = zmq_msg_send(&ident, router, ZMQ_SNDMORE);
|
||||||
|
assert(rc >= 0);
|
||||||
|
rc = zmq_msg_close(&ident);
|
||||||
|
assert(rc >= 0);
|
||||||
|
|
||||||
|
rc = zmq_msg_send(&empty, router, 0);
|
||||||
|
assert(rc >= 0);
|
||||||
|
|
||||||
|
// This close used to fail with Bad Address
|
||||||
|
rc = zmq_msg_close(&empty);
|
||||||
|
assert(rc >= 0);
|
||||||
|
|
||||||
|
close_zero_linger(dealer);
|
||||||
|
close_zero_linger(router);
|
||||||
|
zmq_ctx_term(ctx);
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user