mirror of
https://github.com/zeromq/libzmq.git
synced 2024-12-13 02:42:58 +01:00
Problem: duplicated code in stream_t & router_t
Solution: pulled up to routing_socket_base_t
This commit is contained in:
parent
09fab930b3
commit
ab3895a470
@ -152,9 +152,7 @@ void zmq::router_t::xpipe_terminated (pipe_t *pipe_)
|
||||
if (it != _anonymous_pipes.end ())
|
||||
_anonymous_pipes.erase (it);
|
||||
else {
|
||||
out_pipes_t::iterator iter = _out_pipes.find (pipe_->get_routing_id ());
|
||||
zmq_assert (iter != _out_pipes.end ());
|
||||
_out_pipes.erase (iter);
|
||||
erase_out_pipe (pipe_);
|
||||
_fq.pipe_terminated (pipe_);
|
||||
pipe_->rollback ();
|
||||
if (pipe_ == _current_out)
|
||||
|
@ -1770,6 +1770,11 @@ zmq::routing_socket_base_t::routing_socket_base_t (class ctx_t *parent_,
|
||||
{
|
||||
}
|
||||
|
||||
zmq::routing_socket_base_t::~routing_socket_base_t ()
|
||||
{
|
||||
zmq_assert (_out_pipes.empty ());
|
||||
}
|
||||
|
||||
int zmq::routing_socket_base_t::xsetsockopt (int option_,
|
||||
const void *optval_,
|
||||
size_t optvallen_)
|
||||
@ -1807,3 +1812,10 @@ std::string zmq::routing_socket_base_t::extract_connect_routing_id ()
|
||||
_connect_routing_id.clear ();
|
||||
return res;
|
||||
}
|
||||
|
||||
void zmq::routing_socket_base_t::erase_out_pipe (pipe_t *pipe_)
|
||||
{
|
||||
out_pipes_t::iterator it = _out_pipes.find (pipe_->get_routing_id ());
|
||||
zmq_assert (it != _out_pipes.end ());
|
||||
_out_pipes.erase (it);
|
||||
}
|
||||
|
@ -302,15 +302,18 @@ class routing_socket_base_t : public socket_base_t
|
||||
{
|
||||
protected:
|
||||
routing_socket_base_t (class ctx_t *parent_, uint32_t tid_, int sid_);
|
||||
~routing_socket_base_t ();
|
||||
|
||||
// methods from socket_base_t
|
||||
virtual int
|
||||
xsetsockopt (int option_, const void *optval_, size_t optvallen_);
|
||||
virtual void xwrite_activated (pipe_t *pipe_);
|
||||
|
||||
void xwrite_activated (pipe_t *pipe_);
|
||||
|
||||
|
||||
// own methods
|
||||
std::string extract_connect_routing_id ();
|
||||
|
||||
void erase_out_pipe (pipe_t *pipe_);
|
||||
|
||||
struct out_pipe_t
|
||||
{
|
||||
pipe_t *pipe;
|
||||
|
@ -53,7 +53,6 @@ zmq::stream_t::stream_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
|
||||
|
||||
zmq::stream_t::~stream_t ()
|
||||
{
|
||||
zmq_assert (_out_pipes.empty ());
|
||||
_prefetched_routing_id.close ();
|
||||
_prefetched_msg.close ();
|
||||
}
|
||||
@ -70,9 +69,7 @@ void zmq::stream_t::xattach_pipe (pipe_t *pipe_, bool subscribe_to_all_)
|
||||
|
||||
void zmq::stream_t::xpipe_terminated (pipe_t *pipe_)
|
||||
{
|
||||
out_pipes_t::iterator it = _out_pipes.find (pipe_->get_routing_id ());
|
||||
zmq_assert (it != _out_pipes.end ());
|
||||
_out_pipes.erase (it);
|
||||
erase_out_pipe (pipe_);
|
||||
_fq.pipe_terminated (pipe_);
|
||||
// TODO router_t calls pipe_->rollback() here; should this be done here as
|
||||
// well? then xpipe_terminated could be pulled up to routing_socket_base_t
|
||||
|
Loading…
Reference in New Issue
Block a user