diff options
author | Martin Sustrik <sustrik@250bpm.com> | 2011-04-22 07:51:24 +0200 |
---|---|---|
committer | Martin Sustrik <sustrik@250bpm.com> | 2011-04-22 07:51:24 +0200 |
commit | 10fbc78e5cab494c3af727f5ea451fdced1c9d95 (patch) | |
tree | 8b29dfd2e0810217aba3ccdef3f3572a96188e2d | |
parent | e0246e32d79d71f8e73207b43aed8b23648e4fc7 (diff) |
Assert during SUB socket termination fixed.
Fair queueing algorithm was checking whether the current pipe
is not closed in the middle of reading a multipart message.
However, this is OK when the socket is closing down.
Signed-off-by: Martin Sustrik <sustrik@250bpm.com>
-rw-r--r-- | src/fq.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
@@ -55,10 +55,9 @@ void zmq::fq_t::attach (reader_t *pipe_) void zmq::fq_t::terminated (reader_t *pipe_) { - // TODO: This is a problem with session-initiated termination. It breaks - // message atomicity. However, for socket initiated termination it's - // just fine. - zmq_assert (!more || pipes [current] != pipe_); + // Make sure that we are not closing current pipe while + // message is half-read. + zmq_assert (terminating || (!more || pipes [current] != pipe_)); // Remove the pipe from the list; adjust number of active pipes // accordingly. |