mirror of
https://github.com/zeromq/libzmq.git
synced 2024-12-28 07:58:14 +08:00
Fix for issue #307
dist was skipping over pipes when one failed because the non-working pipe got swapped with a working pipe but the write was never retried on that pipe
This commit is contained in:
parent
6d776d0865
commit
084e1c2193
@ -139,7 +139,8 @@ void zmq::dist_t::distribute (msg_t *msg_, int flags_)
|
||||
|
||||
if (msg_->is_vsm ()) {
|
||||
for (pipes_t::size_type i = 0; i < matching; ++i)
|
||||
write (pipes [i], msg_);
|
||||
if(!write (pipes [i], msg_))
|
||||
--i; // Retry last write because index will have been swapped
|
||||
int rc = msg_->close();
|
||||
errno_assert (rc == 0);
|
||||
rc = msg_->init ();
|
||||
@ -154,8 +155,10 @@ void zmq::dist_t::distribute (msg_t *msg_, int flags_)
|
||||
// Push copy of the message to each matching pipe.
|
||||
int failed = 0;
|
||||
for (pipes_t::size_type i = 0; i < matching; ++i)
|
||||
if (!write (pipes [i], msg_))
|
||||
if (!write (pipes [i], msg_)) {
|
||||
++failed;
|
||||
--i; // Retry last write because index will have been swapped
|
||||
}
|
||||
if (unlikely (failed))
|
||||
msg_->rm_refs (failed);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user