Commit 92923cd4 authored by Martin Sustrik's avatar Martin Sustrik

bug in pipe deactivation fixed

parent 035c937e
...@@ -80,11 +80,8 @@ bool zmq::reader_t::check_read () ...@@ -80,11 +80,8 @@ bool zmq::reader_t::check_read ()
return false; return false;
// Check if there's an item in the pipe. // Check if there's an item in the pipe.
// If not, deactivate the pipe. if (!pipe->check_read ())
if (!pipe->check_read ()) {
terminate ();
return false; return false;
}
// If the next item in the pipe is message delimiter, // If the next item in the pipe is message delimiter,
// initiate its termination. // initiate its termination.
...@@ -198,7 +195,8 @@ bool zmq::writer_t::check_write () ...@@ -198,7 +195,8 @@ bool zmq::writer_t::check_write ()
if (terminating) if (terminating)
return false; return false;
if (pipe_full () && (msg_store == NULL || msg_store->full () || extra_msg_flag)) { if (pipe_full () && (msg_store == NULL || msg_store->full () ||
extra_msg_flag)) {
stalled = true; stalled = true;
return false; return false;
} }
......
...@@ -244,7 +244,7 @@ int zmq::socket_base_t::getsockopt (int option_, void *optval_, ...@@ -244,7 +244,7 @@ int zmq::socket_base_t::getsockopt (int option_, void *optval_,
errno = EINVAL; errno = EINVAL;
return -1; return -1;
} }
process_commands(false, false); process_commands (false, false);
*((uint32_t*) optval_) = 0; *((uint32_t*) optval_) = 0;
if (has_out ()) if (has_out ())
*((uint32_t*) optval_) |= ZMQ_POLLOUT; *((uint32_t*) optval_) |= ZMQ_POLLOUT;
......
...@@ -39,9 +39,10 @@ int main () ...@@ -39,9 +39,10 @@ int main ()
{ {
const string returned = zmqtestutil::ping_pong (p, expect); const string returned = zmqtestutil::ping_pong (p, expect);
assert (expect == returned); assert (expect == returned);
// Adjust socket state so that poll shows only 1 pending message. // Adjust socket state so that poll shows only 1 pending message.
zmq::message_t mx ; zmq::message_t mx ;
p.first->recv(&mx, 0); p.first->recv (&mx, 0);
} }
{ {
...@@ -58,8 +59,7 @@ int main () ...@@ -58,8 +59,7 @@ int main ()
p.first->send (m1, 0); p.first->send (m1, 0);
// Now use polling. Timout makes test abort on error. int rc = zmq::poll (&items [0], 2, -1);
int rc = zmq::poll (&items [0], 2, 1000);
assert (rc == 1); assert (rc == 1);
assert ((items [1].revents & ZMQ_POLLIN) != 0); assert ((items [1].revents & ZMQ_POLLIN) != 0);
...@@ -74,4 +74,5 @@ int main () ...@@ -74,4 +74,5 @@ int main ()
delete (p.second); delete (p.second);
return 0 ; return 0 ;
assert (false);
} }
...@@ -39,6 +39,7 @@ int main() ...@@ -39,6 +39,7 @@ int main()
{ {
const string returned = zmqtestutil::ping_pong (p, expect); const string returned = zmqtestutil::ping_pong (p, expect);
assert (expect == returned); assert (expect == returned);
// Adjust socket state, so that first is clean for another send. // Adjust socket state, so that first is clean for another send.
zmq::message_t mx ; zmq::message_t mx ;
p.first->recv(&mx, 0); p.first->recv(&mx, 0);
...@@ -58,8 +59,7 @@ int main() ...@@ -58,8 +59,7 @@ int main()
p.first->send (m1, 0); p.first->send (m1, 0);
// Now use polling. Timout makes test abort on error. int rc = zmq::poll(&items [0], 2, -1);
int rc = zmq::poll(&items [0], 2, 1000);
assert (rc == 1); assert (rc == 1);
assert ((items [1].revents & ZMQ_POLLIN) != 0); assert ((items [1].revents & ZMQ_POLLIN) != 0);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment