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
36cdcc6c
Commit
36cdcc6c
authored
Feb 28, 2018
by
Simon Giesecke
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Problem: docs of mtrie referring to subscriptions and pipes
Solution: generalized terms to entries/values
parent
e34e03d1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
18 deletions
+19
-18
generic_mtrie.hpp
src/generic_mtrie.hpp
+19
-18
No files found.
src/generic_mtrie.hpp
View file @
36cdcc6c
...
@@ -37,7 +37,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
...
@@ -37,7 +37,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
namespace
zmq
namespace
zmq
{
{
// Multi-trie
. Each node in the trie is a set of pointers to pipe
s.
// Multi-trie
(prefix tree). Each node in the trie is a set of pointer
s.
template
<
typename
T
>
class
generic_mtrie_t
template
<
typename
T
>
class
generic_mtrie_t
{
{
public
:
public
:
...
@@ -47,47 +47,48 @@ template <typename T> class generic_mtrie_t
...
@@ -47,47 +47,48 @@ template <typename T> class generic_mtrie_t
generic_mtrie_t
();
generic_mtrie_t
();
~
generic_mtrie_t
();
~
generic_mtrie_t
();
// Add key to the trie. Returns true if it's a new
subscription
// Add key to the trie. Returns true if it's a new
entry
// rather than a duplicate (i.e. an entry with the same prefix
// rather than a duplicate (i.e. an entry with the same prefix
// but a different pipe already exists).
// and the same or different value already exists).
// TODO what if this is called with the same prefix AND pipe?
bool
add
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
value_
);
// Is this legal? It is not checked anywhere.
bool
add
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
pipe_
);
// Remove all
subscriptions for a specific peer
from the trie.
// Remove all
entries with a specific value
from the trie.
// The call_on_uniq_ flag controls if the callback is invoked
// The call_on_uniq_ flag controls if the callback is invoked
// when there are no subscriptions left on a topic only (true)
// when there are no entries left on a prefix only (true)
// or on every removal (false).
// or on every removal (false). The arg_ argument is passed
// through to the callback function.
template
<
typename
Arg
>
template
<
typename
Arg
>
void
rm
(
value_t
*
pip
e_
,
void
rm
(
value_t
*
valu
e_
,
void
(
*
func_
)
(
const
unsigned
char
*
data_
,
size_t
size_
,
Arg
arg_
),
void
(
*
func_
)
(
const
unsigned
char
*
data_
,
size_t
size_
,
Arg
arg_
),
Arg
arg_
,
Arg
arg_
,
bool
call_on_uniq_
);
bool
call_on_uniq_
);
// Remove
specific subscription
from the trie. Return true if it was
// Remove
s a specific entry
from the trie. Return true if it was
// actually removed rather than de-duplicated.
// actually removed rather than de-duplicated.
// TODO this must be made clearer, and the case where the prefix/
pip
e
// TODO this must be made clearer, and the case where the prefix/
valu
e
// pair was not found must be specified
// pair was not found must be specified
bool
rm
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
pip
e_
);
bool
rm
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
valu
e_
);
// Signal all the matching pipes.
// Calls a callback function for all matching entries, i.e. any node
// corresponding to data_ or a prefix of it. The arg_ argument
// is passed through to the callback function.
template
<
typename
Arg
>
template
<
typename
Arg
>
void
match
(
prefix_t
data_
,
void
match
(
prefix_t
data_
,
size_t
size_
,
size_t
size_
,
void
(
*
func_
)
(
value_t
*
pip
e_
,
Arg
arg_
),
void
(
*
func_
)
(
value_t
*
valu
e_
,
Arg
arg_
),
Arg
arg_
);
Arg
arg_
);
private
:
private
:
bool
add_helper
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
pip
e_
);
bool
add_helper
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
valu
e_
);
template
<
typename
Arg
>
template
<
typename
Arg
>
void
rm_helper
(
value_t
*
pip
e_
,
void
rm_helper
(
value_t
*
valu
e_
,
unsigned
char
**
buff_
,
unsigned
char
**
buff_
,
size_t
buffsize_
,
size_t
buffsize_
,
size_t
maxbuffsize_
,
size_t
maxbuffsize_
,
void
(
*
func_
)
(
prefix_t
data_
,
size_t
size_
,
Arg
arg_
),
void
(
*
func_
)
(
prefix_t
data_
,
size_t
size_
,
Arg
arg_
),
Arg
arg_
,
Arg
arg_
,
bool
call_on_uniq_
);
bool
call_on_uniq_
);
bool
rm_helper
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
pip
e_
);
bool
rm_helper
(
prefix_t
prefix_
,
size_t
size_
,
value_t
*
valu
e_
);
bool
is_redundant
()
const
;
bool
is_redundant
()
const
;
typedef
std
::
set
<
value_t
*>
pipes_t
;
typedef
std
::
set
<
value_t
*>
pipes_t
;
...
...
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