Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
c12fedc7
Commit
c12fedc7
authored
Mar 22, 2012
by
Pieter Hintjens
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Completed internal renaming of XREP/XREQ to ROUTER/DEALER
parent
75809b27
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
99 additions
and
99 deletions
+99
-99
dealer.cpp
src/dealer.cpp
+17
-17
dealer.hpp
src/dealer.hpp
+12
-12
rep.cpp
src/rep.cpp
+8
-8
rep.hpp
src/rep.hpp
+3
-3
req.cpp
src/req.cpp
+13
-13
req.hpp
src/req.hpp
+3
-3
router.cpp
src/router.cpp
+19
-19
router.hpp
src/router.hpp
+12
-12
session_base.cpp
src/session_base.cpp
+6
-6
socket_base.cpp
src/socket_base.cpp
+6
-6
No files found.
src/
xreq
.cpp
→
src/
dealer
.cpp
View file @
c12fedc7
...
@@ -19,17 +19,17 @@
...
@@ -19,17 +19,17 @@
along with this program. If not, see <http://www.gnu.org/licenses/>.
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
#include "
xreq
.hpp"
#include "
dealer
.hpp"
#include "err.hpp"
#include "err.hpp"
#include "msg.hpp"
#include "msg.hpp"
zmq
::
xreq_t
::
xreq
_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
zmq
::
dealer_t
::
dealer
_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
socket_base_t
(
parent_
,
tid_
,
sid_
),
socket_base_t
(
parent_
,
tid_
,
sid_
),
prefetched
(
false
)
prefetched
(
false
)
{
{
options
.
type
=
ZMQ_
XREQ
;
options
.
type
=
ZMQ_
DEALER
;
// TODO: Uncomment the following line when
XREQ will become true XREQ
// TODO: Uncomment the following line when
DEALER will become true DEALER
// rather than generic dealer socket.
// rather than generic dealer socket.
// If the socket is closing we can drop all the outbound requests. There'll
// If the socket is closing we can drop all the outbound requests. There'll
// be noone to receive the replies anyway.
// be noone to receive the replies anyway.
...
@@ -41,24 +41,24 @@ zmq::xreq_t::xreq_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
...
@@ -41,24 +41,24 @@ zmq::xreq_t::xreq_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
prefetched_msg
.
init
();
prefetched_msg
.
init
();
}
}
zmq
::
xreq_t
::~
xreq
_t
()
zmq
::
dealer_t
::~
dealer
_t
()
{
{
prefetched_msg
.
close
();
prefetched_msg
.
close
();
}
}
void
zmq
::
xreq
_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
icanhasall_
)
void
zmq
::
dealer
_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
icanhasall_
)
{
{
zmq_assert
(
pipe_
);
zmq_assert
(
pipe_
);
fq
.
attach
(
pipe_
);
fq
.
attach
(
pipe_
);
lb
.
attach
(
pipe_
);
lb
.
attach
(
pipe_
);
}
}
int
zmq
::
xreq
_t
::
xsend
(
msg_t
*
msg_
,
int
flags_
)
int
zmq
::
dealer
_t
::
xsend
(
msg_t
*
msg_
,
int
flags_
)
{
{
return
lb
.
send
(
msg_
,
flags_
);
return
lb
.
send
(
msg_
,
flags_
);
}
}
int
zmq
::
xreq
_t
::
xrecv
(
msg_t
*
msg_
,
int
flags_
)
int
zmq
::
dealer
_t
::
xrecv
(
msg_t
*
msg_
,
int
flags_
)
{
{
// If there is a prefetched message, return it.
// If there is a prefetched message, return it.
if
(
prefetched
)
{
if
(
prefetched
)
{
...
@@ -68,7 +68,7 @@ int zmq::xreq_t::xrecv (msg_t *msg_, int flags_)
...
@@ -68,7 +68,7 @@ int zmq::xreq_t::xrecv (msg_t *msg_, int flags_)
return
0
;
return
0
;
}
}
//
XREQ
socket doesn't use identities. We can safely drop it and
//
DEALER
socket doesn't use identities. We can safely drop it and
while
(
true
)
{
while
(
true
)
{
int
rc
=
fq
.
recv
(
msg_
,
flags_
);
int
rc
=
fq
.
recv
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
...
@@ -79,14 +79,14 @@ int zmq::xreq_t::xrecv (msg_t *msg_, int flags_)
...
@@ -79,14 +79,14 @@ int zmq::xreq_t::xrecv (msg_t *msg_, int flags_)
return
0
;
return
0
;
}
}
bool
zmq
::
xreq
_t
::
xhas_in
()
bool
zmq
::
dealer
_t
::
xhas_in
()
{
{
// We may already have a message pre-fetched.
// We may already have a message pre-fetched.
if
(
prefetched
)
if
(
prefetched
)
return
true
;
return
true
;
// Try to read the next message to the pre-fetch buffer.
// Try to read the next message to the pre-fetch buffer.
int
rc
=
xreq
_t
::
xrecv
(
&
prefetched_msg
,
ZMQ_DONTWAIT
);
int
rc
=
dealer
_t
::
xrecv
(
&
prefetched_msg
,
ZMQ_DONTWAIT
);
if
(
rc
!=
0
&&
errno
==
EAGAIN
)
if
(
rc
!=
0
&&
errno
==
EAGAIN
)
return
false
;
return
false
;
zmq_assert
(
rc
==
0
);
zmq_assert
(
rc
==
0
);
...
@@ -94,35 +94,35 @@ bool zmq::xreq_t::xhas_in ()
...
@@ -94,35 +94,35 @@ bool zmq::xreq_t::xhas_in ()
return
true
;
return
true
;
}
}
bool
zmq
::
xreq
_t
::
xhas_out
()
bool
zmq
::
dealer
_t
::
xhas_out
()
{
{
return
lb
.
has_out
();
return
lb
.
has_out
();
}
}
void
zmq
::
xreq
_t
::
xread_activated
(
pipe_t
*
pipe_
)
void
zmq
::
dealer
_t
::
xread_activated
(
pipe_t
*
pipe_
)
{
{
fq
.
activated
(
pipe_
);
fq
.
activated
(
pipe_
);
}
}
void
zmq
::
xreq
_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
void
zmq
::
dealer
_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
{
{
lb
.
activated
(
pipe_
);
lb
.
activated
(
pipe_
);
}
}
void
zmq
::
xreq
_t
::
xterminated
(
pipe_t
*
pipe_
)
void
zmq
::
dealer
_t
::
xterminated
(
pipe_t
*
pipe_
)
{
{
fq
.
terminated
(
pipe_
);
fq
.
terminated
(
pipe_
);
lb
.
terminated
(
pipe_
);
lb
.
terminated
(
pipe_
);
}
}
zmq
::
xreq_session_t
::
xreq
_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
zmq
::
dealer_session_t
::
dealer
_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
)
:
const
address_t
*
addr_
)
:
session_base_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
session_base_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
{
{
}
}
zmq
::
xreq_session_t
::~
xreq
_session_t
()
zmq
::
dealer_session_t
::~
dealer
_session_t
()
{
{
}
}
src/
xreq
.hpp
→
src/
dealer
.hpp
View file @
c12fedc7
...
@@ -18,8 +18,8 @@
...
@@ -18,8 +18,8 @@
along with this program. If not, see <http://www.gnu.org/licenses/>.
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
#ifndef __ZMQ_
XREQ
_HPP_INCLUDED__
#ifndef __ZMQ_
DEALER
_HPP_INCLUDED__
#define __ZMQ_
XREQ
_HPP_INCLUDED__
#define __ZMQ_
DEALER
_HPP_INCLUDED__
#include "socket_base.hpp"
#include "socket_base.hpp"
#include "session_base.hpp"
#include "session_base.hpp"
...
@@ -35,13 +35,13 @@ namespace zmq
...
@@ -35,13 +35,13 @@ namespace zmq
class
io_thread_t
;
class
io_thread_t
;
class
socket_base_t
;
class
socket_base_t
;
class
xreq
_t
:
class
dealer
_t
:
public
socket_base_t
public
socket_base_t
{
{
public
:
public
:
xreq
_t
(
zmq
::
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid
);
dealer
_t
(
zmq
::
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid
);
~
xreq
_t
();
~
dealer
_t
();
protected
:
protected
:
...
@@ -68,23 +68,23 @@ namespace zmq
...
@@ -68,23 +68,23 @@ namespace zmq
// Holds the prefetched message.
// Holds the prefetched message.
msg_t
prefetched_msg
;
msg_t
prefetched_msg
;
xreq_t
(
const
xreq
_t
&
);
dealer_t
(
const
dealer
_t
&
);
const
xreq_t
&
operator
=
(
const
xreq
_t
&
);
const
dealer_t
&
operator
=
(
const
dealer
_t
&
);
};
};
class
xreq
_session_t
:
public
session_base_t
class
dealer
_session_t
:
public
session_base_t
{
{
public
:
public
:
xreq
_session_t
(
zmq
::
io_thread_t
*
io_thread_
,
bool
connect_
,
dealer
_session_t
(
zmq
::
io_thread_t
*
io_thread_
,
bool
connect_
,
zmq
::
socket_base_t
*
socket_
,
const
options_t
&
options_
,
zmq
::
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
);
const
address_t
*
addr_
);
~
xreq
_session_t
();
~
dealer
_session_t
();
private
:
private
:
xreq_session_t
(
const
xreq
_session_t
&
);
dealer_session_t
(
const
dealer
_session_t
&
);
const
xreq_session_t
&
operator
=
(
const
xreq
_session_t
&
);
const
dealer_session_t
&
operator
=
(
const
dealer
_session_t
&
);
};
};
}
}
...
...
src/rep.cpp
View file @
c12fedc7
...
@@ -24,7 +24,7 @@
...
@@ -24,7 +24,7 @@
#include "msg.hpp"
#include "msg.hpp"
zmq
::
rep_t
::
rep_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
zmq
::
rep_t
::
rep_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
xrep
_t
(
parent_
,
tid_
,
sid_
),
router
_t
(
parent_
,
tid_
,
sid_
),
sending_reply
(
false
),
sending_reply
(
false
),
request_begins
(
true
)
request_begins
(
true
)
{
{
...
@@ -46,7 +46,7 @@ int zmq::rep_t::xsend (msg_t *msg_, int flags_)
...
@@ -46,7 +46,7 @@ int zmq::rep_t::xsend (msg_t *msg_, int flags_)
bool
more
=
msg_
->
flags
()
&
msg_t
::
more
?
true
:
false
;
bool
more
=
msg_
->
flags
()
&
msg_t
::
more
?
true
:
false
;
// Push message to the reply pipe.
// Push message to the reply pipe.
int
rc
=
xrep
_t
::
xsend
(
msg_
,
flags_
);
int
rc
=
router
_t
::
xsend
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
...
@@ -69,12 +69,12 @@ int zmq::rep_t::xrecv (msg_t *msg_, int flags_)
...
@@ -69,12 +69,12 @@ int zmq::rep_t::xrecv (msg_t *msg_, int flags_)
// to the reply pipe.
// to the reply pipe.
if
(
request_begins
)
{
if
(
request_begins
)
{
while
(
true
)
{
while
(
true
)
{
int
rc
=
xrep
_t
::
xrecv
(
msg_
,
flags_
);
int
rc
=
router
_t
::
xrecv
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
zmq_assert
(
msg_
->
flags
()
&
msg_t
::
more
);
zmq_assert
(
msg_
->
flags
()
&
msg_t
::
more
);
bool
bottom
=
(
msg_
->
size
()
==
0
);
bool
bottom
=
(
msg_
->
size
()
==
0
);
rc
=
xrep
_t
::
xsend
(
msg_
,
flags_
);
rc
=
router
_t
::
xsend
(
msg_
,
flags_
);
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
if
(
bottom
)
if
(
bottom
)
break
;
break
;
...
@@ -83,7 +83,7 @@ int zmq::rep_t::xrecv (msg_t *msg_, int flags_)
...
@@ -83,7 +83,7 @@ int zmq::rep_t::xrecv (msg_t *msg_, int flags_)
}
}
// Get next message part to return to the user.
// Get next message part to return to the user.
int
rc
=
xrep
_t
::
xrecv
(
msg_
,
flags_
);
int
rc
=
router
_t
::
xrecv
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
...
@@ -101,7 +101,7 @@ bool zmq::rep_t::xhas_in ()
...
@@ -101,7 +101,7 @@ bool zmq::rep_t::xhas_in ()
if
(
sending_reply
)
if
(
sending_reply
)
return
false
;
return
false
;
return
xrep
_t
::
xhas_in
();
return
router
_t
::
xhas_in
();
}
}
bool
zmq
::
rep_t
::
xhas_out
()
bool
zmq
::
rep_t
::
xhas_out
()
...
@@ -109,13 +109,13 @@ bool zmq::rep_t::xhas_out ()
...
@@ -109,13 +109,13 @@ bool zmq::rep_t::xhas_out ()
if
(
!
sending_reply
)
if
(
!
sending_reply
)
return
false
;
return
false
;
return
xrep
_t
::
xhas_out
();
return
router
_t
::
xhas_out
();
}
}
zmq
::
rep_session_t
::
rep_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
zmq
::
rep_session_t
::
rep_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
)
:
const
address_t
*
addr_
)
:
xrep
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
router
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
{
{
}
}
...
...
src/rep.hpp
View file @
c12fedc7
...
@@ -22,7 +22,7 @@
...
@@ -22,7 +22,7 @@
#ifndef __ZMQ_REP_HPP_INCLUDED__
#ifndef __ZMQ_REP_HPP_INCLUDED__
#define __ZMQ_REP_HPP_INCLUDED__
#define __ZMQ_REP_HPP_INCLUDED__
#include "
xrep
.hpp"
#include "
router
.hpp"
namespace
zmq
namespace
zmq
{
{
...
@@ -32,7 +32,7 @@ namespace zmq
...
@@ -32,7 +32,7 @@ namespace zmq
class
io_thread_t
;
class
io_thread_t
;
class
socket_base_t
;
class
socket_base_t
;
class
rep_t
:
public
xrep
_t
class
rep_t
:
public
router
_t
{
{
public
:
public
:
...
@@ -60,7 +60,7 @@ namespace zmq
...
@@ -60,7 +60,7 @@ namespace zmq
};
};
class
rep_session_t
:
public
xrep
_session_t
class
rep_session_t
:
public
router
_session_t
{
{
public
:
public
:
...
...
src/req.cpp
View file @
c12fedc7
...
@@ -28,7 +28,7 @@
...
@@ -28,7 +28,7 @@
#include "likely.hpp"
#include "likely.hpp"
zmq
::
req_t
::
req_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
zmq
::
req_t
::
req_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
xreq
_t
(
parent_
,
tid_
,
sid_
),
dealer
_t
(
parent_
,
tid_
,
sid_
),
receiving_reply
(
false
),
receiving_reply
(
false
),
message_begins
(
true
)
message_begins
(
true
)
{
{
...
@@ -54,7 +54,7 @@ int zmq::req_t::xsend (msg_t *msg_, int flags_)
...
@@ -54,7 +54,7 @@ int zmq::req_t::xsend (msg_t *msg_, int flags_)
int
rc
=
bottom
.
init
();
int
rc
=
bottom
.
init
();
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
bottom
.
set_flags
(
msg_t
::
more
);
bottom
.
set_flags
(
msg_t
::
more
);
rc
=
xreq
_t
::
xsend
(
&
bottom
,
0
);
rc
=
dealer
_t
::
xsend
(
&
bottom
,
0
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
-
1
;
return
-
1
;
message_begins
=
false
;
message_begins
=
false
;
...
@@ -62,7 +62,7 @@ int zmq::req_t::xsend (msg_t *msg_, int flags_)
...
@@ -62,7 +62,7 @@ int zmq::req_t::xsend (msg_t *msg_, int flags_)
bool
more
=
msg_
->
flags
()
&
msg_t
::
more
?
true
:
false
;
bool
more
=
msg_
->
flags
()
&
msg_t
::
more
?
true
:
false
;
int
rc
=
xreq
_t
::
xsend
(
msg_
,
flags_
);
int
rc
=
dealer
_t
::
xsend
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
...
@@ -85,14 +85,14 @@ int zmq::req_t::xrecv (msg_t *msg_, int flags_)
...
@@ -85,14 +85,14 @@ int zmq::req_t::xrecv (msg_t *msg_, int flags_)
// First part of the reply should be the original request ID.
// First part of the reply should be the original request ID.
if
(
message_begins
)
{
if
(
message_begins
)
{
int
rc
=
xreq
_t
::
xrecv
(
msg_
,
flags_
);
int
rc
=
dealer
_t
::
xrecv
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
// TODO: This should also close the connection with the peer!
// TODO: This should also close the connection with the peer!
if
(
unlikely
(
!
(
msg_
->
flags
()
&
msg_t
::
more
)
||
msg_
->
size
()
!=
0
))
{
if
(
unlikely
(
!
(
msg_
->
flags
()
&
msg_t
::
more
)
||
msg_
->
size
()
!=
0
))
{
while
(
true
)
{
while
(
true
)
{
int
rc
=
xreq
_t
::
xrecv
(
msg_
,
flags_
);
int
rc
=
dealer
_t
::
xrecv
(
msg_
,
flags_
);
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
if
(
!
(
msg_
->
flags
()
&
msg_t
::
more
))
if
(
!
(
msg_
->
flags
()
&
msg_t
::
more
))
break
;
break
;
...
@@ -106,7 +106,7 @@ int zmq::req_t::xrecv (msg_t *msg_, int flags_)
...
@@ -106,7 +106,7 @@ int zmq::req_t::xrecv (msg_t *msg_, int flags_)
message_begins
=
false
;
message_begins
=
false
;
}
}
int
rc
=
xreq
_t
::
xrecv
(
msg_
,
flags_
);
int
rc
=
dealer
_t
::
xrecv
(
msg_
,
flags_
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
rc
;
return
rc
;
...
@@ -126,7 +126,7 @@ bool zmq::req_t::xhas_in ()
...
@@ -126,7 +126,7 @@ bool zmq::req_t::xhas_in ()
if
(
!
receiving_reply
)
if
(
!
receiving_reply
)
return
false
;
return
false
;
return
xreq
_t
::
xhas_in
();
return
dealer
_t
::
xhas_in
();
}
}
bool
zmq
::
req_t
::
xhas_out
()
bool
zmq
::
req_t
::
xhas_out
()
...
@@ -134,13 +134,13 @@ bool zmq::req_t::xhas_out ()
...
@@ -134,13 +134,13 @@ bool zmq::req_t::xhas_out ()
if
(
receiving_reply
)
if
(
receiving_reply
)
return
false
;
return
false
;
return
xreq
_t
::
xhas_out
();
return
dealer
_t
::
xhas_out
();
}
}
zmq
::
req_session_t
::
req_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
zmq
::
req_session_t
::
req_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
)
:
const
address_t
*
addr_
)
:
xreq
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
),
dealer
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
),
state
(
identity
)
state
(
identity
)
{
{
}
}
...
@@ -156,21 +156,21 @@ int zmq::req_session_t::write (msg_t *msg_)
...
@@ -156,21 +156,21 @@ int zmq::req_session_t::write (msg_t *msg_)
case
bottom
:
case
bottom
:
if
(
msg_
->
flags
()
==
msg_t
::
more
&&
msg_
->
size
()
==
0
)
{
if
(
msg_
->
flags
()
==
msg_t
::
more
&&
msg_
->
size
()
==
0
)
{
state
=
body
;
state
=
body
;
return
xreq
_session_t
::
write
(
msg_
);
return
dealer
_session_t
::
write
(
msg_
);
}
}
break
;
break
;
case
body
:
case
body
:
if
(
msg_
->
flags
()
==
msg_t
::
more
)
if
(
msg_
->
flags
()
==
msg_t
::
more
)
return
xreq
_session_t
::
write
(
msg_
);
return
dealer
_session_t
::
write
(
msg_
);
if
(
msg_
->
flags
()
==
0
)
{
if
(
msg_
->
flags
()
==
0
)
{
state
=
bottom
;
state
=
bottom
;
return
xreq
_session_t
::
write
(
msg_
);
return
dealer
_session_t
::
write
(
msg_
);
}
}
break
;
break
;
case
identity
:
case
identity
:
if
(
msg_
->
flags
()
==
0
)
{
if
(
msg_
->
flags
()
==
0
)
{
state
=
bottom
;
state
=
bottom
;
return
xreq
_session_t
::
write
(
msg_
);
return
dealer
_session_t
::
write
(
msg_
);
}
}
break
;
break
;
}
}
...
...
src/req.hpp
View file @
c12fedc7
...
@@ -23,7 +23,7 @@
...
@@ -23,7 +23,7 @@
#ifndef __ZMQ_REQ_HPP_INCLUDED__
#ifndef __ZMQ_REQ_HPP_INCLUDED__
#define __ZMQ_REQ_HPP_INCLUDED__
#define __ZMQ_REQ_HPP_INCLUDED__
#include "
xreq
.hpp"
#include "
dealer
.hpp"
#include "stdint.hpp"
#include "stdint.hpp"
namespace
zmq
namespace
zmq
...
@@ -34,7 +34,7 @@ namespace zmq
...
@@ -34,7 +34,7 @@ namespace zmq
class
io_thread_t
;
class
io_thread_t
;
class
socket_base_t
;
class
socket_base_t
;
class
req_t
:
public
xreq
_t
class
req_t
:
public
dealer
_t
{
{
public
:
public
:
...
@@ -61,7 +61,7 @@ namespace zmq
...
@@ -61,7 +61,7 @@ namespace zmq
const
req_t
&
operator
=
(
const
req_t
&
);
const
req_t
&
operator
=
(
const
req_t
&
);
};
};
class
req_session_t
:
public
xreq
_session_t
class
req_session_t
:
public
dealer
_session_t
{
{
public
:
public
:
...
...
src/
xrep
.cpp
→
src/
router
.cpp
View file @
c12fedc7
...
@@ -20,14 +20,14 @@
...
@@ -20,14 +20,14 @@
along with this program. If not, see <http://www.gnu.org/licenses/>.
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
#include "
xrep
.hpp"
#include "
router
.hpp"
#include "pipe.hpp"
#include "pipe.hpp"
#include "wire.hpp"
#include "wire.hpp"
#include "random.hpp"
#include "random.hpp"
#include "likely.hpp"
#include "likely.hpp"
#include "err.hpp"
#include "err.hpp"
zmq
::
xrep_t
::
xrep
_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
zmq
::
router_t
::
router
_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
socket_base_t
(
parent_
,
tid_
,
sid_
),
socket_base_t
(
parent_
,
tid_
,
sid_
),
prefetched
(
0
),
prefetched
(
0
),
more_in
(
false
),
more_in
(
false
),
...
@@ -36,9 +36,9 @@ zmq::xrep_t::xrep_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
...
@@ -36,9 +36,9 @@ zmq::xrep_t::xrep_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
next_peer_id
(
generate_random
()),
next_peer_id
(
generate_random
()),
fail_unroutable
(
false
)
fail_unroutable
(
false
)
{
{
options
.
type
=
ZMQ_
XREP
;
options
.
type
=
ZMQ_
ROUTER
;
// TODO: Uncomment the following line when
XREP will become true XREP
// TODO: Uncomment the following line when
ROUTER will become true ROUTER
// rather than generic router socket.
// rather than generic router socket.
// If peer disconnect there's noone to send reply to anyway. We can drop
// If peer disconnect there's noone to send reply to anyway. We can drop
// all the outstanding requests from that peer.
// all the outstanding requests from that peer.
...
@@ -50,13 +50,13 @@ zmq::xrep_t::xrep_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
...
@@ -50,13 +50,13 @@ zmq::xrep_t::xrep_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
prefetched_msg
.
init
();
prefetched_msg
.
init
();
}
}
zmq
::
xrep_t
::~
xrep
_t
()
zmq
::
router_t
::~
router
_t
()
{
{
zmq_assert
(
outpipes
.
empty
());
zmq_assert
(
outpipes
.
empty
());
prefetched_msg
.
close
();
prefetched_msg
.
close
();
}
}
void
zmq
::
xrep
_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
icanhasall_
)
void
zmq
::
router
_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
icanhasall_
)
{
{
zmq_assert
(
pipe_
);
zmq_assert
(
pipe_
);
...
@@ -78,7 +78,7 @@ void zmq::xrep_t::xattach_pipe (pipe_t *pipe_, bool icanhasall_)
...
@@ -78,7 +78,7 @@ void zmq::xrep_t::xattach_pipe (pipe_t *pipe_, bool icanhasall_)
fq
.
attach
(
pipe_
);
fq
.
attach
(
pipe_
);
}
}
int
zmq
::
xrep
_t
::
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
int
zmq
::
router
_t
::
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
size_t
optvallen_
)
size_t
optvallen_
)
{
{
if
(
option_
!=
ZMQ_FAIL_UNROUTABLE
)
{
if
(
option_
!=
ZMQ_FAIL_UNROUTABLE
)
{
...
@@ -93,7 +93,7 @@ int zmq::xrep_t::xsetsockopt (int option_, const void *optval_,
...
@@ -93,7 +93,7 @@ int zmq::xrep_t::xsetsockopt (int option_, const void *optval_,
return
0
;
return
0
;
}
}
void
zmq
::
xrep
_t
::
xterminated
(
pipe_t
*
pipe_
)
void
zmq
::
router
_t
::
xterminated
(
pipe_t
*
pipe_
)
{
{
fq
.
terminated
(
pipe_
);
fq
.
terminated
(
pipe_
);
...
@@ -109,12 +109,12 @@ void zmq::xrep_t::xterminated (pipe_t *pipe_)
...
@@ -109,12 +109,12 @@ void zmq::xrep_t::xterminated (pipe_t *pipe_)
zmq_assert
(
false
);
zmq_assert
(
false
);
}
}
void
zmq
::
xrep
_t
::
xread_activated
(
pipe_t
*
pipe_
)
void
zmq
::
router
_t
::
xread_activated
(
pipe_t
*
pipe_
)
{
{
fq
.
activated
(
pipe_
);
fq
.
activated
(
pipe_
);
}
}
void
zmq
::
xrep
_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
void
zmq
::
router
_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
{
{
for
(
outpipes_t
::
iterator
it
=
outpipes
.
begin
();
for
(
outpipes_t
::
iterator
it
=
outpipes
.
begin
();
it
!=
outpipes
.
end
();
++
it
)
{
it
!=
outpipes
.
end
();
++
it
)
{
...
@@ -127,7 +127,7 @@ void zmq::xrep_t::xwrite_activated (pipe_t *pipe_)
...
@@ -127,7 +127,7 @@ void zmq::xrep_t::xwrite_activated (pipe_t *pipe_)
zmq_assert
(
false
);
zmq_assert
(
false
);
}
}
int
zmq
::
xrep
_t
::
xsend
(
msg_t
*
msg_
,
int
flags_
)
int
zmq
::
router
_t
::
xsend
(
msg_t
*
msg_
,
int
flags_
)
{
{
// If this is the first part of the message it's the ID of the
// If this is the first part of the message it's the ID of the
// peer to send the message to.
// peer to send the message to.
...
@@ -200,7 +200,7 @@ int zmq::xrep_t::xsend (msg_t *msg_, int flags_)
...
@@ -200,7 +200,7 @@ int zmq::xrep_t::xsend (msg_t *msg_, int flags_)
return
0
;
return
0
;
}
}
int
zmq
::
xrep
_t
::
xrecv
(
msg_t
*
msg_
,
int
flags_
)
int
zmq
::
router
_t
::
xrecv
(
msg_t
*
msg_
,
int
flags_
)
{
{
// if there is a prefetched identity, return it.
// if there is a prefetched identity, return it.
if
(
prefetched
==
2
)
if
(
prefetched
==
2
)
...
@@ -280,7 +280,7 @@ int zmq::xrep_t::xrecv (msg_t *msg_, int flags_)
...
@@ -280,7 +280,7 @@ int zmq::xrep_t::xrecv (msg_t *msg_, int flags_)
return
0
;
return
0
;
}
}
int
zmq
::
xrep
_t
::
rollback
(
void
)
int
zmq
::
router
_t
::
rollback
(
void
)
{
{
if
(
current_out
)
{
if
(
current_out
)
{
current_out
->
rollback
();
current_out
->
rollback
();
...
@@ -290,7 +290,7 @@ int zmq::xrep_t::rollback (void)
...
@@ -290,7 +290,7 @@ int zmq::xrep_t::rollback (void)
return
0
;
return
0
;
}
}
bool
zmq
::
xrep
_t
::
xhas_in
()
bool
zmq
::
router
_t
::
xhas_in
()
{
{
// If we are in the middle of reading the messages, there are
// If we are in the middle of reading the messages, there are
// definitely more parts available.
// definitely more parts available.
...
@@ -305,7 +305,7 @@ bool zmq::xrep_t::xhas_in ()
...
@@ -305,7 +305,7 @@ bool zmq::xrep_t::xhas_in ()
// it will be identity of the peer sending the message.
// it will be identity of the peer sending the message.
msg_t
id
;
msg_t
id
;
id
.
init
();
id
.
init
();
int
rc
=
xrep
_t
::
xrecv
(
&
id
,
ZMQ_DONTWAIT
);
int
rc
=
router
_t
::
xrecv
(
&
id
,
ZMQ_DONTWAIT
);
if
(
rc
!=
0
&&
errno
==
EAGAIN
)
{
if
(
rc
!=
0
&&
errno
==
EAGAIN
)
{
id
.
close
();
id
.
close
();
return
false
;
return
false
;
...
@@ -321,22 +321,22 @@ bool zmq::xrep_t::xhas_in ()
...
@@ -321,22 +321,22 @@ bool zmq::xrep_t::xhas_in ()
return
true
;
return
true
;
}
}
bool
zmq
::
xrep
_t
::
xhas_out
()
bool
zmq
::
router
_t
::
xhas_out
()
{
{
// In theory,
XREP
socket is always ready for writing. Whether actual
// In theory,
ROUTER
socket is always ready for writing. Whether actual
// attempt to write succeeds depends on whitch pipe the message is going
// attempt to write succeeds depends on whitch pipe the message is going
// to be routed to.
// to be routed to.
return
true
;
return
true
;
}
}
zmq
::
xrep_session_t
::
xrep
_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
zmq
::
router_session_t
::
router
_session_t
(
io_thread_t
*
io_thread_
,
bool
connect_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
)
:
const
address_t
*
addr_
)
:
session_base_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
session_base_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
)
{
{
}
}
zmq
::
xrep_session_t
::~
xrep
_session_t
()
zmq
::
router_session_t
::~
router
_session_t
()
{
{
}
}
src/
xrep
.hpp
→
src/
router
.hpp
View file @
c12fedc7
...
@@ -20,8 +20,8 @@
...
@@ -20,8 +20,8 @@
along with this program. If not, see <http://www.gnu.org/licenses/>.
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
#ifndef __ZMQ_
XREP
_HPP_INCLUDED__
#ifndef __ZMQ_
ROUTER
_HPP_INCLUDED__
#define __ZMQ_
XREP
_HPP_INCLUDED__
#define __ZMQ_
ROUTER
_HPP_INCLUDED__
#include <map>
#include <map>
...
@@ -39,13 +39,13 @@ namespace zmq
...
@@ -39,13 +39,13 @@ namespace zmq
class
pipe_t
;
class
pipe_t
;
// TODO: This class uses O(n) scheduling. Rewrite it to use O(1) algorithm.
// TODO: This class uses O(n) scheduling. Rewrite it to use O(1) algorithm.
class
xrep
_t
:
class
router
_t
:
public
socket_base_t
public
socket_base_t
{
{
public
:
public
:
xrep
_t
(
zmq
::
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid
);
router
_t
(
zmq
::
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid
);
~
xrep
_t
();
~
router
_t
();
// Overloads of functions from socket_base_t.
// Overloads of functions from socket_base_t.
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
...
@@ -104,23 +104,23 @@ namespace zmq
...
@@ -104,23 +104,23 @@ namespace zmq
// If true, fail on unroutable messages instead of silently dropping them.
// If true, fail on unroutable messages instead of silently dropping them.
bool
fail_unroutable
;
bool
fail_unroutable
;
xrep_t
(
const
xrep
_t
&
);
router_t
(
const
router
_t
&
);
const
xrep_t
&
operator
=
(
const
xrep
_t
&
);
const
router_t
&
operator
=
(
const
router
_t
&
);
};
};
class
xrep
_session_t
:
public
session_base_t
class
router
_session_t
:
public
session_base_t
{
{
public
:
public
:
xrep
_session_t
(
zmq
::
io_thread_t
*
io_thread_
,
bool
connect_
,
router
_session_t
(
zmq
::
io_thread_t
*
io_thread_
,
bool
connect_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
socket_base_t
*
socket_
,
const
options_t
&
options_
,
const
address_t
*
addr_
);
const
address_t
*
addr_
);
~
xrep
_session_t
();
~
router
_session_t
();
private
:
private
:
xrep_session_t
(
const
xrep
_session_t
&
);
router_session_t
(
const
router
_session_t
&
);
const
xrep_session_t
&
operator
=
(
const
xrep
_session_t
&
);
const
router_session_t
&
operator
=
(
const
router
_session_t
&
);
};
};
}
}
...
...
src/session_base.cpp
View file @
c12fedc7
...
@@ -33,9 +33,9 @@
...
@@ -33,9 +33,9 @@
#include "address.hpp"
#include "address.hpp"
#include "req.hpp"
#include "req.hpp"
#include "
xreq
.hpp"
#include "
dealer
.hpp"
#include "rep.hpp"
#include "rep.hpp"
#include "
xrep
.hpp"
#include "
router
.hpp"
#include "pub.hpp"
#include "pub.hpp"
#include "xpub.hpp"
#include "xpub.hpp"
#include "sub.hpp"
#include "sub.hpp"
...
@@ -54,15 +54,15 @@ zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_,
...
@@ -54,15 +54,15 @@ zmq::session_base_t *zmq::session_base_t::create (class io_thread_t *io_thread_,
s
=
new
(
std
::
nothrow
)
req_session_t
(
io_thread_
,
connect_
,
s
=
new
(
std
::
nothrow
)
req_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
);
socket_
,
options_
,
addr_
);
break
;
break
;
case
ZMQ_
XREQ
:
case
ZMQ_
DEALER
:
s
=
new
(
std
::
nothrow
)
xreq
_session_t
(
io_thread_
,
connect_
,
s
=
new
(
std
::
nothrow
)
dealer
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
);
socket_
,
options_
,
addr_
);
case
ZMQ_REP
:
case
ZMQ_REP
:
s
=
new
(
std
::
nothrow
)
rep_session_t
(
io_thread_
,
connect_
,
s
=
new
(
std
::
nothrow
)
rep_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
);
socket_
,
options_
,
addr_
);
break
;
break
;
case
ZMQ_
XREP
:
case
ZMQ_
ROUTER
:
s
=
new
(
std
::
nothrow
)
xrep
_session_t
(
io_thread_
,
connect_
,
s
=
new
(
std
::
nothrow
)
router
_session_t
(
io_thread_
,
connect_
,
socket_
,
options_
,
addr_
);
socket_
,
options_
,
addr_
);
break
;
break
;
case
ZMQ_PUB
:
case
ZMQ_PUB
:
...
...
src/socket_base.cpp
View file @
c12fedc7
...
@@ -64,8 +64,8 @@
...
@@ -64,8 +64,8 @@
#include "rep.hpp"
#include "rep.hpp"
#include "pull.hpp"
#include "pull.hpp"
#include "push.hpp"
#include "push.hpp"
#include "
xreq
.hpp"
#include "
dealer
.hpp"
#include "
xrep
.hpp"
#include "
router
.hpp"
#include "xpub.hpp"
#include "xpub.hpp"
#include "xsub.hpp"
#include "xsub.hpp"
...
@@ -95,11 +95,11 @@ zmq::socket_base_t *zmq::socket_base_t::create (int type_, class ctx_t *parent_,
...
@@ -95,11 +95,11 @@ zmq::socket_base_t *zmq::socket_base_t::create (int type_, class ctx_t *parent_,
case
ZMQ_REP
:
case
ZMQ_REP
:
s
=
new
(
std
::
nothrow
)
rep_t
(
parent_
,
tid_
,
sid_
);
s
=
new
(
std
::
nothrow
)
rep_t
(
parent_
,
tid_
,
sid_
);
break
;
break
;
case
ZMQ_
XREQ
:
case
ZMQ_
DEALER
:
s
=
new
(
std
::
nothrow
)
xreq
_t
(
parent_
,
tid_
,
sid_
);
s
=
new
(
std
::
nothrow
)
dealer
_t
(
parent_
,
tid_
,
sid_
);
break
;
break
;
case
ZMQ_
XREP
:
case
ZMQ_
ROUTER
:
s
=
new
(
std
::
nothrow
)
xrep
_t
(
parent_
,
tid_
,
sid_
);
s
=
new
(
std
::
nothrow
)
router
_t
(
parent_
,
tid_
,
sid_
);
break
;
break
;
case
ZMQ_PULL
:
case
ZMQ_PULL
:
s
=
new
(
std
::
nothrow
)
pull_t
(
parent_
,
tid_
,
sid_
);
s
=
new
(
std
::
nothrow
)
pull_t
(
parent_
,
tid_
,
sid_
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment