Commit a2d736c1 authored by Simon Giesecke's avatar Simon Giesecke

Problem: functionality around inprocs_t is scattered

Solution: extract into functions of new inprocs_t class
parent fb576d2f
...@@ -97,6 +97,36 @@ ...@@ -97,6 +97,36 @@
#include "scatter.hpp" #include "scatter.hpp"
#include "dgram.hpp" #include "dgram.hpp"
void zmq::socket_base_t::inprocs_t::emplace (const char *addr_, pipe_t *pipe_)
{
_inprocs.ZMQ_MAP_INSERT_OR_EMPLACE (std::string (addr_), pipe_);
}
int zmq::socket_base_t::inprocs_t::erase_pipes (const std::string &addr_str_)
{
const std::pair<map_t::iterator, map_t::iterator> range =
_inprocs.equal_range (addr_str_);
if (range.first == range.second) {
errno = ENOENT;
return -1;
}
for (map_t::iterator it = range.first; it != range.second; ++it)
it->second->terminate (true);
_inprocs.erase (range.first, range.second);
return 0;
}
void zmq::socket_base_t::inprocs_t::erase_pipe (pipe_t *pipe_)
{
for (map_t::iterator it = _inprocs.begin (), end = _inprocs.end ();
it != end; ++it)
if (it->second == pipe_) {
_inprocs.erase (it);
break;
}
}
bool zmq::socket_base_t::check_tag () const bool zmq::socket_base_t::check_tag () const
{ {
return _tag == 0xbaddecaf; return _tag == 0xbaddecaf;
...@@ -749,7 +779,7 @@ int zmq::socket_base_t::connect (const char *addr_) ...@@ -749,7 +779,7 @@ int zmq::socket_base_t::connect (const char *addr_)
_last_endpoint.assign (addr_); _last_endpoint.assign (addr_);
// remember inproc connections for disconnect // remember inproc connections for disconnect
_inprocs.ZMQ_MAP_INSERT_OR_EMPLACE (std::string (addr_), new_pipes[0]); _inprocs.emplace (addr_, new_pipes[0]);
options.connected = true; options.connected = true;
return 0; return 0;
...@@ -978,24 +1008,13 @@ int zmq::socket_base_t::term_endpoint (const char *addr_) ...@@ -978,24 +1008,13 @@ int zmq::socket_base_t::term_endpoint (const char *addr_)
return -1; return -1;
} }
const std::string addr_str = std::string (addr_);
// Disconnect an inproc socket // Disconnect an inproc socket
if (protocol == "inproc") { if (protocol == "inproc") {
if (unregister_endpoint (addr_str, this) == 0) { const std::string addr_str = std::string (addr_);
return 0;
}
const std::pair<inprocs_t::iterator, inprocs_t::iterator> range =
_inprocs.equal_range (addr_str);
if (range.first == range.second) {
errno = ENOENT;
return -1;
}
for (inprocs_t::iterator it = range.first; it != range.second; ++it) return unregister_endpoint (addr_str, this) == 0
it->second->terminate (true); ? 0
_inprocs.erase (range.first, range.second); : _inprocs.erase_pipes (addr_str);
return 0;
} }
std::string resolved_addr = addr_; std::string resolved_addr = addr_;
...@@ -1507,12 +1526,7 @@ void zmq::socket_base_t::pipe_terminated (pipe_t *pipe_) ...@@ -1507,12 +1526,7 @@ void zmq::socket_base_t::pipe_terminated (pipe_t *pipe_)
xpipe_terminated (pipe_); xpipe_terminated (pipe_);
// Remove pipe from inproc pipes // Remove pipe from inproc pipes
for (inprocs_t::iterator it = _inprocs.begin (), end = _inprocs.end (); _inprocs.erase_pipe (pipe_);
it != end; ++it)
if (it->second == pipe_) {
_inprocs.erase (it);
break;
}
// Remove the pipe from the list of attached pipes and confirm its // Remove the pipe from the list of attached pipes and confirm its
// termination if we are already shutting down. // termination if we are already shutting down.
......
...@@ -200,7 +200,17 @@ class socket_base_t : public own_t, ...@@ -200,7 +200,17 @@ class socket_base_t : public own_t,
endpoints_t _endpoints; endpoints_t _endpoints;
// Map of open inproc endpoints. // Map of open inproc endpoints.
typedef std::multimap<std::string, pipe_t *> inprocs_t; class inprocs_t
{
public:
void emplace (const char *addr_, pipe_t *pipe_);
int erase_pipes (const std::string &addr_str_);
void erase_pipe (pipe_t *pipe_);
private:
typedef std::multimap<std::string, pipe_t *> map_t;
map_t _inprocs;
};
inprocs_t _inprocs; inprocs_t _inprocs;
// To be called after processing commands or invoking any command // To be called after processing commands or invoking any command
......
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