diff options
| author | Martin Sustrik <sustrik@250bpm.com> | 2010-08-11 14:09:56 +0200 | 
|---|---|---|
| committer | Martin Sustrik <sustrik@250bpm.com> | 2010-08-25 15:39:20 +0200 | 
| commit | d13933bc62fce71b5a58118020e0dd3776e79aa9 (patch) | |
| tree | 6586d5b9cc637dbf8acae4b32d24da9c8e046014 /src/xreq.cpp | |
| parent | ee1f1af0091d9bdffa0e5ce1783da925b3cd7e56 (diff) | |
I/O object hierarchy implemented
Diffstat (limited to 'src/xreq.cpp')
| -rw-r--r-- | src/xreq.cpp | 17 | 
1 files changed, 11 insertions, 6 deletions
| diff --git a/src/xreq.cpp b/src/xreq.cpp index 893c18e..e511660 100644 --- a/src/xreq.cpp +++ b/src/xreq.cpp @@ -23,7 +23,9 @@  #include "err.hpp"  zmq::xreq_t::xreq_t (class ctx_t *parent_, uint32_t slot_) : -    socket_base_t (parent_, slot_) +    socket_base_t (parent_, slot_), +    fq (this), +    lb (this)  {      options.requires_in = true;      options.requires_out = true; @@ -41,15 +43,18 @@ void zmq::xreq_t::xattach_pipes (class reader_t *inpipe_,      lb.attach (outpipe_);  } -void zmq::xreq_t::xterm_pipes () +void zmq::xreq_t::process_term ()  { -    fq.term_pipes (); -    lb.term_pipes (); +    register_term_acks (2); +    fq.terminate (); +    lb.terminate (); + +    socket_base_t::process_term ();  } -bool zmq::xreq_t::xhas_pipes () +void zmq::xreq_t::terminated ()  { -    return fq.has_pipes () || lb.has_pipes (); +    unregister_term_ack ();  }  int zmq::xreq_t::xsend (zmq_msg_t *msg_, int flags_) | 
