Skip to content

Commit

Permalink
fixes #1315 socket monitor hangs if zmq_bind fails
Browse files Browse the repository at this point in the history
  • Loading branch information
Charles Stanley committed Oct 9, 2015
1 parent a28398a commit 516b440
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 5 deletions.
8 changes: 4 additions & 4 deletions src/socket_base.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1497,12 +1497,12 @@ int zmq::socket_base_t::monitor (const char *addr_, int events_)
int linger = 0;
int rc = zmq_setsockopt (monitor_socket, ZMQ_LINGER, &linger, sizeof (linger));
if (rc == -1)
stop_monitor ();
stop_monitor (false);

// Spawn the monitor socket endpoint
rc = zmq_bind (monitor_socket, addr_);
if (rc == -1)
stop_monitor ();
stop_monitor (false);
return rc;
}

Expand Down Expand Up @@ -1598,10 +1598,10 @@ void zmq::socket_base_t::monitor_event (int event_, int value_, const std::strin
}
}

void zmq::socket_base_t::stop_monitor (void)
void zmq::socket_base_t::stop_monitor (bool send_monitor_stopped_event_)
{
if (monitor_socket) {
if (monitor_events & ZMQ_EVENT_MONITOR_STOPPED)
if ((monitor_events & ZMQ_EVENT_MONITOR_STOPPED) && send_monitor_stopped_event_)
monitor_event (ZMQ_EVENT_MONITOR_STOPPED, 0, "");
zmq_close (monitor_socket);
monitor_socket = NULL;
Expand Down
2 changes: 1 addition & 1 deletion src/socket_base.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ namespace zmq
void monitor_event (int event_, int value_, const std::string& addr_);

// Monitor socket cleanup
void stop_monitor ();
void stop_monitor (bool send_monitor_stopped_event_ = true);

// Next assigned name on a zmq_connect() call used by ROUTER and STREAM socket types
std::string connect_rid;
Expand Down

0 comments on commit 516b440

Please sign in to comment.