Commit 9a6993ad authored by sigiesec's avatar sigiesec Committed by Simon Giesecke

Problem: several code style issues in mechanism_t: code and data duplication,

unnecessary construction of temporary std::string

Solution: removed duplication, removed construction of std::string
parent b77d7610
...@@ -70,13 +70,44 @@ const zmq::blob_t &zmq::mechanism_t::get_user_id () const ...@@ -70,13 +70,44 @@ const zmq::blob_t &zmq::mechanism_t::get_user_id () const
return user_id; return user_id;
} }
const char socket_type_pair[] = "PAIR";
const char socket_type_pub[] = "PUB";
const char socket_type_sub[] = "SUB";
const char socket_type_req[] = "REQ";
const char socket_type_rep[] = "REP";
const char socket_type_dealer[] = "DEALER";
const char socket_type_router[] = "ROUTER";
const char socket_type_pull[] = "PULL";
const char socket_type_push[] = "PUSH";
const char socket_type_xpub[] = "XPUB";
const char socket_type_xsub[] = "XSUB";
const char socket_type_stream[] = "STREAM";
#ifdef ZMQ_BUILD_DRAFT_API
const char socket_type_server[] = "SERVER";
const char socket_type_client[] = "CLIENT";
const char socket_type_radio[] = "RADIO";
const char socket_type_dish[] = "DISH";
const char socket_type_gather[] = "GATHER";
const char socket_type_scatter[] = "SCATTER";
const char socket_type_dgram[] = "DGRAM";
#endif
const char *zmq::mechanism_t::socket_type_string (int socket_type) const const char *zmq::mechanism_t::socket_type_string (int socket_type) const
{ {
// TODO the order must of the names must correspond to the values resp. order of ZMQ_* socket type definitions in zmq.h!
static const char *names[] = { static const char *names[] = {
"PAIR", "PUB", "SUB", "REQ", "REP", "DEALER", "ROUTER", socket_type_pair, socket_type_pub, socket_type_sub,
"PULL", "PUSH", "XPUB", "XSUB", "STREAM", "SERVER", "CLIENT", socket_type_req, socket_type_rep, socket_type_dealer,
"RADIO", "DISH", "GATHER", "SCATTER", "DGRAM"}; socket_type_router, socket_type_pull, socket_type_push,
zmq_assert (socket_type >= 0 && socket_type <= 18); socket_type_xpub, socket_type_xsub, socket_type_stream,
#ifdef ZMQ_BUILD_DRAFT_API
socket_type_server, socket_type_client, socket_type_radio,
socket_type_dish, socket_type_gather, socket_type_scatter,
socket_type_dgram
#endif
};
static const size_t names_count = sizeof (names) / sizeof (names[0]);
zmq_assert (socket_type >= 0 && socket_type < (int) names_count);
return names[socket_type]; return names[socket_type];
} }
...@@ -133,10 +164,11 @@ size_t zmq::mechanism_t::add_basic_properties (unsigned char *buf, ...@@ -133,10 +164,11 @@ size_t zmq::mechanism_t::add_basic_properties (unsigned char *buf,
// Add identity (aka routing id) property // Add identity (aka routing id) property
if (options.type == ZMQ_REQ || options.type == ZMQ_DEALER if (options.type == ZMQ_REQ || options.type == ZMQ_DEALER
|| options.type == ZMQ_ROUTER) || options.type == ZMQ_ROUTER) {
ptr += ptr +=
add_property (ptr, buf_capacity - (ptr - buf), ZMTP_PROPERTY_IDENTITY, add_property (ptr, buf_capacity - (ptr - buf), ZMTP_PROPERTY_IDENTITY,
options.routing_id, options.routing_id_size); options.routing_id, options.routing_id_size);
}
return ptr - buf; return ptr - buf;
} }
...@@ -152,17 +184,17 @@ size_t zmq::mechanism_t::basic_properties_len () const ...@@ -152,17 +184,17 @@ size_t zmq::mechanism_t::basic_properties_len () const
} }
void zmq::mechanism_t::make_command_with_basic_properties ( void zmq::mechanism_t::make_command_with_basic_properties (
msg_t *msg_, const char *prefix, size_t prefix_len) const msg_t *msg_, const char *prefix_, size_t prefix_len_) const
{ {
const size_t command_size = prefix_len + basic_properties_len (); const size_t command_size = prefix_len_ + basic_properties_len ();
const int rc = msg_->init_size (command_size); const int rc = msg_->init_size (command_size);
errno_assert (rc == 0); errno_assert (rc == 0);
unsigned char *ptr = (unsigned char *) msg_->data (); unsigned char *ptr = (unsigned char *) msg_->data ();
// Add prefix // Add prefix
memcpy (ptr, prefix, prefix_len); memcpy (ptr, prefix_, prefix_len_);
ptr += prefix_len; ptr += prefix_len_;
add_basic_properties (ptr, command_size add_basic_properties (ptr, command_size
- (ptr - (unsigned char *) msg_->data ())); - (ptr - (unsigned char *) msg_->data ()));
...@@ -170,7 +202,7 @@ void zmq::mechanism_t::make_command_with_basic_properties ( ...@@ -170,7 +202,7 @@ void zmq::mechanism_t::make_command_with_basic_properties (
int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_, int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_,
size_t length_, size_t length_,
bool zap_flag) bool zap_flag_)
{ {
size_t bytes_left = length_; size_t bytes_left = length_;
...@@ -200,8 +232,7 @@ int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_, ...@@ -200,8 +232,7 @@ int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_,
if (name == ZMTP_PROPERTY_IDENTITY && options.recv_routing_id) if (name == ZMTP_PROPERTY_IDENTITY && options.recv_routing_id)
set_peer_routing_id (value, value_length); set_peer_routing_id (value, value_length);
else if (name == ZMTP_PROPERTY_SOCKET_TYPE) { else if (name == ZMTP_PROPERTY_SOCKET_TYPE) {
const std::string socket_type ((char *) value, value_length); if (!check_socket_type ((const char *) value, value_length)) {
if (!check_socket_type (socket_type)) {
errno = EINVAL; errno = EINVAL;
return -1; return -1;
} }
...@@ -210,11 +241,8 @@ int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_, ...@@ -210,11 +241,8 @@ int zmq::mechanism_t::parse_metadata (const unsigned char *ptr_,
if (rc == -1) if (rc == -1)
return -1; return -1;
} }
if (zap_flag) (zap_flag_ ? zap_properties : zmtp_properties)
zap_properties.ZMQ_MAP_INSERT_OR_EMPLACE ( .ZMQ_MAP_INSERT_OR_EMPLACE (
name, std::string ((char *) value, value_length));
else
zmtp_properties.ZMQ_MAP_INSERT_OR_EMPLACE (
name, std::string ((char *) value, value_length)); name, std::string ((char *) value, value_length));
} }
if (bytes_left > 0) { if (bytes_left > 0) {
...@@ -233,45 +261,67 @@ int zmq::mechanism_t::property (const std::string & /* name_ */, ...@@ -233,45 +261,67 @@ int zmq::mechanism_t::property (const std::string & /* name_ */,
return 0; return 0;
} }
bool zmq::mechanism_t::check_socket_type (const std::string &type_) const template <size_t N>
static bool strequals (const char *actual_type_,
const size_t actual_len_,
const char (&expected_type_)[N])
{
return actual_len_ == N - 1
&& memcmp (actual_type_, expected_type_, N - 1) == 0;
}
bool zmq::mechanism_t::check_socket_type (const char *type_,
const size_t len_) const
{ {
switch (options.type) { switch (options.type) {
case ZMQ_REQ: case ZMQ_REQ:
return type_ == "REP" || type_ == "ROUTER"; return strequals (type_, len_, socket_type_rep)
|| strequals (type_, len_, socket_type_router);
case ZMQ_REP: case ZMQ_REP:
return type_ == "REQ" || type_ == "DEALER"; return strequals (type_, len_, socket_type_req)
|| strequals (type_, len_, socket_type_dealer);
case ZMQ_DEALER: case ZMQ_DEALER:
return type_ == "REP" || type_ == "DEALER" || type_ == "ROUTER"; return strequals (type_, len_, socket_type_rep)
|| strequals (type_, len_, socket_type_dealer)
|| strequals (type_, len_, socket_type_router);
case ZMQ_ROUTER: case ZMQ_ROUTER:
return type_ == "REQ" || type_ == "DEALER" || type_ == "ROUTER"; return strequals (type_, len_, socket_type_req)
|| strequals (type_, len_, socket_type_dealer)
|| strequals (type_, len_, socket_type_router);
case ZMQ_PUSH: case ZMQ_PUSH:
return type_ == "PULL"; return strequals (type_, len_, socket_type_pull);
case ZMQ_PULL: case ZMQ_PULL:
return type_ == "PUSH"; return strequals (type_, len_, socket_type_push);
case ZMQ_PUB: case ZMQ_PUB:
return type_ == "SUB" || type_ == "XSUB"; return strequals (type_, len_, socket_type_sub)
|| strequals (type_, len_, socket_type_xsub);
case ZMQ_SUB: case ZMQ_SUB:
return type_ == "PUB" || type_ == "XPUB"; return strequals (type_, len_, socket_type_pub)
|| strequals (type_, len_, socket_type_xpub);
case ZMQ_XPUB: case ZMQ_XPUB:
return type_ == "SUB" || type_ == "XSUB"; return strequals (type_, len_, socket_type_sub)
|| strequals (type_, len_, socket_type_xsub);
case ZMQ_XSUB: case ZMQ_XSUB:
return type_ == "PUB" || type_ == "XPUB"; return strequals (type_, len_, socket_type_pub)
|| strequals (type_, len_, socket_type_xpub);
case ZMQ_PAIR: case ZMQ_PAIR:
return type_ == "PAIR"; return strequals (type_, len_, socket_type_pair);
#ifdef ZMQ_BUILD_DRAFT_API
case ZMQ_SERVER: case ZMQ_SERVER:
return type_ == "CLIENT"; return strequals (type_, len_, socket_type_client);
case ZMQ_CLIENT: case ZMQ_CLIENT:
return type_ == "SERVER"; return strequals (type_, len_, socket_type_server);
case ZMQ_RADIO: case ZMQ_RADIO:
return type_ == "DISH"; return strequals (type_, len_, socket_type_dish);
case ZMQ_DISH: case ZMQ_DISH:
return type_ == "RADIO"; return strequals (type_, len_, socket_type_radio);
case ZMQ_GATHER: case ZMQ_GATHER:
return type_ == "SCATTER"; return strequals (type_, len_, socket_type_scatter);
case ZMQ_SCATTER: case ZMQ_SCATTER:
return type_ == "GATHER"; return strequals (type_, len_, socket_type_gather);
case ZMQ_DGRAM: case ZMQ_DGRAM:
return type_ == "DGRAM"; return strequals (type_, len_, socket_type_dgram);
#endif
default: default:
break; break;
} }
......
...@@ -137,7 +137,7 @@ class mechanism_t ...@@ -137,7 +137,7 @@ class mechanism_t
// Returns true iff socket associated with the mechanism // Returns true iff socket associated with the mechanism
// is compatible with a given socket type 'type_'. // is compatible with a given socket type 'type_'.
bool check_socket_type (const std::string &type_) const; bool check_socket_type (const char *type_, size_t len_) const;
}; };
} }
......
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