czmq-ffi-gen 0.13.0-x86-mingw32 → 0.14.1-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGES.md +13 -0
- data/lib/czmq-ffi-gen/czmq/ffi.rb +224 -698
- data/lib/czmq-ffi-gen/czmq/ffi/zactor.rb +40 -7
- data/lib/czmq-ffi-gen/czmq/ffi/zargs.rb +259 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zarmour.rb +3 -3
- data/lib/czmq-ffi-gen/czmq/ffi/zcert.rb +15 -6
- data/lib/czmq-ffi-gen/czmq/ffi/zcertstore.rb +25 -11
- data/lib/czmq-ffi-gen/czmq/ffi/zchunk.rb +18 -18
- data/lib/czmq-ffi-gen/czmq/ffi/zclock.rb +6 -6
- data/lib/czmq-ffi-gen/czmq/ffi/zconfig.rb +27 -17
- data/lib/czmq-ffi-gen/czmq/ffi/zdigest.rb +4 -4
- data/lib/czmq-ffi-gen/czmq/ffi/zdir.rb +36 -36
- data/lib/czmq-ffi-gen/czmq/ffi/zdir_patch.rb +1 -1
- data/lib/czmq-ffi-gen/czmq/ffi/zfile.rb +27 -19
- data/lib/czmq-ffi-gen/czmq/ffi/zframe.rb +22 -21
- data/lib/czmq-ffi-gen/czmq/ffi/zhash.rb +54 -54
- data/lib/czmq-ffi-gen/czmq/ffi/zhashx.rb +82 -80
- data/lib/czmq-ffi-gen/czmq/ffi/ziflist.rb +30 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zlist.rb +30 -30
- data/lib/czmq-ffi-gen/czmq/ffi/zlistx.rb +44 -44
- data/lib/czmq-ffi-gen/czmq/ffi/zloop.rb +39 -39
- data/lib/czmq-ffi-gen/czmq/ffi/zmsg.rb +46 -46
- data/lib/czmq-ffi-gen/czmq/ffi/zpoller.rb +16 -16
- data/lib/czmq-ffi-gen/czmq/ffi/zproc.rb +237 -34
- data/lib/czmq-ffi-gen/czmq/ffi/zsock.rb +1201 -973
- data/lib/czmq-ffi-gen/czmq/ffi/zstr.rb +58 -19
- data/lib/czmq-ffi-gen/czmq/ffi/zsys.rb +836 -0
- data/lib/czmq-ffi-gen/czmq/ffi/ztimerset.rb +6 -6
- data/lib/czmq-ffi-gen/czmq/ffi/ztrie.rb +10 -10
- data/lib/czmq-ffi-gen/czmq/ffi/zuuid.rb +4 -4
- data/lib/czmq-ffi-gen/gem_version.rb +1 -1
- data/lib/czmq-ffi-gen/vendor.rb +9 -1
- data/vendor/local/bin/inproc_lat.exe +0 -0
- data/vendor/local/bin/inproc_thr.exe +0 -0
- data/vendor/local/bin/libczmq.dll +0 -0
- data/vendor/local/bin/libzmq.dll +0 -0
- data/vendor/local/bin/local_lat.exe +0 -0
- data/vendor/local/bin/local_thr.exe +0 -0
- data/vendor/local/bin/remote_lat.exe +0 -0
- data/vendor/local/bin/remote_thr.exe +0 -0
- data/vendor/local/bin/zmakecert.exe +0 -0
- data/vendor/local/include/czmq_library.h +18 -9
- data/vendor/local/include/czmq_prelude.h +104 -16
- data/vendor/local/include/zactor.h +25 -7
- data/vendor/local/include/zarmour.h +3 -3
- data/vendor/local/include/zcert.h +11 -6
- data/vendor/local/include/zcertstore.h +18 -9
- data/vendor/local/include/zchunk.h +18 -18
- data/vendor/local/include/zclock.h +6 -6
- data/vendor/local/include/zconfig.h +25 -16
- data/vendor/local/include/zdigest.h +4 -4
- data/vendor/local/include/zdir.h +36 -36
- data/vendor/local/include/zdir_patch.h +1 -1
- data/vendor/local/include/zfile.h +27 -19
- data/vendor/local/include/zframe.h +22 -21
- data/vendor/local/include/zgossip.h +5 -5
- data/vendor/local/include/zgossip_engine.inc +103 -22
- data/vendor/local/include/zgossip_msg.h +28 -30
- data/vendor/local/include/zhash.h +53 -53
- data/vendor/local/include/zhashx.h +75 -73
- data/vendor/local/include/ziflist.h +22 -1
- data/vendor/local/include/zlist.h +28 -28
- data/vendor/local/include/zlistx.h +41 -41
- data/vendor/local/include/zloop.h +36 -36
- data/vendor/local/include/zmsg.h +46 -46
- data/vendor/local/include/zpoller.h +16 -16
- data/vendor/local/include/zsock.h +414 -364
- data/vendor/local/include/zsock_option.inc +234 -1062
- data/vendor/local/include/zstr.h +44 -19
- data/vendor/local/include/zsys.h +63 -19
- data/vendor/local/include/zuuid.h +4 -4
- data/vendor/local/lib/libczmq.dll.a +0 -0
- data/vendor/local/lib/liblibzmq.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/libczmq.pc +1 -1
- metadata +6 -3
@@ -1,13 +1,13 @@
|
|
1
1
|
/* =========================================================================
|
2
2
|
zgossip_msg - class description
|
3
3
|
|
4
|
-
Copyright (c) the Contributors as noted in the AUTHORS file.
|
5
|
-
This file is part of CZMQ, the high-level C binding for 0MQ:
|
6
|
-
http://czmq.zeromq.org.
|
7
|
-
|
4
|
+
Copyright (c) the Contributors as noted in the AUTHORS file.
|
5
|
+
This file is part of CZMQ, the high-level C binding for 0MQ:
|
6
|
+
http://czmq.zeromq.org.
|
7
|
+
|
8
8
|
This Source Code Form is subject to the terms of the Mozilla Public
|
9
9
|
License, v. 2.0. If a copy of the MPL was not distributed with this
|
10
|
-
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
10
|
+
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
11
11
|
=========================================================================
|
12
12
|
*/
|
13
13
|
|
@@ -18,8 +18,6 @@
|
|
18
18
|
extern "C" {
|
19
19
|
#endif
|
20
20
|
|
21
|
-
typedef struct _zgossip_msg_t zgossip_msg_t;
|
22
|
-
|
23
21
|
// @warning THE FOLLOWING @INTERFACE BLOCK IS AUTO-GENERATED BY ZPROJECT
|
24
22
|
// @warning Please edit the model at "api/zgossip_msg.api" to make changes.
|
25
23
|
// @interface
|
@@ -27,96 +25,96 @@ typedef struct _zgossip_msg_t zgossip_msg_t;
|
|
27
25
|
// stable builds by default. If you use this in applications, please ask
|
28
26
|
// for it to be pushed to stable state. Use --enable-drafts to enable.
|
29
27
|
#ifdef CZMQ_BUILD_DRAFT_API
|
30
|
-
#define ZGOSSIP_MSG_HELLO 1 //
|
31
|
-
#define ZGOSSIP_MSG_PUBLISH 2 //
|
32
|
-
#define ZGOSSIP_MSG_PING 3 //
|
33
|
-
#define ZGOSSIP_MSG_PONG 4 //
|
34
|
-
#define ZGOSSIP_MSG_INVALID 5 //
|
28
|
+
#define ZGOSSIP_MSG_HELLO 1 //
|
29
|
+
#define ZGOSSIP_MSG_PUBLISH 2 //
|
30
|
+
#define ZGOSSIP_MSG_PING 3 //
|
31
|
+
#define ZGOSSIP_MSG_PONG 4 //
|
32
|
+
#define ZGOSSIP_MSG_INVALID 5 //
|
35
33
|
|
36
34
|
// *** Draft method, for development use, may change without warning ***
|
37
35
|
// Create a new empty zgossip_msg
|
38
|
-
|
36
|
+
CZMQ_PRIVATE zgossip_msg_t *
|
39
37
|
zgossip_msg_new (void);
|
40
38
|
|
41
39
|
// *** Draft method, for development use, may change without warning ***
|
42
40
|
// Destroy a zgossip_msg instance
|
43
|
-
|
41
|
+
CZMQ_PRIVATE void
|
44
42
|
zgossip_msg_destroy (zgossip_msg_t **self_p);
|
45
43
|
|
46
44
|
// *** Draft method, for development use, may change without warning ***
|
47
45
|
// Receive a zgossip_msg from the socket. Returns 0 if OK, -1 if
|
48
|
-
// there was an error. Blocks if there is no message waiting.
|
49
|
-
|
46
|
+
// there was an error. Blocks if there is no message waiting.
|
47
|
+
CZMQ_PRIVATE int
|
50
48
|
zgossip_msg_recv (zgossip_msg_t *self, zsock_t *input);
|
51
49
|
|
52
50
|
// *** Draft method, for development use, may change without warning ***
|
53
51
|
// Send the zgossip_msg to the output socket, does not destroy it
|
54
|
-
|
52
|
+
CZMQ_PRIVATE int
|
55
53
|
zgossip_msg_send (zgossip_msg_t *self, zsock_t *output);
|
56
54
|
|
57
55
|
// *** Draft method, for development use, may change without warning ***
|
58
56
|
// Print contents of message to stdout
|
59
|
-
|
57
|
+
CZMQ_PRIVATE void
|
60
58
|
zgossip_msg_print (zgossip_msg_t *self);
|
61
59
|
|
62
60
|
// *** Draft method, for development use, may change without warning ***
|
63
61
|
// Get the message routing id, as a frame
|
64
|
-
|
62
|
+
CZMQ_PRIVATE zframe_t *
|
65
63
|
zgossip_msg_routing_id (zgossip_msg_t *self);
|
66
64
|
|
67
65
|
// *** Draft method, for development use, may change without warning ***
|
68
66
|
// Set the message routing id from a frame
|
69
|
-
|
67
|
+
CZMQ_PRIVATE void
|
70
68
|
zgossip_msg_set_routing_id (zgossip_msg_t *self, zframe_t *routing_id);
|
71
69
|
|
72
70
|
// *** Draft method, for development use, may change without warning ***
|
73
71
|
// Get the zgossip_msg message id
|
74
|
-
|
72
|
+
CZMQ_PRIVATE int
|
75
73
|
zgossip_msg_id (zgossip_msg_t *self);
|
76
74
|
|
77
75
|
// *** Draft method, for development use, may change without warning ***
|
78
76
|
// Set the zgossip_msg message id
|
79
|
-
|
77
|
+
CZMQ_PRIVATE void
|
80
78
|
zgossip_msg_set_id (zgossip_msg_t *self, int id);
|
81
79
|
|
82
80
|
// *** Draft method, for development use, may change without warning ***
|
83
81
|
// Get the zgossip_msg message id as printable text
|
84
|
-
|
82
|
+
CZMQ_PRIVATE const char *
|
85
83
|
zgossip_msg_command (zgossip_msg_t *self);
|
86
84
|
|
87
85
|
// *** Draft method, for development use, may change without warning ***
|
88
86
|
// Get the key field
|
89
|
-
|
87
|
+
CZMQ_PRIVATE const char *
|
90
88
|
zgossip_msg_key (zgossip_msg_t *self);
|
91
89
|
|
92
90
|
// *** Draft method, for development use, may change without warning ***
|
93
91
|
// Set the key field
|
94
|
-
|
92
|
+
CZMQ_PRIVATE void
|
95
93
|
zgossip_msg_set_key (zgossip_msg_t *self, const char *key);
|
96
94
|
|
97
95
|
// *** Draft method, for development use, may change without warning ***
|
98
96
|
// Get the value field
|
99
|
-
|
97
|
+
CZMQ_PRIVATE const char *
|
100
98
|
zgossip_msg_value (zgossip_msg_t *self);
|
101
99
|
|
102
100
|
// *** Draft method, for development use, may change without warning ***
|
103
101
|
// Set the value field
|
104
|
-
|
102
|
+
CZMQ_PRIVATE void
|
105
103
|
zgossip_msg_set_value (zgossip_msg_t *self, const char *value);
|
106
104
|
|
107
105
|
// *** Draft method, for development use, may change without warning ***
|
108
106
|
// Get the ttl field
|
109
|
-
|
107
|
+
CZMQ_PRIVATE uint32_t
|
110
108
|
zgossip_msg_ttl (zgossip_msg_t *self);
|
111
109
|
|
112
110
|
// *** Draft method, for development use, may change without warning ***
|
113
111
|
// Set the ttl field
|
114
|
-
|
112
|
+
CZMQ_PRIVATE void
|
115
113
|
zgossip_msg_set_ttl (zgossip_msg_t *self, uint32_t ttl);
|
116
114
|
|
117
115
|
// *** Draft method, for development use, may change without warning ***
|
118
116
|
// Self test of this class.
|
119
|
-
|
117
|
+
CZMQ_PRIVATE void
|
120
118
|
zgossip_msg_test (bool verbose);
|
121
119
|
|
122
120
|
#endif // CZMQ_BUILD_DRAFT_API
|
@@ -32,8 +32,8 @@ CZMQ_EXPORT zhash_t *
|
|
32
32
|
zhash_new (void);
|
33
33
|
|
34
34
|
// Unpack binary frame into a new hash table. Packed data must follow format
|
35
|
-
// defined by zhash_pack. Hash table is set to autofree. An empty frame
|
36
|
-
// unpacks to an empty hash table.
|
35
|
+
// defined by zhash_pack. Hash table is set to autofree. An empty frame
|
36
|
+
// unpacks to an empty hash table.
|
37
37
|
CZMQ_EXPORT zhash_t *
|
38
38
|
zhash_unpack (zframe_t *frame);
|
39
39
|
|
@@ -41,20 +41,20 @@ CZMQ_EXPORT zhash_t *
|
|
41
41
|
CZMQ_EXPORT void
|
42
42
|
zhash_destroy (zhash_t **self_p);
|
43
43
|
|
44
|
-
// Insert item into hash table with specified key and item.
|
44
|
+
// Insert item into hash table with specified key and item.
|
45
45
|
// If key is already present returns -1 and leaves existing item unchanged
|
46
|
-
// Returns 0 on success.
|
46
|
+
// Returns 0 on success.
|
47
47
|
CZMQ_EXPORT int
|
48
48
|
zhash_insert (zhash_t *self, const char *key, void *item);
|
49
49
|
|
50
|
-
// Update item into hash table with specified key and item.
|
51
|
-
// If key is already present, destroys old item and inserts new one.
|
50
|
+
// Update item into hash table with specified key and item.
|
51
|
+
// If key is already present, destroys old item and inserts new one.
|
52
52
|
// Use free_fn method to ensure deallocator is properly called on item.
|
53
53
|
CZMQ_EXPORT void
|
54
54
|
zhash_update (zhash_t *self, const char *key, void *item);
|
55
55
|
|
56
56
|
// Remove an item specified by key from the hash table. If there was no such
|
57
|
-
// item, this function does nothing.
|
57
|
+
// item, this function does nothing.
|
58
58
|
CZMQ_EXPORT void
|
59
59
|
zhash_delete (zhash_t *self, const char *key);
|
60
60
|
|
@@ -63,15 +63,15 @@ CZMQ_EXPORT void *
|
|
63
63
|
zhash_lookup (zhash_t *self, const char *key);
|
64
64
|
|
65
65
|
// Reindexes an item from an old key to a new key. If there was no such
|
66
|
-
// item, does nothing. Returns 0 if successful, else -1.
|
66
|
+
// item, does nothing. Returns 0 if successful, else -1.
|
67
67
|
CZMQ_EXPORT int
|
68
68
|
zhash_rename (zhash_t *self, const char *old_key, const char *new_key);
|
69
69
|
|
70
70
|
// Set a free function for the specified hash table item. When the item is
|
71
|
-
// destroyed, the free function, if any, is called on that item.
|
72
|
-
// Use this when hash items are dynamically allocated, to ensure that
|
73
|
-
// you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
|
74
|
-
// Returns the item, or NULL if there is no such item.
|
71
|
+
// destroyed, the free function, if any, is called on that item.
|
72
|
+
// Use this when hash items are dynamically allocated, to ensure that
|
73
|
+
// you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
|
74
|
+
// Returns the item, or NULL if there is no such item.
|
75
75
|
CZMQ_EXPORT void *
|
76
76
|
zhash_freefn (zhash_t *self, const char *key, zhash_free_fn free_fn);
|
77
77
|
|
@@ -79,10 +79,10 @@ CZMQ_EXPORT void *
|
|
79
79
|
CZMQ_EXPORT size_t
|
80
80
|
zhash_size (zhash_t *self);
|
81
81
|
|
82
|
-
// Make copy of hash table; if supplied table is null, returns null.
|
83
|
-
// Does not copy items themselves. Rebuilds new table so may be slow on
|
82
|
+
// Make copy of hash table; if supplied table is null, returns null.
|
83
|
+
// Does not copy items themselves. Rebuilds new table so may be slow on
|
84
84
|
// very large tables. NOTE: only works with item values that are strings
|
85
|
-
// since there's no other way to know how to duplicate the item value.
|
85
|
+
// since there's no other way to know how to duplicate the item value.
|
86
86
|
// Caller owns return value and must destroy it when done.
|
87
87
|
CZMQ_EXPORT zhash_t *
|
88
88
|
zhash_dup (zhash_t *self);
|
@@ -92,80 +92,80 @@ CZMQ_EXPORT zhash_t *
|
|
92
92
|
CZMQ_EXPORT zlist_t *
|
93
93
|
zhash_keys (zhash_t *self);
|
94
94
|
|
95
|
-
// Simple iterator; returns first item in hash table, in no given order,
|
96
|
-
// or NULL if the table is empty. This method is simpler to use than the
|
95
|
+
// Simple iterator; returns first item in hash table, in no given order,
|
96
|
+
// or NULL if the table is empty. This method is simpler to use than the
|
97
97
|
// foreach() method, which is deprecated. To access the key for this item
|
98
|
-
// use zhash_cursor(). NOTE: do NOT modify the table while iterating.
|
98
|
+
// use zhash_cursor(). NOTE: do NOT modify the table while iterating.
|
99
99
|
CZMQ_EXPORT void *
|
100
100
|
zhash_first (zhash_t *self);
|
101
101
|
|
102
|
-
// Simple iterator; returns next item in hash table, in no given order,
|
102
|
+
// Simple iterator; returns next item in hash table, in no given order,
|
103
103
|
// or NULL if the last item was already returned. Use this together with
|
104
|
-
// zhash_first() to process all items in a hash table. If you need the
|
105
|
-
// items in sorted order, use zhash_keys() and then zlist_sort(). To
|
106
|
-
// access the key for this item use zhash_cursor(). NOTE: do NOT modify
|
107
|
-
// the table while iterating.
|
104
|
+
// zhash_first() to process all items in a hash table. If you need the
|
105
|
+
// items in sorted order, use zhash_keys() and then zlist_sort(). To
|
106
|
+
// access the key for this item use zhash_cursor(). NOTE: do NOT modify
|
107
|
+
// the table while iterating.
|
108
108
|
CZMQ_EXPORT void *
|
109
109
|
zhash_next (zhash_t *self);
|
110
110
|
|
111
111
|
// After a successful first/next method, returns the key for the item that
|
112
|
-
// was returned. This is a constant string that you may not modify or
|
113
|
-
// deallocate, and which lasts as long as the item in the hash. After an
|
114
|
-
// unsuccessful first/next, returns NULL.
|
112
|
+
// was returned. This is a constant string that you may not modify or
|
113
|
+
// deallocate, and which lasts as long as the item in the hash. After an
|
114
|
+
// unsuccessful first/next, returns NULL.
|
115
115
|
CZMQ_EXPORT const char *
|
116
116
|
zhash_cursor (zhash_t *self);
|
117
117
|
|
118
|
-
// Add a comment to hash table before saving to disk. You can add as many
|
118
|
+
// Add a comment to hash table before saving to disk. You can add as many
|
119
119
|
// comment lines as you like. These comment lines are discarded when loading
|
120
|
-
// the file. If you use a null format, all comments are deleted.
|
120
|
+
// the file. If you use a null format, all comments are deleted.
|
121
121
|
CZMQ_EXPORT void
|
122
122
|
zhash_comment (zhash_t *self, const char *format, ...) CHECK_PRINTF (2);
|
123
123
|
|
124
124
|
// Serialize hash table to a binary frame that can be sent in a message.
|
125
125
|
// The packed format is compatible with the 'dictionary' type defined in
|
126
|
-
// http://rfc.zeromq.org/spec:35/FILEMQ, and implemented by zproto:
|
127
|
-
//
|
128
|
-
// ; A list of name/value pairs
|
129
|
-
// dictionary = dict-count *( dict-name dict-value )
|
130
|
-
// dict-count = number-4
|
131
|
-
// dict-value = longstr
|
132
|
-
// dict-name = string
|
133
|
-
//
|
134
|
-
// ; Strings are always length + text contents
|
135
|
-
// longstr = number-4 *VCHAR
|
136
|
-
// string = number-1 *VCHAR
|
137
|
-
//
|
138
|
-
// ; Numbers are unsigned integers in network byte order
|
139
|
-
// number-1 = 1OCTET
|
140
|
-
// number-4 = 4OCTET
|
141
|
-
//
|
142
|
-
// Comments are not included in the packed data. Item values MUST be
|
143
|
-
// strings.
|
126
|
+
// http://rfc.zeromq.org/spec:35/FILEMQ, and implemented by zproto:
|
127
|
+
//
|
128
|
+
// ; A list of name/value pairs
|
129
|
+
// dictionary = dict-count *( dict-name dict-value )
|
130
|
+
// dict-count = number-4
|
131
|
+
// dict-value = longstr
|
132
|
+
// dict-name = string
|
133
|
+
//
|
134
|
+
// ; Strings are always length + text contents
|
135
|
+
// longstr = number-4 *VCHAR
|
136
|
+
// string = number-1 *VCHAR
|
137
|
+
//
|
138
|
+
// ; Numbers are unsigned integers in network byte order
|
139
|
+
// number-1 = 1OCTET
|
140
|
+
// number-4 = 4OCTET
|
141
|
+
//
|
142
|
+
// Comments are not included in the packed data. Item values MUST be
|
143
|
+
// strings.
|
144
144
|
// Caller owns return value and must destroy it when done.
|
145
145
|
CZMQ_EXPORT zframe_t *
|
146
146
|
zhash_pack (zhash_t *self);
|
147
147
|
|
148
148
|
// Save hash table to a text file in name=value format. Hash values must be
|
149
|
-
// printable strings; keys may not contain '=' character. Returns 0 if OK,
|
150
|
-
// else -1 if a file error occurred.
|
149
|
+
// printable strings; keys may not contain '=' character. Returns 0 if OK,
|
150
|
+
// else -1 if a file error occurred.
|
151
151
|
CZMQ_EXPORT int
|
152
152
|
zhash_save (zhash_t *self, const char *filename);
|
153
153
|
|
154
|
-
// Load hash table from a text file in name=value format; hash table must
|
154
|
+
// Load hash table from a text file in name=value format; hash table must
|
155
155
|
// already exist. Hash values must printable strings; keys may not contain
|
156
|
-
// '=' character. Returns 0 if OK, else -1 if a file was not readable.
|
156
|
+
// '=' character. Returns 0 if OK, else -1 if a file was not readable.
|
157
157
|
CZMQ_EXPORT int
|
158
158
|
zhash_load (zhash_t *self, const char *filename);
|
159
159
|
|
160
160
|
// When a hash table was loaded from a file by zhash_load, this method will
|
161
161
|
// reload the file if it has been modified since, and is "stable", i.e. not
|
162
|
-
// still changing. Returns 0 if OK, -1 if there was an error reloading the
|
163
|
-
// file.
|
162
|
+
// still changing. Returns 0 if OK, -1 if there was an error reloading the
|
163
|
+
// file.
|
164
164
|
CZMQ_EXPORT int
|
165
165
|
zhash_refresh (zhash_t *self);
|
166
166
|
|
167
167
|
// Set hash for automatic value destruction. Note that this assumes that
|
168
|
-
// values are NULL-terminated strings. Do not use with different types.
|
168
|
+
// values are NULL-terminated strings. Do not use with different types.
|
169
169
|
CZMQ_EXPORT void
|
170
170
|
zhash_autofree (zhash_t *self);
|
171
171
|
|
@@ -46,12 +46,12 @@ typedef void (zhashx_free_fn) (
|
|
46
46
|
typedef size_t (zhashx_hash_fn) (
|
47
47
|
const void *key);
|
48
48
|
|
49
|
-
// Serializes an item to a longstr.
|
49
|
+
// Serializes an item to a longstr.
|
50
50
|
// The caller takes ownership of the newly created object.
|
51
51
|
typedef char * (zhashx_serializer_fn) (
|
52
52
|
const void *item);
|
53
53
|
|
54
|
-
// Deserializes a longstr into an item.
|
54
|
+
// Deserializes a longstr into an item.
|
55
55
|
// The caller takes ownership of the newly created object.
|
56
56
|
typedef void * (zhashx_deserializer_fn) (
|
57
57
|
const char *item_str);
|
@@ -61,8 +61,8 @@ CZMQ_EXPORT zhashx_t *
|
|
61
61
|
zhashx_new (void);
|
62
62
|
|
63
63
|
// Unpack binary frame into a new hash table. Packed data must follow format
|
64
|
-
// defined by zhashx_pack. Hash table is set to autofree. An empty frame
|
65
|
-
// unpacks to an empty hash table.
|
64
|
+
// defined by zhashx_pack. Hash table is set to autofree. An empty frame
|
65
|
+
// unpacks to an empty hash table.
|
66
66
|
CZMQ_EXPORT zhashx_t *
|
67
67
|
zhashx_unpack (zframe_t *frame);
|
68
68
|
|
@@ -70,28 +70,28 @@ CZMQ_EXPORT zhashx_t *
|
|
70
70
|
CZMQ_EXPORT void
|
71
71
|
zhashx_destroy (zhashx_t **self_p);
|
72
72
|
|
73
|
-
// Insert item into hash table with specified key and item.
|
73
|
+
// Insert item into hash table with specified key and item.
|
74
74
|
// If key is already present returns -1 and leaves existing item unchanged
|
75
|
-
// Returns 0 on success.
|
75
|
+
// Returns 0 on success.
|
76
76
|
CZMQ_EXPORT int
|
77
77
|
zhashx_insert (zhashx_t *self, const void *key, void *item);
|
78
78
|
|
79
79
|
// Update or insert item into hash table with specified key and item. If the
|
80
80
|
// key is already present, destroys old item and inserts new one. If you set
|
81
|
-
// a container item destructor, this is called on the old value. If the key
|
82
|
-
// was not already present, inserts a new item. Sets the hash cursor to the
|
83
|
-
// new item.
|
81
|
+
// a container item destructor, this is called on the old value. If the key
|
82
|
+
// was not already present, inserts a new item. Sets the hash cursor to the
|
83
|
+
// new item.
|
84
84
|
CZMQ_EXPORT void
|
85
85
|
zhashx_update (zhashx_t *self, const void *key, void *item);
|
86
86
|
|
87
87
|
// Remove an item specified by key from the hash table. If there was no such
|
88
|
-
// item, this function does nothing.
|
88
|
+
// item, this function does nothing.
|
89
89
|
CZMQ_EXPORT void
|
90
90
|
zhashx_delete (zhashx_t *self, const void *key);
|
91
91
|
|
92
|
-
// Delete all items from the hash table. If the key destructor is
|
92
|
+
// Delete all items from the hash table. If the key destructor is
|
93
93
|
// set, calls it on every key. If the item destructor is set, calls
|
94
|
-
// it on every item.
|
94
|
+
// it on every item.
|
95
95
|
CZMQ_EXPORT void
|
96
96
|
zhashx_purge (zhashx_t *self);
|
97
97
|
|
@@ -100,15 +100,15 @@ CZMQ_EXPORT void *
|
|
100
100
|
zhashx_lookup (zhashx_t *self, const void *key);
|
101
101
|
|
102
102
|
// Reindexes an item from an old key to a new key. If there was no such
|
103
|
-
// item, does nothing. Returns 0 if successful, else -1.
|
103
|
+
// item, does nothing. Returns 0 if successful, else -1.
|
104
104
|
CZMQ_EXPORT int
|
105
105
|
zhashx_rename (zhashx_t *self, const void *old_key, const void *new_key);
|
106
106
|
|
107
107
|
// Set a free function for the specified hash table item. When the item is
|
108
|
-
// destroyed, the free function, if any, is called on that item.
|
109
|
-
// Use this when hash items are dynamically allocated, to ensure that
|
110
|
-
// you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
|
111
|
-
// Returns the item, or NULL if there is no such item.
|
108
|
+
// destroyed, the free function, if any, is called on that item.
|
109
|
+
// Use this when hash items are dynamically allocated, to ensure that
|
110
|
+
// you don't have memory leaks. You can pass 'free' or NULL as a free_fn.
|
111
|
+
// Returns the item, or NULL if there is no such item.
|
112
112
|
CZMQ_EXPORT void *
|
113
113
|
zhashx_freefn (zhashx_t *self, const void *key, zhashx_free_fn free_fn);
|
114
114
|
|
@@ -116,95 +116,95 @@ CZMQ_EXPORT void *
|
|
116
116
|
CZMQ_EXPORT size_t
|
117
117
|
zhashx_size (zhashx_t *self);
|
118
118
|
|
119
|
-
// Return a zlistx_t containing the keys for the items in the
|
119
|
+
// Return a zlistx_t containing the keys for the items in the
|
120
120
|
// table. Uses the key_duplicator to duplicate all keys and sets the
|
121
|
-
// key_destructor as destructor for the list.
|
121
|
+
// key_destructor as destructor for the list.
|
122
122
|
// Caller owns return value and must destroy it when done.
|
123
123
|
CZMQ_EXPORT zlistx_t *
|
124
124
|
zhashx_keys (zhashx_t *self);
|
125
125
|
|
126
|
-
// Return a zlistx_t containing the values for the items in the
|
126
|
+
// Return a zlistx_t containing the values for the items in the
|
127
127
|
// table. Uses the duplicator to duplicate all items and sets the
|
128
|
-
// destructor as destructor for the list.
|
128
|
+
// destructor as destructor for the list.
|
129
129
|
// Caller owns return value and must destroy it when done.
|
130
130
|
CZMQ_EXPORT zlistx_t *
|
131
131
|
zhashx_values (zhashx_t *self);
|
132
132
|
|
133
|
-
// Simple iterator; returns first item in hash table, in no given order,
|
134
|
-
// or NULL if the table is empty. This method is simpler to use than the
|
133
|
+
// Simple iterator; returns first item in hash table, in no given order,
|
134
|
+
// or NULL if the table is empty. This method is simpler to use than the
|
135
135
|
// foreach() method, which is deprecated. To access the key for this item
|
136
|
-
// use zhashx_cursor(). NOTE: do NOT modify the table while iterating.
|
136
|
+
// use zhashx_cursor(). NOTE: do NOT modify the table while iterating.
|
137
137
|
CZMQ_EXPORT void *
|
138
138
|
zhashx_first (zhashx_t *self);
|
139
139
|
|
140
|
-
// Simple iterator; returns next item in hash table, in no given order,
|
140
|
+
// Simple iterator; returns next item in hash table, in no given order,
|
141
141
|
// or NULL if the last item was already returned. Use this together with
|
142
|
-
// zhashx_first() to process all items in a hash table. If you need the
|
143
|
-
// items in sorted order, use zhashx_keys() and then zlistx_sort(). To
|
142
|
+
// zhashx_first() to process all items in a hash table. If you need the
|
143
|
+
// items in sorted order, use zhashx_keys() and then zlistx_sort(). To
|
144
144
|
// access the key for this item use zhashx_cursor(). NOTE: do NOT modify
|
145
|
-
// the table while iterating.
|
145
|
+
// the table while iterating.
|
146
146
|
CZMQ_EXPORT void *
|
147
147
|
zhashx_next (zhashx_t *self);
|
148
148
|
|
149
149
|
// After a successful first/next method, returns the key for the item that
|
150
|
-
// was returned. This is a constant string that you may not modify or
|
151
|
-
// deallocate, and which lasts as long as the item in the hash. After an
|
152
|
-
// unsuccessful first/next, returns NULL.
|
150
|
+
// was returned. This is a constant string that you may not modify or
|
151
|
+
// deallocate, and which lasts as long as the item in the hash. After an
|
152
|
+
// unsuccessful first/next, returns NULL.
|
153
153
|
CZMQ_EXPORT const void *
|
154
154
|
zhashx_cursor (zhashx_t *self);
|
155
155
|
|
156
|
-
// Add a comment to hash table before saving to disk. You can add as many
|
156
|
+
// Add a comment to hash table before saving to disk. You can add as many
|
157
157
|
// comment lines as you like. These comment lines are discarded when loading
|
158
|
-
// the file. If you use a null format, all comments are deleted.
|
158
|
+
// the file. If you use a null format, all comments are deleted.
|
159
159
|
CZMQ_EXPORT void
|
160
160
|
zhashx_comment (zhashx_t *self, const char *format, ...) CHECK_PRINTF (2);
|
161
161
|
|
162
162
|
// Save hash table to a text file in name=value format. Hash values must be
|
163
|
-
// printable strings; keys may not contain '=' character. Returns 0 if OK,
|
164
|
-
// else -1 if a file error occurred.
|
163
|
+
// printable strings; keys may not contain '=' character. Returns 0 if OK,
|
164
|
+
// else -1 if a file error occurred.
|
165
165
|
CZMQ_EXPORT int
|
166
166
|
zhashx_save (zhashx_t *self, const char *filename);
|
167
167
|
|
168
|
-
// Load hash table from a text file in name=value format; hash table must
|
168
|
+
// Load hash table from a text file in name=value format; hash table must
|
169
169
|
// already exist. Hash values must printable strings; keys may not contain
|
170
|
-
// '=' character. Returns 0 if OK, else -1 if a file was not readable.
|
170
|
+
// '=' character. Returns 0 if OK, else -1 if a file was not readable.
|
171
171
|
CZMQ_EXPORT int
|
172
172
|
zhashx_load (zhashx_t *self, const char *filename);
|
173
173
|
|
174
174
|
// When a hash table was loaded from a file by zhashx_load, this method will
|
175
|
-
// reload the file if it has been modified since, and is "stable", i.e. not
|
176
|
-
// still changing. Returns 0 if OK, -1 if there was an error reloading the
|
177
|
-
// file.
|
175
|
+
// reload the file if it has been modified since, and is "stable", i.e. not
|
176
|
+
// still changing. Returns 0 if OK, -1 if there was an error reloading the
|
177
|
+
// file.
|
178
178
|
CZMQ_EXPORT int
|
179
179
|
zhashx_refresh (zhashx_t *self);
|
180
180
|
|
181
181
|
// Serialize hash table to a binary frame that can be sent in a message.
|
182
182
|
// The packed format is compatible with the 'dictionary' type defined in
|
183
|
-
// http://rfc.zeromq.org/spec:35/FILEMQ, and implemented by zproto:
|
184
|
-
//
|
185
|
-
// ; A list of name/value pairs
|
186
|
-
// dictionary = dict-count *( dict-name dict-value )
|
187
|
-
// dict-count = number-4
|
188
|
-
// dict-value = longstr
|
189
|
-
// dict-name = string
|
190
|
-
//
|
191
|
-
// ; Strings are always length + text contents
|
192
|
-
// longstr = number-4 *VCHAR
|
193
|
-
// string = number-1 *VCHAR
|
194
|
-
//
|
195
|
-
// ; Numbers are unsigned integers in network byte order
|
196
|
-
// number-1 = 1OCTET
|
197
|
-
// number-4 = 4OCTET
|
198
|
-
//
|
199
|
-
// Comments are not included in the packed data. Item values MUST be
|
200
|
-
// strings.
|
183
|
+
// http://rfc.zeromq.org/spec:35/FILEMQ, and implemented by zproto:
|
184
|
+
//
|
185
|
+
// ; A list of name/value pairs
|
186
|
+
// dictionary = dict-count *( dict-name dict-value )
|
187
|
+
// dict-count = number-4
|
188
|
+
// dict-value = longstr
|
189
|
+
// dict-name = string
|
190
|
+
//
|
191
|
+
// ; Strings are always length + text contents
|
192
|
+
// longstr = number-4 *VCHAR
|
193
|
+
// string = number-1 *VCHAR
|
194
|
+
//
|
195
|
+
// ; Numbers are unsigned integers in network byte order
|
196
|
+
// number-1 = 1OCTET
|
197
|
+
// number-4 = 4OCTET
|
198
|
+
//
|
199
|
+
// Comments are not included in the packed data. Item values MUST be
|
200
|
+
// strings.
|
201
201
|
// Caller owns return value and must destroy it when done.
|
202
202
|
CZMQ_EXPORT zframe_t *
|
203
203
|
zhashx_pack (zhashx_t *self);
|
204
204
|
|
205
|
-
// Make a copy of the list; items are duplicated if you set a duplicator
|
206
|
-
// for the list, otherwise not. Copying a null reference returns a null
|
207
|
-
// reference. Note that this method's behavior changed slightly for CZMQ
|
205
|
+
// Make a copy of the list; items are duplicated if you set a duplicator
|
206
|
+
// for the list, otherwise not. Copying a null reference returns a null
|
207
|
+
// reference. Note that this method's behavior changed slightly for CZMQ
|
208
208
|
// v3.x, as it does not set nor respect autofree. It does however let you
|
209
209
|
// duplicate any hash table safely. The old behavior is in zhashx_dup_v2.
|
210
210
|
// Caller owns return value and must destroy it when done.
|
@@ -212,39 +212,41 @@ CZMQ_EXPORT zhashx_t *
|
|
212
212
|
zhashx_dup (zhashx_t *self);
|
213
213
|
|
214
214
|
// Set a user-defined deallocator for hash items; by default items are not
|
215
|
-
// freed when the hash is destroyed.
|
215
|
+
// freed when the hash is destroyed.
|
216
216
|
CZMQ_EXPORT void
|
217
217
|
zhashx_set_destructor (zhashx_t *self, zhashx_destructor_fn destructor);
|
218
218
|
|
219
219
|
// Set a user-defined duplicator for hash items; by default items are not
|
220
|
-
// copied when the hash is duplicated.
|
220
|
+
// copied when the hash is duplicated.
|
221
221
|
CZMQ_EXPORT void
|
222
222
|
zhashx_set_duplicator (zhashx_t *self, zhashx_duplicator_fn duplicator);
|
223
223
|
|
224
224
|
// Set a user-defined deallocator for keys; by default keys are freed
|
225
|
-
// when the hash is destroyed using free().
|
225
|
+
// when the hash is destroyed using free().
|
226
226
|
CZMQ_EXPORT void
|
227
227
|
zhashx_set_key_destructor (zhashx_t *self, zhashx_destructor_fn destructor);
|
228
228
|
|
229
229
|
// Set a user-defined duplicator for keys; by default keys are duplicated
|
230
|
-
// using strdup.
|
230
|
+
// using strdup.
|
231
231
|
CZMQ_EXPORT void
|
232
232
|
zhashx_set_key_duplicator (zhashx_t *self, zhashx_duplicator_fn duplicator);
|
233
233
|
|
234
234
|
// Set a user-defined comparator for keys; by default keys are
|
235
|
-
// compared using strcmp.
|
235
|
+
// compared using strcmp.
|
236
|
+
// The callback function should return zero (0) on matching
|
237
|
+
// items.
|
236
238
|
CZMQ_EXPORT void
|
237
239
|
zhashx_set_key_comparator (zhashx_t *self, zhashx_comparator_fn comparator);
|
238
240
|
|
239
|
-
// Set a user-defined
|
240
|
-
//
|
241
|
+
// Set a user-defined hash function for keys; by default keys are
|
242
|
+
// hashed by a modified Bernstein hashing function.
|
241
243
|
CZMQ_EXPORT void
|
242
244
|
zhashx_set_key_hasher (zhashx_t *self, zhashx_hash_fn hasher);
|
243
245
|
|
244
|
-
// Make copy of hash table; if supplied table is null, returns null.
|
245
|
-
// Does not copy items themselves. Rebuilds new table so may be slow on
|
246
|
+
// Make copy of hash table; if supplied table is null, returns null.
|
247
|
+
// Does not copy items themselves. Rebuilds new table so may be slow on
|
246
248
|
// very large tables. NOTE: only works with item values that are strings
|
247
|
-
// since there's no other way to know how to duplicate the item value.
|
249
|
+
// since there's no other way to know how to duplicate the item value.
|
248
250
|
CZMQ_EXPORT zhashx_t *
|
249
251
|
zhashx_dup_v2 (zhashx_t *self);
|
250
252
|
|
@@ -255,13 +257,13 @@ CZMQ_EXPORT void
|
|
255
257
|
#ifdef CZMQ_BUILD_DRAFT_API
|
256
258
|
// *** Draft method, for development use, may change without warning ***
|
257
259
|
// Same as unpack but uses a user-defined deserializer function to convert
|
258
|
-
// a longstr back into item format.
|
260
|
+
// a longstr back into item format.
|
259
261
|
CZMQ_EXPORT zhashx_t *
|
260
262
|
zhashx_unpack_own (zframe_t *frame, zhashx_deserializer_fn deserializer);
|
261
263
|
|
262
264
|
// *** Draft method, for development use, may change without warning ***
|
263
265
|
// Same as pack but uses a user-defined serializer function to convert items
|
264
|
-
// into longstr.
|
266
|
+
// into longstr.
|
265
267
|
// Caller owns return value and must destroy it when done.
|
266
268
|
CZMQ_EXPORT zframe_t *
|
267
269
|
zhashx_pack_own (zhashx_t *self, zhashx_serializer_fn serializer);
|