Commit a90c1db7 authored by Ian Barber's avatar Ian Barber

Filter read and write activated calls from the pipe to the session, and delay…

Filter read and write activated calls from the pipe to the session, and delay shutdown in terminated until the final pipe is shutdown.
parent a5f7300d
...@@ -233,11 +233,17 @@ void zmq::session_base_t::terminated (pipe_t *pipe_) ...@@ -233,11 +233,17 @@ void zmq::session_base_t::terminated (pipe_t *pipe_)
// Drop the reference to the deallocated pipe if required. // Drop the reference to the deallocated pipe if required.
zmq_assert (pipe == pipe_ || incomplete_detach > 0); zmq_assert (pipe == pipe_ || incomplete_detach > 0);
// If we still have pipes outstanding, decrement.
// This will only have been set in a disconnect situation
// where delay_attach_on_connect is 1.
if (incomplete_detach > 0) if (incomplete_detach > 0)
incomplete_detach --; incomplete_detach --;
if ( incomplete_detach == 0 ) // If there are still extra detached pipes, don't continue
pipe = NULL; if (incomplete_detach > 0)
return;
pipe = NULL;
// If we are waiting for pending messages to be sent, at this point // If we are waiting for pending messages to be sent, at this point
// we are sure that there will be no more messages and we can proceed // we are sure that there will be no more messages and we can proceed
...@@ -248,6 +254,10 @@ void zmq::session_base_t::terminated (pipe_t *pipe_) ...@@ -248,6 +254,10 @@ void zmq::session_base_t::terminated (pipe_t *pipe_)
void zmq::session_base_t::read_activated (pipe_t *pipe_) void zmq::session_base_t::read_activated (pipe_t *pipe_)
{ {
// Skip activating if we're detaching this pipe
if (incomplete_detach > 0 && pipe_ != pipe)
return;
zmq_assert (pipe == pipe_); zmq_assert (pipe == pipe_);
if (likely (engine != NULL)) if (likely (engine != NULL))
...@@ -258,6 +268,10 @@ void zmq::session_base_t::read_activated (pipe_t *pipe_) ...@@ -258,6 +268,10 @@ void zmq::session_base_t::read_activated (pipe_t *pipe_)
void zmq::session_base_t::write_activated (pipe_t *pipe_) void zmq::session_base_t::write_activated (pipe_t *pipe_)
{ {
// Skip activating if we're detaching this pipe
if (incomplete_detach > 0 && pipe_ != pipe)
return;
zmq_assert (pipe == pipe_); zmq_assert (pipe == pipe_);
if (engine) if (engine)
......
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