Merge pull request #1158 from hurtonm/master

Code cleanup
This commit is contained in:
Pieter Hintjens 2014-08-12 12:32:24 +02:00
commit acc4fe8794
6 changed files with 17 additions and 46 deletions

View File

@ -196,21 +196,11 @@ bool zmq::dist_t::write (pipe_t *pipe_, msg_t *msg_)
bool zmq::dist_t::check_hwm ()
{
// If there are no matching pipes available, there is nothing to write.
bool pipes_hwm_ok = true;
for (pipes_t::size_type i = 0; i < matching; ++i)
if (!pipes [i]->check_hwm ())
return false;
if (matching == 0) {
return true;
}
for (pipes_t::size_type i = 0; i < matching; ++i) {
if( !pipes [i] -> check_hwm()) {
pipes_hwm_ok = false;
break;
}
}
return pipes_hwm_ok;
return true;
}

View File

@ -458,12 +458,6 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
return 0;
}
break;
case ZMQ_XPUB_NODROP:
{
pub_nodrop = true;
return 0;
}
break;
default:
#if defined (ZMQ_ACT_MILITANT)
@ -811,12 +805,6 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_)
}
break;
case ZMQ_XPUB_NODROP:
if( is_int) {
*value = pub_nodrop;
return 0;
}
break;
default:
#if defined (ZMQ_ACT_MILITANT)
malformed = false;

View File

@ -179,9 +179,6 @@ namespace zmq
// close socket. Default is 30 secs. 0 means no handshake timeout.
int handshake_ivl;
// flag if PUB socket should not drop messages if reaching HWM
bool pub_nodrop;
};
}

View File

@ -501,7 +501,7 @@ void zmq::pipe_t::set_hwms (int inhwm_, int outhwm_)
hwm = outhwm_;
}
bool zmq::pipe_t::check_hwm ()
bool zmq::pipe_t::check_hwm () const
{
bool full = hwm > 0 && msgs_written - peers_msgs_read >= uint64_t (hwm - 1);
return( !full );

View File

@ -119,7 +119,7 @@ namespace zmq
void set_hwms (int inhwm_, int outhwm_);
// check HWM
bool check_hwm ();
bool check_hwm () const;
// provide a way to link pipe to engine fd. Set on session initialization
fd_t assoc_fd; //=retired_fd
private:

View File

@ -98,14 +98,10 @@ int zmq::xpub_t::xsetsockopt (int option_, const void *optval_,
errno = EINVAL;
return -1;
}
if (option_ == ZMQ_XPUB_VERBOSE) {
if (option_ == ZMQ_XPUB_VERBOSE)
verbose = (*static_cast <const int*> (optval_) != 0);
} else if (option_ == ZMQ_XPUB_NODROP) {
else
nodrop = (*static_cast <const int*> (optval_) != 0);
}
else {
return -1;
}
return 0;
}
@ -135,11 +131,11 @@ int zmq::xpub_t::xsend (msg_t *msg_)
subscriptions.match ((unsigned char*) msg_->data (), msg_->size (),
mark_as_matching, this);
if (nodrop && !dist.check_hwm()) {
return EAGAIN;
if (nodrop && !dist.check_hwm ()) {
errno = EAGAIN;
return -1;
}
// Send the message to all the pipes that were marked as matching
// in the previous step.
int rc = dist.send_to_matching (msg_);