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
76602516
Unverified
Commit
76602516
authored
Aug 09, 2018
by
Luca Boccassi
Committed by
GitHub
Aug 09, 2018
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3205 from sigiesec/code-improvements
Code style improvements
parents
05e400a3
be81dcd4
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
169 additions
and
105 deletions
+169
-105
ctx.cpp
src/ctx.cpp
+5
-4
dish.cpp
src/dish.cpp
+4
-7
epoll.cpp
src/epoll.cpp
+4
-4
generic_mtrie.hpp
src/generic_mtrie.hpp
+11
-0
generic_mtrie_impl.hpp
src/generic_mtrie_impl.hpp
+53
-32
mailbox_safe.cpp
src/mailbox_safe.cpp
+7
-4
mechanism.cpp
src/mechanism.cpp
+9
-6
own.cpp
src/own.cpp
+2
-1
pgm_receiver.cpp
src/pgm_receiver.cpp
+2
-1
pipe.cpp
src/pipe.cpp
+2
-2
poller_base.cpp
src/poller_base.cpp
+2
-1
radio.cpp
src/radio.cpp
+12
-7
router.cpp
src/router.cpp
+1
-1
server.cpp
src/server.cpp
+2
-1
socket_base.cpp
src/socket_base.cpp
+9
-11
socket_poller.cpp
src/socket_poller.cpp
+30
-19
stream_engine.cpp
src/stream_engine.cpp
+0
-0
stream_engine.hpp
src/stream_engine.hpp
+13
-3
timers.cpp
src/timers.cpp
+1
-1
No files found.
src/ctx.cpp
View file @
76602516
...
...
@@ -137,8 +137,8 @@ int zmq::ctx_t::terminate ()
// Connect up any pending inproc connections, otherwise we will hang
pending_connections_t
copy
=
_pending_connections
;
for
(
pending_connections_t
::
iterator
p
=
copy
.
begin
()
;
p
!
=
copy
.
end
();
++
p
)
{
for
(
pending_connections_t
::
iterator
p
=
copy
.
begin
()
,
end
=
copy
.
end
();
p
!=
end
;
++
p
)
{
zmq
::
socket_base_t
*
s
=
create_socket
(
ZMQ_PAIR
);
// create_socket might fail eg: out of memory/sockets limit reached
zmq_assert
(
s
);
...
...
@@ -528,8 +528,9 @@ void zmq::ctx_t::unregister_endpoints (socket_base_t *socket_)
{
scoped_lock_t
locker
(
_endpoints_sync
);
for
(
endpoints_t
::
iterator
it
=
_endpoints
.
begin
();
it
!=
_endpoints
.
end
();)
{
for
(
endpoints_t
::
iterator
it
=
_endpoints
.
begin
(),
end
=
_endpoints
.
end
();
it
!=
end
;)
{
if
(
it
->
second
.
socket
==
socket_
)
#if __cplusplus >= 201103L
it
=
_endpoints
.
erase
(
it
);
...
...
src/dish.cpp
View file @
76602516
...
...
@@ -100,16 +100,12 @@ int zmq::dish_t::xjoin (const char *group_)
return
-
1
;
}
subscriptions_t
::
iterator
it
=
_subscriptions
.
find
(
group
);
// User cannot join same group twice
if
(
it
!=
_subscriptions
.
end
()
)
{
if
(
!
_subscriptions
.
insert
(
group
).
second
)
{
errno
=
EINVAL
;
return
-
1
;
}
_subscriptions
.
insert
(
group
);
msg_t
msg
;
int
rc
=
msg
.
init_join
();
errno_assert
(
rc
==
0
);
...
...
@@ -230,8 +226,9 @@ const zmq::blob_t &zmq::dish_t::get_credential () const
void
zmq
::
dish_t
::
send_subscriptions
(
pipe_t
*
pipe_
)
{
for
(
subscriptions_t
::
iterator
it
=
_subscriptions
.
begin
();
it
!=
_subscriptions
.
end
();
++
it
)
{
for
(
subscriptions_t
::
iterator
it
=
_subscriptions
.
begin
(),
end
=
_subscriptions
.
end
();
it
!=
end
;
++
it
)
{
msg_t
msg
;
int
rc
=
msg
.
init_join
();
errno_assert
(
rc
==
0
);
...
...
src/epoll.cpp
View file @
76602516
...
...
@@ -75,8 +75,8 @@ zmq::epoll_t::~epoll_t ()
#else
close
(
_epoll_fd
);
#endif
for
(
retired_t
::
iterator
it
=
_retired
.
begin
()
;
it
!
=
_retired
.
end
();
++
it
)
{
for
(
retired_t
::
iterator
it
=
_retired
.
begin
()
,
end
=
_retired
.
end
();
it
!=
end
;
++
it
)
{
LIBZMQ_DELETE
(
*
it
);
}
}
...
...
@@ -207,8 +207,8 @@ void zmq::epoll_t::loop ()
}
// Destroy retired event sources.
for
(
retired_t
::
iterator
it
=
_retired
.
begin
()
;
it
!
=
_retired
.
end
();
++
it
)
{
for
(
retired_t
::
iterator
it
=
_retired
.
begin
()
,
end
=
_retired
.
end
();
it
!=
end
;
++
it
)
{
LIBZMQ_DELETE
(
*
it
);
}
_retired
.
clear
();
...
...
src/generic_mtrie.hpp
View file @
76602516
...
...
@@ -92,6 +92,17 @@ template <typename T> class generic_mtrie_t
void
(
*
func_
)
(
prefix_t
data_
,
size_t
size_
,
Arg
arg_
),
Arg
arg_
,
bool
call_on_uniq_
);
template
<
typename
Arg
>
void
rm_helper_multiple_subnodes
(
unsigned
char
**
buff_
,
size_t
buffsize_
,
size_t
maxbuffsize_
,
void
(
*
func_
)
(
prefix_t
data_
,
size_t
size_
,
Arg
arg_
),
Arg
arg_
,
bool
call_on_uniq_
,
value_t
*
pipe_
);
rm_result
rm_helper
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
value_
);
bool
is_redundant
()
const
;
...
...
src/generic_mtrie_impl.hpp
View file @
76602516
...
...
@@ -37,7 +37,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#include <algorithm>
#include "err.hpp"
#include "pipe.hpp"
#include "macros.hpp"
#include "generic_mtrie.hpp"
...
...
@@ -80,7 +79,7 @@ bool zmq::generic_mtrie_t<T>::add_helper (prefix_t prefix_,
{
// We are at the node corresponding to the prefix. We are done.
if
(
!
size_
)
{
bool
result
=
!
_pipes
;
const
bool
result
=
!
_pipes
;
if
(
!
_pipes
)
{
_pipes
=
new
(
std
::
nothrow
)
pipes_t
;
alloc_assert
(
_pipes
);
...
...
@@ -89,7 +88,7 @@ bool zmq::generic_mtrie_t<T>::add_helper (prefix_t prefix_,
return
result
;
}
unsigned
char
c
=
*
prefix_
;
const
unsigned
char
c
=
*
prefix_
;
if
(
c
<
_min
||
c
>=
_min
+
_count
)
{
// The character is out of range of currently handled
// characters. We have to extend the table.
...
...
@@ -98,11 +97,11 @@ bool zmq::generic_mtrie_t<T>::add_helper (prefix_t prefix_,
_count
=
1
;
_next
.
node
=
NULL
;
}
else
if
(
_count
==
1
)
{
unsigned
char
oldc
=
_min
;
const
unsigned
char
oldc
=
_min
;
generic_mtrie_t
*
oldp
=
_next
.
node
;
_count
=
(
_min
<
c
?
c
-
_min
:
_min
-
c
)
+
1
;
_next
.
table
=
(
generic_mtrie_t
**
)
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
for
(
unsigned
short
i
=
0
;
i
!=
_count
;
++
i
)
_next
.
table
[
i
]
=
0
;
...
...
@@ -110,19 +109,19 @@ bool zmq::generic_mtrie_t<T>::add_helper (prefix_t prefix_,
_next
.
table
[
oldc
-
_min
]
=
oldp
;
}
else
if
(
_min
<
c
)
{
// The new character is above the current character range.
unsigned
short
old_count
=
_count
;
const
unsigned
short
old_count
=
_count
;
_count
=
c
-
_min
+
1
;
_next
.
table
=
(
generic_mtrie_t
**
)
realloc
(
_next
.
table
,
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
realloc
(
_next
.
table
,
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
for
(
unsigned
short
i
=
old_count
;
i
!=
_count
;
i
++
)
_next
.
table
[
i
]
=
NULL
;
}
else
{
// The new character is below the current character range.
unsigned
short
old_count
=
_count
;
const
unsigned
short
old_count
=
_count
;
_count
=
(
_min
+
old_count
)
-
c
;
_next
.
table
=
(
generic_mtrie_t
**
)
realloc
(
_next
.
table
,
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
realloc
(
_next
.
table
,
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
memmove
(
_next
.
table
+
_min
-
c
,
_next
.
table
,
old_count
*
sizeof
(
generic_mtrie_t
*
));
...
...
@@ -194,12 +193,13 @@ void zmq::generic_mtrie_t<T>::rm_helper (value_t *pipe_,
alloc_assert
(
*
buff_
);
}
switch
(
_count
)
{
case
0
:
// If there are no subnodes in the trie, return.
if
(
_count
==
0
)
return
;
break
;
case
1
:
// If there's one subnode (optimisation).
if
(
_count
==
1
)
{
(
*
buff_
)[
buffsize_
]
=
_min
;
buffsize_
++
;
_next
.
node
->
rm_helper
(
pipe_
,
buff_
,
buffsize_
,
maxbuffsize_
,
func_
,
...
...
@@ -212,11 +212,26 @@ void zmq::generic_mtrie_t<T>::rm_helper (value_t *pipe_,
--
_live_nodes
;
zmq_assert
(
_live_nodes
==
0
);
}
return
;
break
;
default
:
// If there are multiple subnodes.
rm_helper_multiple_subnodes
(
buff_
,
buffsize_
,
maxbuffsize_
,
func_
,
arg_
,
call_on_uniq_
,
pipe_
);
break
;
}
}
// If there are multiple subnodes.
//
template
<
typename
T
>
template
<
typename
Arg
>
void
zmq
::
generic_mtrie_t
<
T
>::
rm_helper_multiple_subnodes
(
unsigned
char
**
buff_
,
size_t
buffsize_
,
size_t
maxbuffsize_
,
void
(
*
func_
)
(
prefix_t
data_
,
size_t
size_
,
Arg
arg_
),
Arg
arg_
,
bool
call_on_uniq_
,
value_t
*
pipe_
)
{
// New min non-null character in the node table after the removal
unsigned
char
new_min
=
_min
+
_count
-
1
;
// New max non-null character in the node table after the removal
...
...
@@ -253,25 +268,31 @@ void zmq::generic_mtrie_t<T>::rm_helper (value_t *pipe_,
zmq_assert
(
_count
>
1
);
// Free the node table if it's no longer used.
if
(
_live_nodes
==
0
)
{
switch
(
_live_nodes
)
{
case
0
:
free
(
_next
.
table
);
_next
.
table
=
NULL
;
_count
=
0
;
}
break
;
case
1
:
// Compact the node table if possible
else
if
(
_live_nodes
==
1
)
{
// If there's only one live node in the table we can
// switch to using the more compact single-node
// representation
zmq_assert
(
new_min
==
new_max
);
zmq_assert
(
new_min
>=
_min
&&
new_min
<
_min
+
_count
);
{
generic_mtrie_t
*
node
=
_next
.
table
[
new_min
-
_min
];
zmq_assert
(
node
);
free
(
_next
.
table
);
_next
.
node
=
node
;
}
_count
=
1
;
_min
=
new_min
;
}
else
if
(
new_min
>
_min
||
new_max
<
_min
+
_count
-
1
)
{
break
;
default
:
if
(
new_min
>
_min
||
new_max
<
_min
+
_count
-
1
)
{
zmq_assert
(
new_max
-
new_min
+
1
>
1
);
generic_mtrie_t
**
old_table
=
_next
.
table
;
...
...
@@ -281,8 +302,8 @@ void zmq::generic_mtrie_t<T>::rm_helper (value_t *pipe_,
zmq_assert
(
new_max
-
new_min
+
1
<
_count
);
_count
=
new_max
-
new_min
+
1
;
_next
.
table
=
(
generic_mtrie_t
**
)
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
memmove
(
_next
.
table
,
old_table
+
(
new_min
-
_min
),
...
...
@@ -291,8 +312,8 @@ void zmq::generic_mtrie_t<T>::rm_helper (value_t *pipe_,
_min
=
new_min
;
}
}
}
template
<
typename
T
>
typename
zmq
::
generic_mtrie_t
<
T
>::
rm_result
zmq
::
generic_mtrie_t
<
T
>::
rm
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
pipe_
)
...
...
@@ -317,7 +338,7 @@ typename zmq::generic_mtrie_t<T>::rm_result zmq::generic_mtrie_t<T>::rm_helper (
return
(
erased
==
1
)
?
values_remain
:
not_found
;
}
unsigned
char
c
=
*
prefix_
;
const
unsigned
char
c
=
*
prefix_
;
if
(
!
_count
||
c
<
_min
||
c
>=
_min
+
_count
)
return
not_found
;
...
...
@@ -327,7 +348,7 @@ typename zmq::generic_mtrie_t<T>::rm_result zmq::generic_mtrie_t<T>::rm_helper (
if
(
!
next_node
)
return
not_found
;
rm_result
ret
=
next_node
->
rm_helper
(
prefix_
+
1
,
size_
-
1
,
pipe_
);
const
rm_result
ret
=
next_node
->
rm_helper
(
prefix_
+
1
,
size_
-
1
,
pipe_
);
if
(
next_node
->
is_redundant
())
{
LIBZMQ_DELETE
(
next_node
);
...
...
@@ -370,8 +391,8 @@ typename zmq::generic_mtrie_t<T>::rm_result zmq::generic_mtrie_t<T>::rm_helper (
_min
+=
i
;
_count
-=
i
;
generic_mtrie_t
**
old_table
=
_next
.
table
;
_next
.
table
=
(
generic_mtrie_t
**
)
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
memmove
(
_next
.
table
,
old_table
+
i
,
sizeof
(
generic_mtrie_t
*
)
*
_count
);
...
...
@@ -386,8 +407,8 @@ typename zmq::generic_mtrie_t<T>::rm_result zmq::generic_mtrie_t<T>::rm_helper (
zmq_assert
(
i
<
_count
);
_count
-=
i
;
generic_mtrie_t
**
old_table
=
_next
.
table
;
_next
.
table
=
(
generic_mtrie_t
**
)
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
);
_next
.
table
=
static_cast
<
generic_mtrie_t
**>
(
malloc
(
sizeof
(
generic_mtrie_t
*
)
*
_count
)
);
alloc_assert
(
_next
.
table
);
memmove
(
_next
.
table
,
old_table
,
sizeof
(
generic_mtrie_t
*
)
*
_count
);
...
...
src/mailbox_safe.cpp
View file @
76602516
...
...
@@ -61,10 +61,11 @@ void zmq::mailbox_safe_t::add_signaler (signaler_t *signaler_)
void
zmq
::
mailbox_safe_t
::
remove_signaler
(
signaler_t
*
signaler_
)
{
// TODO: make a copy of array and signal outside the lock
const
std
::
vector
<
zmq
::
signaler_t
*>::
iterator
end
=
_signalers
.
end
();
std
::
vector
<
signaler_t
*>::
iterator
it
=
std
::
find
(
_signalers
.
begin
(),
_signalers
.
end
()
,
signaler_
);
std
::
find
(
_signalers
.
begin
(),
end
,
signaler_
);
if
(
it
!=
_signalers
.
end
()
)
if
(
it
!=
end
)
_signalers
.
erase
(
it
);
}
...
...
@@ -81,8 +82,10 @@ void zmq::mailbox_safe_t::send (const command_t &cmd_)
if
(
!
ok
)
{
_cond_var
.
broadcast
();
for
(
std
::
vector
<
signaler_t
*>::
iterator
it
=
_signalers
.
begin
();
it
!=
_signalers
.
end
();
++
it
)
{
for
(
std
::
vector
<
signaler_t
*>::
iterator
it
=
_signalers
.
begin
(),
end
=
_signalers
.
end
();
it
!=
end
;
++
it
)
{
(
*
it
)
->
send
();
}
}
...
...
src/mechanism.cpp
View file @
76602516
...
...
@@ -178,12 +178,14 @@ size_t zmq::mechanism_t::add_basic_properties (unsigned char *ptr_,
}
for
(
std
::
map
<
std
::
string
,
std
::
string
>::
const_iterator
it
=
options
.
app_metadata
.
begin
();
it
!=
options
.
app_metadata
.
end
();
++
it
)
for
(
std
::
map
<
std
::
string
,
std
::
string
>::
const_iterator
it
=
options
.
app_metadata
.
begin
(),
end
=
options
.
app_metadata
.
end
();
it
!=
end
;
++
it
)
{
ptr
+=
add_property
(
ptr
,
ptr_capacity_
-
(
ptr
-
ptr_
),
it
->
first
.
c_str
(),
it
->
second
.
c_str
(),
strlen
(
it
->
second
.
c_str
()));
}
return
ptr
-
ptr_
;
}
...
...
@@ -193,9 +195,10 @@ size_t zmq::mechanism_t::basic_properties_len () const
const
char
*
socket_type
=
socket_type_string
(
options
.
type
);
size_t
meta_len
=
0
;
for
(
std
::
map
<
std
::
string
,
std
::
string
>::
const_iterator
it
=
options
.
app_metadata
.
begin
();
it
!=
options
.
app_metadata
.
end
();
++
it
)
{
for
(
std
::
map
<
std
::
string
,
std
::
string
>::
const_iterator
it
=
options
.
app_metadata
.
begin
(),
end
=
options
.
app_metadata
.
end
();
it
!=
end
;
++
it
)
{
meta_len
+=
property_len
(
it
->
first
.
c_str
(),
strlen
(
it
->
second
.
c_str
()));
}
...
...
src/own.cpp
View file @
76602516
...
...
@@ -158,7 +158,8 @@ void zmq::own_t::process_term (int linger_)
zmq_assert
(
!
_terminating
);
// Send termination request to all owned objects.
for
(
owned_t
::
iterator
it
=
_owned
.
begin
();
it
!=
_owned
.
end
();
++
it
)
for
(
owned_t
::
iterator
it
=
_owned
.
begin
(),
end
=
_owned
.
end
();
it
!=
end
;
++
it
)
send_term
(
*
it
,
linger_
);
register_term_acks
(
static_cast
<
int
>
(
_owned
.
size
()));
_owned
.
clear
();
...
...
src/pgm_receiver.cpp
View file @
76602516
...
...
@@ -86,7 +86,8 @@ void zmq::pgm_receiver_t::plug (io_thread_t *io_thread_,
void
zmq
::
pgm_receiver_t
::
unplug
()
{
// Delete decoders.
for
(
peers_t
::
iterator
it
=
peers
.
begin
();
it
!=
peers
.
end
();
++
it
)
{
for
(
peers_t
::
iterator
it
=
peers
.
begin
(),
end
=
peers
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
second
.
decoder
!=
NULL
)
{
LIBZMQ_DELETE
(
it
->
second
.
decoder
);
}
...
...
src/pipe.cpp
View file @
76602516
...
...
@@ -520,8 +520,8 @@ void zmq::pipe_t::hiccup ()
void
zmq
::
pipe_t
::
set_hwms
(
int
inhwm_
,
int
outhwm_
)
{
int
in
=
inhwm_
+
(
_in_hwm_boost
>
0
?
_in_hwm_boost
:
0
);
int
out
=
outhwm_
+
(
_out_hwm_boost
>
0
?
_out_hwm_boost
:
0
);
int
in
=
inhwm_
+
std
::
max
(
_in_hwm_boost
,
0
);
int
out
=
outhwm_
+
std
::
max
(
_out_hwm_boost
,
0
);
// if either send or recv side has hwm <= 0 it means infinite so we should set hwms infinite
if
(
inhwm_
<=
0
||
_in_hwm_boost
==
0
)
...
...
src/poller_base.cpp
View file @
76602516
...
...
@@ -65,7 +65,8 @@ void zmq::poller_base_t::add_timer (int timeout_, i_poll_events *sink_, int id_)
void
zmq
::
poller_base_t
::
cancel_timer
(
i_poll_events
*
sink_
,
int
id_
)
{
// Complexity of this operation is O(n). We assume it is rarely used.
for
(
timers_t
::
iterator
it
=
_timers
.
begin
();
it
!=
_timers
.
end
();
++
it
)
for
(
timers_t
::
iterator
it
=
_timers
.
begin
(),
end
=
_timers
.
end
();
it
!=
end
;
++
it
)
if
(
it
->
second
.
sink
==
sink_
&&
it
->
second
.
id
==
id_
)
{
_timers
.
erase
(
it
);
return
;
...
...
src/radio.cpp
View file @
76602516
...
...
@@ -122,8 +122,9 @@ int zmq::radio_t::xsetsockopt (int option_,
void
zmq
::
radio_t
::
xpipe_terminated
(
pipe_t
*
pipe_
)
{
for
(
subscriptions_t
::
iterator
it
=
_subscriptions
.
begin
();
it
!=
_subscriptions
.
end
();)
{
for
(
subscriptions_t
::
iterator
it
=
_subscriptions
.
begin
(),
end
=
_subscriptions
.
end
();
it
!=
end
;)
{
if
(
it
->
second
==
pipe_
)
{
#if __cplusplus >= 201103L
it
=
_subscriptions
.
erase
(
it
);
...
...
@@ -135,10 +136,13 @@ void zmq::radio_t::xpipe_terminated (pipe_t *pipe_)
}
}
udp_pipes_t
::
iterator
it
=
std
::
find
(
_udp_pipes
.
begin
(),
_udp_pipes
.
end
(),
pipe_
);
if
(
it
!=
_udp_pipes
.
end
())
{
const
udp_pipes_t
::
iterator
end
=
_udp_pipes
.
end
();
const
udp_pipes_t
::
iterator
it
=
std
::
find
(
_udp_pipes
.
begin
(),
end
,
pipe_
);
if
(
it
!=
end
)
_udp_pipes
.
erase
(
it
);
}
_dist
.
pipe_terminated
(
pipe_
);
}
...
...
@@ -159,8 +163,9 @@ int zmq::radio_t::xsend (msg_t *msg_)
for
(
subscriptions_t
::
iterator
it
=
range
.
first
;
it
!=
range
.
second
;
++
it
)
_dist
.
match
(
it
->
second
);
for
(
udp_pipes_t
::
iterator
it
=
_udp_pipes
.
begin
();
it
!=
_udp_pipes
.
end
();
++
it
)
for
(
udp_pipes_t
::
iterator
it
=
_udp_pipes
.
begin
(),
end
=
_udp_pipes
.
end
();
it
!=
end
;
++
it
)
_dist
.
match
(
*
it
);
int
rc
=
-
1
;
...
...
src/router.cpp
View file @
76602516
...
...
@@ -165,7 +165,7 @@ void zmq::router_t::xread_activated (pipe_t *pipe_)
if
(
it
==
_anonymous_pipes
.
end
())
_fq
.
activated
(
pipe_
);
else
{
bool
routing_id_ok
=
identify_peer
(
pipe_
,
false
);
const
bool
routing_id_ok
=
identify_peer
(
pipe_
,
false
);
if
(
routing_id_ok
)
{
_anonymous_pipes
.
erase
(
it
);
_fq
.
attach
(
pipe_
);
...
...
src/server.cpp
View file @
76602516
...
...
@@ -86,8 +86,9 @@ void zmq::server_t::xread_activated (pipe_t *pipe_)
void
zmq
::
server_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
{
const
out_pipes_t
::
iterator
end
=
_out_pipes
.
end
();
out_pipes_t
::
iterator
it
;
for
(
it
=
_out_pipes
.
begin
();
it
!=
_out_pipes
.
end
()
;
++
it
)
for
(
it
=
_out_pipes
.
begin
();
it
!=
end
;
++
it
)
if
(
it
->
second
.
pipe
==
pipe_
)
break
;
...
...
src/socket_base.cpp
View file @
76602516
...
...
@@ -543,8 +543,6 @@ int zmq::socket_base_t::bind (const char *addr_)
session_base_t
::
create
(
io_thread
,
true
,
this
,
options
,
paddr
);
errno_assert
(
session
);
pipe_t
*
newpipe
=
NULL
;
// Create a bi-directional pipe.
object_t
*
parents
[
2
]
=
{
this
,
session
};
pipe_t
*
new_pipes
[
2
]
=
{
NULL
,
NULL
};
...
...
@@ -556,7 +554,7 @@ int zmq::socket_base_t::bind (const char *addr_)
// Attach local end of the pipe to the socket object.
attach_pipe
(
new_pipes
[
0
],
true
,
true
);
newpipe
=
new_pipes
[
0
];
pipe_t
*
const
newpipe
=
new_pipes
[
0
];
// Attach remote end of the pipe to the session object later on.
session
->
attach_pipe
(
new_pipes
[
1
]);
...
...
@@ -564,7 +562,7 @@ int zmq::socket_base_t::bind (const char *addr_)
// Save last endpoint URI
paddr
->
to_string
(
_last_endpoint
);
add_endpoint
(
addr_
,
(
own_t
*
)
session
,
newpipe
);
add_endpoint
(
addr_
,
static_cast
<
own_t
*>
(
session
)
,
newpipe
);
return
0
;
}
...
...
@@ -786,12 +784,11 @@ int zmq::socket_base_t::connect (const char *addr_)
options
.
connected
=
true
;
return
0
;
}
bool
is_single_connect
=
const
bool
is_single_connect
=
(
options
.
type
==
ZMQ_DEALER
||
options
.
type
==
ZMQ_SUB
||
options
.
type
==
ZMQ_PUB
||
options
.
type
==
ZMQ_REQ
);
if
(
unlikely
(
is_single_connect
))
{
const
endpoints_t
::
iterator
it
=
_endpoints
.
find
(
addr_
);
if
(
it
!=
_endpoints
.
end
())
{
if
(
0
!=
_endpoints
.
count
(
addr_
))
{
// There is no valid use for multiple connects for SUB-PUB nor
// DEALER-ROUTER nor REQ-REP. Multiple connects produces
// nonsensical results.
...
...
@@ -1551,8 +1548,8 @@ void zmq::socket_base_t::pipe_terminated (pipe_t *pipe_)
xpipe_terminated
(
pipe_
);
// Remove pipe from inproc pipes
for
(
inprocs_t
::
iterator
it
=
_inprocs
.
begin
()
;
it
!
=
_inprocs
.
end
();
++
it
)
for
(
inprocs_t
::
iterator
it
=
_inprocs
.
begin
()
,
end
=
_inprocs
.
end
();
it
!=
end
;
++
it
)
if
(
it
->
second
==
pipe_
)
{
_inprocs
.
erase
(
it
);
break
;
...
...
@@ -1790,12 +1787,13 @@ int zmq::routing_socket_base_t::xsetsockopt (int option_,
void
zmq
::
routing_socket_base_t
::
xwrite_activated
(
pipe_t
*
pipe_
)
{
const
out_pipes_t
::
iterator
end
=
_out_pipes
.
end
();
out_pipes_t
::
iterator
it
;
for
(
it
=
_out_pipes
.
begin
();
it
!=
_out_pipes
.
end
()
;
++
it
)
for
(
it
=
_out_pipes
.
begin
();
it
!=
end
;
++
it
)
if
(
it
->
second
.
pipe
==
pipe_
)
break
;
zmq_assert
(
it
!=
_out_pipes
.
end
()
);
zmq_assert
(
it
!=
end
);
zmq_assert
(
!
it
->
second
.
active
);
it
->
second
.
active
=
true
;
}
...
...
src/socket_poller.cpp
View file @
76602516
...
...
@@ -31,6 +31,7 @@
#include "socket_poller.hpp"
#include "err.hpp"
#include "polling_util.hpp"
#include "macros.hpp"
#include <limits.h>
...
...
@@ -59,7 +60,8 @@ zmq::socket_poller_t::~socket_poller_t ()
// Mark the socket_poller as dead
_tag
=
0xdeadbeef
;
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
// TODO shouldn't this zmq_assert (it->socket->check_tag ()) instead?
if
(
it
->
socket
&&
it
->
socket
->
check_tag
()
&&
is_thread_safe
(
*
it
->
socket
))
{
...
...
@@ -68,8 +70,7 @@ zmq::socket_poller_t::~socket_poller_t ()
}
if
(
_signaler
!=
NULL
)
{
delete
_signaler
;
_signaler
=
NULL
;
LIBZMQ_DELETE
(
_signaler
);
}
#if defined ZMQ_POLL_BASED_ON_POLL
...
...
@@ -89,7 +90,8 @@ int zmq::socket_poller_t::add (socket_base_t *socket_,
void
*
user_data_
,
short
events_
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
socket
==
socket_
)
{
errno
=
EINVAL
;
return
-
1
;
...
...
@@ -138,7 +140,8 @@ int zmq::socket_poller_t::add (socket_base_t *socket_,
int
zmq
::
socket_poller_t
::
add_fd
(
fd_t
fd_
,
void
*
user_data_
,
short
events_
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
!
it
->
socket
&&
it
->
fd
==
fd_
)
{
errno
=
EINVAL
;
return
-
1
;
...
...
@@ -169,14 +172,15 @@ int zmq::socket_poller_t::add_fd (fd_t fd_, void *user_data_, short events_)
int
zmq
::
socket_poller_t
::
modify
(
socket_base_t
*
socket_
,
short
events_
)
{
const
items_t
::
iterator
end
=
_items
.
end
();
items_t
::
iterator
it
;
for
(
it
=
_items
.
begin
();
it
!=
_items
.
end
()
;
++
it
)
{
for
(
it
=
_items
.
begin
();
it
!=
end
;
++
it
)
{
if
(
it
->
socket
==
socket_
)
break
;
}
if
(
it
==
_items
.
end
()
)
{
if
(
it
==
end
)
{
errno
=
EINVAL
;
return
-
1
;
}
...
...
@@ -190,14 +194,15 @@ int zmq::socket_poller_t::modify (socket_base_t *socket_, short events_)
int
zmq
::
socket_poller_t
::
modify_fd
(
fd_t
fd_
,
short
events_
)
{
const
items_t
::
iterator
end
=
_items
.
end
();
items_t
::
iterator
it
;
for
(
it
=
_items
.
begin
();
it
!=
_items
.
end
()
;
++
it
)
{
for
(
it
=
_items
.
begin
();
it
!=
end
;
++
it
)
{
if
(
!
it
->
socket
&&
it
->
fd
==
fd_
)
break
;
}
if
(
it
==
_items
.
end
()
)
{
if
(
it
==
end
)
{
errno
=
EINVAL
;
return
-
1
;
}
...
...
@@ -211,14 +216,15 @@ int zmq::socket_poller_t::modify_fd (fd_t fd_, short events_)
int
zmq
::
socket_poller_t
::
remove
(
socket_base_t
*
socket_
)
{
const
items_t
::
iterator
end
=
_items
.
end
();
items_t
::
iterator
it
;
for
(
it
=
_items
.
begin
();
it
!=
_items
.
end
()
;
++
it
)
{
for
(
it
=
_items
.
begin
();
it
!=
end
;
++
it
)
{
if
(
it
->
socket
==
socket_
)
break
;
}
if
(
it
==
_items
.
end
()
)
{
if
(
it
==
end
)
{
errno
=
EINVAL
;
return
-
1
;
}
...
...
@@ -235,14 +241,15 @@ int zmq::socket_poller_t::remove (socket_base_t *socket_)
int
zmq
::
socket_poller_t
::
remove_fd
(
fd_t
fd_
)
{
const
items_t
::
iterator
end
=
_items
.
end
();
items_t
::
iterator
it
;
for
(
it
=
_items
.
begin
();
it
!=
_items
.
end
()
;
++
it
)
{
for
(
it
=
_items
.
begin
();
it
!=
end
;
++
it
)
{
if
(
!
it
->
socket
&&
it
->
fd
==
fd_
)
break
;
}
if
(
it
==
_items
.
end
()
)
{
if
(
it
==
end
)
{
errno
=
EINVAL
;
return
-
1
;
}
...
...
@@ -266,7 +273,8 @@ void zmq::socket_poller_t::rebuild ()
_pollfds
=
NULL
;
}
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
events
)
{
if
(
it
->
socket
&&
is_thread_safe
(
*
it
->
socket
))
{
if
(
!
_use_signaler
)
{
...
...
@@ -292,7 +300,8 @@ void zmq::socket_poller_t::rebuild ()
_pollfds
[
0
].
events
=
POLLIN
;
}
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
events
)
{
if
(
it
->
socket
)
{
if
(
!
is_thread_safe
(
*
it
->
socket
))
{
...
...
@@ -330,7 +339,8 @@ void zmq::socket_poller_t::rebuild ()
FD_ZERO
(
_pollset_out
.
get
());
FD_ZERO
(
_pollset_err
.
get
());
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
socket
&&
is_thread_safe
(
*
it
->
socket
)
&&
it
->
events
)
{
_use_signaler
=
true
;
FD_SET
(
_signaler
->
get_fd
(),
_pollset_in
.
get
());
...
...
@@ -342,7 +352,8 @@ void zmq::socket_poller_t::rebuild ()
_max_fd
=
0
;
// Build the fd_sets for passing to select ().
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
();
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
(),
end
=
_items
.
end
();
it
!=
end
;
++
it
)
{
if
(
it
->
events
)
{
// If the poll item is a 0MQ socket we are interested in input on the
// notification file descriptor retrieved by the ZMQ_FD socket option.
...
...
@@ -404,8 +415,8 @@ int zmq::socket_poller_t::check_events (zmq::socket_poller_t::event_t *events_,
#endif
{
int
found
=
0
;
for
(
items_t
::
iterator
it
=
_items
.
begin
();
it
!=
_items
.
end
()
&&
found
<
n_events_
;
++
it
)
{
for
(
items_t
::
iterator
it
=
_items
.
begin
()
,
end
=
_items
.
end
()
;
it
!=
end
&&
found
<
n_events_
;
++
it
)
{
// The poll item is a 0MQ socket. Retrieve pending events
// using the ZMQ_EVENTS socket option.
if
(
it
->
socket
)
{
...
...
src/stream_engine.cpp
View file @
76602516
This diff is collapsed.
Click to expand it.
src/stream_engine.hpp
View file @
76602516
...
...
@@ -93,12 +93,22 @@ class stream_engine_t : public io_object_t, public i_engine
// Function to handle network disconnections.
void
error
(
error_reason_t
reason_
);
// Receives the greeting message from the peer.
int
receive_greeting
();
// Detects the protocol used by the peer.
bool
handshake
();
// Receive the greeting from the peer.
int
receive_greeting
();
void
receive_greeting_versioned
();
typedef
bool
(
stream_engine_t
::*
handshake_fun_t
)
();
static
handshake_fun_t
select_handshake_fun
(
bool
unversioned
,
unsigned
char
revision
);
bool
handshake_v1_0_unversioned
();
bool
handshake_v1_0
();
bool
handshake_v2_0
();
bool
handshake_v3_0
();
int
routing_id_msg
(
msg_t
*
msg_
);
int
process_routing_id_msg
(
msg_t
*
msg_
);
...
...
src/timers.cpp
View file @
76602516
...
...
@@ -144,7 +144,7 @@ long zmq::timers_t::timeout ()
for
(;
it
!=
end
;
++
it
)
{
if
(
0
==
_cancelled_timers
.
erase
(
it
->
second
.
timer_id
))
{
// Live timer, lets return the timeout
res
=
it
->
first
>
now
?
static_cast
<
long
>
(
it
->
first
-
now
)
:
0
;
res
=
std
::
max
(
static_cast
<
long
>
(
it
->
first
-
now
),
0l
)
;
break
;
}
}
...
...
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