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
f0cf4095
Commit
f0cf4095
authored
Apr 18, 2013
by
Pieter Hintjens
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed issue #525 - multipart upstreaming from xsub to xpub
parent
9df7c70a
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
24 additions
and
18 deletions
+24
-18
xpub.cpp
src/xpub.cpp
+21
-15
xpub.hpp
src/xpub.hpp
+2
-2
xsub.cpp
src/xsub.cpp
+1
-1
No files found.
src/xpub.cpp
View file @
f0cf4095
...
...
@@ -56,9 +56,8 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
// There are some subscriptions waiting. Let's process them.
msg_t
sub
;
while
(
pipe_
->
read
(
&
sub
))
{
// Apply the subscription to the trie.
unsigned
char
*
const
data
=
(
unsigned
char
*
)
sub
.
data
();
// Apply the subscription to the trie
unsigned
char
*
const
data
=
(
unsigned
char
*
)
sub
.
data
();
const
size_t
size
=
sub
.
size
();
if
(
size
>
0
&&
(
*
data
==
0
||
*
data
==
1
))
{
bool
unique
;
...
...
@@ -69,13 +68,16 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
// If the subscription is not a duplicate store it so that it can be
// passed to used on next recv call. (Unsubscribe is not verbose.)
if
(
options
.
type
==
ZMQ_XPUB
&&
(
unique
||
(
*
data
&&
verbose
)))
pending
.
push_back
(
blob_t
(
data
,
size
));
if
(
options
.
type
==
ZMQ_XPUB
&&
(
unique
||
(
*
data
&&
verbose
)))
{
pending_data
.
push_back
(
blob_t
(
data
,
size
));
pending_flags
.
push_back
(
0
);
}
else
}
else
{
// Process user message coming upstream from xsub socket
pending
.
push_back
(
blob_t
(
data
,
size
));
pending_data
.
push_back
(
blob_t
(
data
,
size
));
pending_flags
.
push_back
(
sub
.
flags
());
}
sub
.
close
();
}
}
...
...
@@ -149,24 +151,27 @@ bool zmq::xpub_t::xhas_out ()
int
zmq
::
xpub_t
::
xrecv
(
msg_t
*
msg_
)
{
// If there is at least one
if
(
pending
.
empty
())
{
if
(
pending
_data
.
empty
())
{
errno
=
EAGAIN
;
return
-
1
;
}
int
rc
=
msg_
->
close
();
errno_assert
(
rc
==
0
);
rc
=
msg_
->
init_size
(
pending
.
front
().
size
());
rc
=
msg_
->
init_size
(
pending
_data
.
front
().
size
());
errno_assert
(
rc
==
0
);
memcpy
(
msg_
->
data
(),
pending
.
front
().
data
(),
pending
.
front
().
size
());
pending
.
pop_front
();
memcpy
(
msg_
->
data
(),
pending_data
.
front
().
data
(),
pending_data
.
front
().
size
());
msg_
->
set_flags
(
pending_flags
.
front
());
pending_data
.
pop_front
();
pending_flags
.
pop_front
();
return
0
;
}
bool
zmq
::
xpub_t
::
xhas_in
()
{
return
!
pending
.
empty
();
return
!
pending
_data
.
empty
();
}
void
zmq
::
xpub_t
::
send_unsubscription
(
unsigned
char
*
data_
,
size_t
size_
,
...
...
@@ -180,7 +185,8 @@ void zmq::xpub_t::send_unsubscription (unsigned char *data_, size_t size_,
blob_t
unsub
(
size_
+
1
,
0
);
unsub
[
0
]
=
0
;
memcpy
(
&
unsub
[
1
],
data_
,
size_
);
self
->
pending
.
push_back
(
unsub
);
self
->
pending_data
.
push_back
(
unsub
);
self
->
pending_flags
.
push_back
(
0
);
}
}
...
...
src/xpub.hpp
View file @
f0cf4095
...
...
@@ -82,8 +82,8 @@ namespace zmq
// List of pending (un)subscriptions, ie. those that were already
// applied to the trie, but not yet received by the user.
typedef
std
::
basic_string
<
unsigned
char
>
blob_t
;
typedef
std
::
deque
<
blob_t
>
pending_t
;
pending_t
pending
;
std
::
deque
<
blob_t
>
pending_data
;
std
::
deque
<
unsigned
char
>
pending_flags
;
xpub_t
(
const
xpub_t
&
);
const
xpub_t
&
operator
=
(
const
xpub_t
&
);
...
...
src/xsub.cpp
View file @
f0cf4095
...
...
@@ -83,7 +83,7 @@ void zmq::xsub_t::xhiccuped (pipe_t *pipe_)
int
zmq
::
xsub_t
::
xsend
(
msg_t
*
msg_
)
{
size_t
size
=
msg_
->
size
();
unsigned
char
*
data
=
(
unsigned
char
*
)
msg_
->
data
();
unsigned
char
*
data
=
(
unsigned
char
*
)
msg_
->
data
();
if
(
size
>
0
&&
*
data
==
1
)
{
// Process subscribe message
...
...
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