Commit 19da88be authored by Ian Barber's avatar Ian Barber

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

Revert "Filter read and write activated calls from the pipe to the session, and delay shutdown in terminated until the final pipe is shutdown."

This reverts commit a90c1db7.
parent 4aaf3e63
...@@ -233,17 +233,11 @@ void zmq::session_base_t::terminated (pipe_t *pipe_) ...@@ -233,17 +233,11 @@ 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 there are still extra detached pipes, don't continue if ( incomplete_detach == 0 )
if (incomplete_detach > 0) pipe = NULL;
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
...@@ -254,10 +248,6 @@ void zmq::session_base_t::terminated (pipe_t *pipe_) ...@@ -254,10 +248,6 @@ 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))
...@@ -268,10 +258,6 @@ void zmq::session_base_t::read_activated (pipe_t *pipe_) ...@@ -268,10 +258,6 @@ 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