Commit 1ab85f47 authored by Martin Hurton's avatar Martin Hurton

Exchange greeting messages for all socket types

Fixes #415.
parent b32542e3
...@@ -35,7 +35,6 @@ zmq::dealer_t::dealer_t (class ctx_t *parent_, uint32_t tid_, int sid_) : ...@@ -35,7 +35,6 @@ zmq::dealer_t::dealer_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
// be noone to receive the replies anyway. // be noone to receive the replies anyway.
// options.delay_on_close = false; // options.delay_on_close = false;
options.send_identity = true;
options.recv_identity = true; options.recv_identity = true;
prefetched_msg.init (); prefetched_msg.init ();
......
...@@ -48,7 +48,6 @@ zmq::options_t::options_t () : ...@@ -48,7 +48,6 @@ zmq::options_t::options_t () :
delay_on_close (true), delay_on_close (true),
delay_on_disconnect (true), delay_on_disconnect (true),
filter (false), filter (false),
send_identity (false),
recv_identity (false), recv_identity (false),
tcp_keepalive (-1), tcp_keepalive (-1),
tcp_keepalive_cnt (-1), tcp_keepalive_cnt (-1),
......
...@@ -112,10 +112,7 @@ namespace zmq ...@@ -112,10 +112,7 @@ namespace zmq
// If 1, (X)SUB socket should filter the messages. If 0, it should not. // If 1, (X)SUB socket should filter the messages. If 0, it should not.
bool filter; bool filter;
// Sends identity to all new connections. // If true, the identity message is forwarded to the socket.
bool send_identity;
// Receivers identity from all new connections.
bool recv_identity; bool recv_identity;
// TCP keep-alive settings. // TCP keep-alive settings.
......
...@@ -45,7 +45,6 @@ zmq::router_t::router_t (class ctx_t *parent_, uint32_t tid_, int sid_) : ...@@ -45,7 +45,6 @@ zmq::router_t::router_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
// all the outstanding requests from that peer. // all the outstanding requests from that peer.
// options.delay_on_disconnect = false; // options.delay_on_disconnect = false;
options.send_identity = true;
options.recv_identity = true; options.recv_identity = true;
prefetched_id.init (); prefetched_id.init ();
......
...@@ -117,8 +117,8 @@ zmq::session_base_t::session_base_t (class io_thread_t *io_thread_, ...@@ -117,8 +117,8 @@ zmq::session_base_t::session_base_t (class io_thread_t *io_thread_,
socket (socket_), socket (socket_),
io_thread (io_thread_), io_thread (io_thread_),
has_linger_timer (false), has_linger_timer (false),
send_identity (options_.send_identity), identity_sent (false),
recv_identity (options_.recv_identity), identity_received (false),
addr (addr_) addr (addr_)
{ {
} }
...@@ -152,13 +152,13 @@ void zmq::session_base_t::attach_pipe (pipe_t *pipe_) ...@@ -152,13 +152,13 @@ void zmq::session_base_t::attach_pipe (pipe_t *pipe_)
int zmq::session_base_t::read (msg_t *msg_) int zmq::session_base_t::read (msg_t *msg_)
{ {
// First message to send is identity (if required). // First message to send is identity
if (send_identity) { if (!identity_sent) {
zmq_assert (!(msg_->flags () & msg_t::more)); zmq_assert (!(msg_->flags () & msg_t::more));
int rc = msg_->init_size (options.identity_size); int rc = msg_->init_size (options.identity_size);
errno_assert (rc == 0); errno_assert (rc == 0);
memcpy (msg_->data (), options.identity, options.identity_size); memcpy (msg_->data (), options.identity, options.identity_size);
send_identity = false; identity_sent = true;
incomplete_in = false; incomplete_in = false;
return 0; return 0;
} }
...@@ -174,10 +174,17 @@ int zmq::session_base_t::read (msg_t *msg_) ...@@ -174,10 +174,17 @@ int zmq::session_base_t::read (msg_t *msg_)
int zmq::session_base_t::write (msg_t *msg_) int zmq::session_base_t::write (msg_t *msg_)
{ {
// First message to receive is identity (if required). // First message to receive is identity
if (recv_identity) { if (!identity_received) {
msg_->set_flags (msg_t::identity); msg_->set_flags (msg_t::identity);
recv_identity = false; identity_received = true;
if (!options.recv_identity) {
int rc = msg_->close ();
errno_assert (rc == 0);
rc = msg_->init ();
errno_assert (rc == 0);
return 0;
}
} }
if (pipe && pipe->write (msg_)) { if (pipe && pipe->write (msg_)) {
...@@ -193,8 +200,8 @@ int zmq::session_base_t::write (msg_t *msg_) ...@@ -193,8 +200,8 @@ int zmq::session_base_t::write (msg_t *msg_)
void zmq::session_base_t::reset () void zmq::session_base_t::reset ()
{ {
// Restore identity flags. // Restore identity flags.
send_identity = options.send_identity; identity_sent = false;
recv_identity = options.recv_identity; identity_received = false;
} }
void zmq::session_base_t::flush () void zmq::session_base_t::flush ()
......
...@@ -130,9 +130,9 @@ namespace zmq ...@@ -130,9 +130,9 @@ namespace zmq
// True is linger timer is running. // True is linger timer is running.
bool has_linger_timer; bool has_linger_timer;
// If true, identity is to be sent/recvd from the network. // If true, identity has been sent/received from the network.
bool send_identity; bool identity_sent;
bool recv_identity; bool identity_received;
// Protocol and address to use when connecting. // Protocol and address to use when connecting.
const address_t *addr; const address_t *addr;
......
...@@ -448,7 +448,7 @@ int zmq::socket_base_t::connect (const char *addr_) ...@@ -448,7 +448,7 @@ int zmq::socket_base_t::connect (const char *addr_)
attach_pipe (pipes [0]); attach_pipe (pipes [0]);
// If required, send the identity of the local socket to the peer. // If required, send the identity of the local socket to the peer.
if (options.send_identity) { if (peer.options.recv_identity) {
msg_t id; msg_t id;
rc = id.init_size (options.identity_size); rc = id.init_size (options.identity_size);
errno_assert (rc == 0); errno_assert (rc == 0);
...@@ -460,7 +460,7 @@ int zmq::socket_base_t::connect (const char *addr_) ...@@ -460,7 +460,7 @@ int zmq::socket_base_t::connect (const char *addr_)
} }
// If required, send the identity of the peer to the local socket. // If required, send the identity of the peer to the local socket.
if (peer.options.send_identity) { if (options.recv_identity) {
msg_t id; msg_t id;
rc = id.init_size (peer.options.identity_size); rc = id.init_size (peer.options.identity_size);
errno_assert (rc == 0); errno_assert (rc == 0);
......
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