Commit dc2ab432 authored by Pieter Hintjens's avatar Pieter Hintjens

Merge pull request #789 from trevorbernard/single-connect

Single connect
parents 02a8d1ea 754ae1b1
...@@ -93,6 +93,7 @@ Terry Wilson <terry@logivox.net> ...@@ -93,6 +93,7 @@ Terry Wilson <terry@logivox.net>
Thijs Terlouw <thijsterlouw@gmail.com> Thijs Terlouw <thijsterlouw@gmail.com>
Toralf Wittner <toralf.wittner@gmail.com> Toralf Wittner <toralf.wittner@gmail.com>
Tore Halvorsen <tore.halvorsen@gmail.com> Tore Halvorsen <tore.halvorsen@gmail.com>
Trevor Bernard <trevor.bernard@gmail.com>
Vitaly Mayatskikh <v.mayatskih@gmail.com> Vitaly Mayatskikh <v.mayatskih@gmail.com>
Lourens Naudé <lourens@methodmissing.com> Lourens Naudé <lourens@methodmissing.com>
Hardeep Singh <hshardeesi@gmail.com> Hardeep Singh <hshardeesi@gmail.com>
......
...@@ -546,6 +546,18 @@ int zmq::socket_base_t::connect (const char *addr_) ...@@ -546,6 +546,18 @@ int zmq::socket_base_t::connect (const char *addr_)
return 0; return 0;
} }
bool is_single_connect = (options.type == ZMQ_DEALER ||
options.type == ZMQ_SUB ||
options.type == ZMQ_REQ);
if (unlikely (is_single_connect)) {
endpoints_t::iterator it = endpoints.find (addr_);
if (it != endpoints.end ()) {
// There is no valid use for multiple connects for SUB-PUB nor
// DEALER-ROUTER nor REQ-REP. Multiple connects produces
// nonsensical results.
return 0;
}
}
// Choose the I/O thread to run the session in. // Choose the I/O thread to run the session in.
io_thread_t *io_thread = choose_io_thread (options.affinity); io_thread_t *io_thread = choose_io_thread (options.affinity);
......
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