czmq-ffi-gen 0.9.1-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/AUTHORS +1 -0
- data/CHANGES.md +88 -0
- data/Gemfile +2 -0
- data/LICENSE +14 -0
- data/README.md +112 -0
- data/lib/czmq-ffi-gen.rb +7 -0
- data/lib/czmq-ffi-gen/czmq/ffi.rb +1210 -0
- data/lib/czmq-ffi-gen/czmq/ffi/version.rb +15 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zactor.rb +186 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zarmour.rb +286 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zcert.rb +307 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zcertstore.rb +222 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zchunk.rb +388 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zclock.rb +140 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zconfig.rb +442 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zdigest.rb +156 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zdir.rb +283 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zdir_patch.rb +194 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zfile.rb +353 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zframe.rb +359 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zhash.rb +416 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zhashx.rb +659 -0
- data/lib/czmq-ffi-gen/czmq/ffi/ziflist.rb +189 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zlist.rb +365 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zlistx.rb +478 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zloop.rb +396 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zmsg.rb +515 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zpoller.rb +194 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zproc.rb +294 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zsock.rb +3479 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zstr.rb +203 -0
- data/lib/czmq-ffi-gen/czmq/ffi/ztimerset.rb +203 -0
- data/lib/czmq-ffi-gen/czmq/ffi/ztrie.rb +221 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zuuid.rb +227 -0
- data/lib/czmq-ffi-gen/errors.rb +12 -0
- data/lib/czmq-ffi-gen/gem_version.rb +5 -0
- data/lib/czmq-ffi-gen/legacy.rb +16 -0
- data/lib/czmq-ffi-gen/libzmq.rb +18 -0
- data/lib/czmq-ffi-gen/signals.rb +27 -0
- data/lib/czmq-ffi-gen/vendor.rb +5 -0
- data/lib/czmq-ffi-gen/versions.rb +19 -0
- 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/libgcc_s_sjlj-1.dll +0 -0
- data/vendor/local/bin/libstdc++-6.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/include/czmq.h +31 -0
- data/vendor/local/include/czmq_library.h +199 -0
- data/vendor/local/include/czmq_prelude.h +641 -0
- data/vendor/local/include/readme.txt +83 -0
- data/vendor/local/include/sha1.h +76 -0
- data/vendor/local/include/sha1.inc_c +335 -0
- data/vendor/local/include/slre.h +92 -0
- data/vendor/local/include/slre.inc_c +660 -0
- data/vendor/local/include/zactor.h +76 -0
- data/vendor/local/include/zarmour.h +114 -0
- data/vendor/local/include/zauth.h +100 -0
- data/vendor/local/include/zauth_v2.h +88 -0
- data/vendor/local/include/zbeacon.h +86 -0
- data/vendor/local/include/zbeacon_v2.h +75 -0
- data/vendor/local/include/zcert.h +136 -0
- data/vendor/local/include/zcertstore.h +100 -0
- data/vendor/local/include/zchunk.h +163 -0
- data/vendor/local/include/zclock.h +73 -0
- data/vendor/local/include/zconfig.h +185 -0
- data/vendor/local/include/zctx.h +107 -0
- data/vendor/local/include/zdigest.h +65 -0
- data/vendor/local/include/zdir.h +149 -0
- data/vendor/local/include/zdir_patch.h +82 -0
- data/vendor/local/include/zfile.h +177 -0
- data/vendor/local/include/zframe.h +176 -0
- data/vendor/local/include/zgossip.h +95 -0
- data/vendor/local/include/zgossip_engine.inc +927 -0
- data/vendor/local/include/zgossip_msg.h +129 -0
- data/vendor/local/include/zhash.h +195 -0
- data/vendor/local/include/zhash_primes.inc +329 -0
- data/vendor/local/include/zhashx.h +298 -0
- data/vendor/local/include/ziflist.h +77 -0
- data/vendor/local/include/zlist.h +158 -0
- data/vendor/local/include/zlistx.h +205 -0
- data/vendor/local/include/zloop.h +168 -0
- data/vendor/local/include/zmonitor.h +73 -0
- data/vendor/local/include/zmonitor_v2.h +56 -0
- data/vendor/local/include/zmq.h +617 -0
- data/vendor/local/include/zmq_utils.h +48 -0
- data/vendor/local/include/zmsg.h +280 -0
- data/vendor/local/include/zmutex.h +55 -0
- data/vendor/local/include/zpoller.h +92 -0
- data/vendor/local/include/zproc.h +168 -0
- data/vendor/local/include/zproxy.h +111 -0
- data/vendor/local/include/zproxy_v2.h +62 -0
- data/vendor/local/include/zrex.h +82 -0
- data/vendor/local/include/zsock.h +912 -0
- data/vendor/local/include/zsock_option.inc +4126 -0
- data/vendor/local/include/zsocket.h +110 -0
- data/vendor/local/include/zsockopt.h +256 -0
- data/vendor/local/include/zstr.h +110 -0
- data/vendor/local/include/zsys.h +386 -0
- data/vendor/local/include/zthread.h +50 -0
- data/vendor/local/include/ztimerset.h +90 -0
- data/vendor/local/include/ztrie.h +106 -0
- data/vendor/local/include/zuuid.h +96 -0
- data/vendor/local/lib/libczmq.dll.a +0 -0
- data/vendor/local/lib/liblibzmq.dll.a +0 -0
- data/vendor/local/lib/libzmq-static.a +0 -0
- data/vendor/local/lib/pkgconfig/libczmq.pc +23 -0
- data/vendor/local/lib/pkgconfig/libzmq.pc +11 -0
- data/vendor/local/share/zmq/AUTHORS.txt +147 -0
- data/vendor/local/share/zmq/COPYING.LESSER.txt +181 -0
- data/vendor/local/share/zmq/COPYING.txt +674 -0
- data/vendor/local/share/zmq/NEWS.txt +978 -0
- metadata +230 -0
@@ -0,0 +1,82 @@
|
|
1
|
+
/* =========================================================================
|
2
|
+
zdir_patch - work with directory patches
|
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
|
+
|
8
|
+
This Source Code Form is subject to the terms of the Mozilla Public
|
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/.
|
11
|
+
=========================================================================
|
12
|
+
*/
|
13
|
+
|
14
|
+
#ifndef __ZDIR_PATCH_H_INCLUDED__
|
15
|
+
#define __ZDIR_PATCH_H_INCLUDED__
|
16
|
+
|
17
|
+
#ifdef __cplusplus
|
18
|
+
extern "C" {
|
19
|
+
#endif
|
20
|
+
|
21
|
+
// un-namespaced enumeration values
|
22
|
+
#define patch_create ZDIR_PATCH_CREATE
|
23
|
+
#define patch_delete ZDIR_PATCH_DELETE
|
24
|
+
|
25
|
+
// @warning THE FOLLOWING @INTERFACE BLOCK IS AUTO-GENERATED BY ZPROJECT
|
26
|
+
// @warning Please edit the model at "api/zdir_patch.api" to make changes.
|
27
|
+
// @interface
|
28
|
+
// This is a stable class, and may not change except for emergencies. It
|
29
|
+
// is provided in stable builds.
|
30
|
+
#define ZDIR_PATCH_CREATE 1 // Creates a new file
|
31
|
+
#define ZDIR_PATCH_DELETE 2 // Delete a file
|
32
|
+
|
33
|
+
// Create new patch
|
34
|
+
CZMQ_EXPORT zdir_patch_t *
|
35
|
+
zdir_patch_new (const char *path, zfile_t *file, int op, const char *alias);
|
36
|
+
|
37
|
+
// Destroy a patch
|
38
|
+
CZMQ_EXPORT void
|
39
|
+
zdir_patch_destroy (zdir_patch_t **self_p);
|
40
|
+
|
41
|
+
// Create copy of a patch. If the patch is null, or memory was exhausted,
|
42
|
+
// returns null.
|
43
|
+
// Caller owns return value and must destroy it when done.
|
44
|
+
CZMQ_EXPORT zdir_patch_t *
|
45
|
+
zdir_patch_dup (zdir_patch_t *self);
|
46
|
+
|
47
|
+
// Return patch file directory path
|
48
|
+
CZMQ_EXPORT const char *
|
49
|
+
zdir_patch_path (zdir_patch_t *self);
|
50
|
+
|
51
|
+
// Return patch file item
|
52
|
+
CZMQ_EXPORT zfile_t *
|
53
|
+
zdir_patch_file (zdir_patch_t *self);
|
54
|
+
|
55
|
+
// Return operation
|
56
|
+
CZMQ_EXPORT int
|
57
|
+
zdir_patch_op (zdir_patch_t *self);
|
58
|
+
|
59
|
+
// Return patch virtual file path
|
60
|
+
CZMQ_EXPORT const char *
|
61
|
+
zdir_patch_vpath (zdir_patch_t *self);
|
62
|
+
|
63
|
+
// Calculate hash digest for file (create only)
|
64
|
+
CZMQ_EXPORT void
|
65
|
+
zdir_patch_digest_set (zdir_patch_t *self);
|
66
|
+
|
67
|
+
// Return hash digest for patch file
|
68
|
+
CZMQ_EXPORT const char *
|
69
|
+
zdir_patch_digest (zdir_patch_t *self);
|
70
|
+
|
71
|
+
// Self test of this class.
|
72
|
+
CZMQ_EXPORT void
|
73
|
+
zdir_patch_test (bool verbose);
|
74
|
+
|
75
|
+
// @end
|
76
|
+
|
77
|
+
|
78
|
+
#ifdef __cplusplus
|
79
|
+
}
|
80
|
+
#endif
|
81
|
+
|
82
|
+
#endif
|
@@ -0,0 +1,177 @@
|
|
1
|
+
/* =========================================================================
|
2
|
+
zfile - helper functions for working with files.
|
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
|
+
|
8
|
+
This Source Code Form is subject to the terms of the Mozilla Public
|
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/.
|
11
|
+
=========================================================================
|
12
|
+
*/
|
13
|
+
|
14
|
+
#ifndef __ZFILE_H_INCLUDED__
|
15
|
+
#define __ZFILE_H_INCLUDED__
|
16
|
+
|
17
|
+
#ifdef __cplusplus
|
18
|
+
extern "C" {
|
19
|
+
#endif
|
20
|
+
|
21
|
+
// @warning THE FOLLOWING @INTERFACE BLOCK IS AUTO-GENERATED BY ZPROJECT
|
22
|
+
// @warning Please edit the model at "api/zfile.api" to make changes.
|
23
|
+
// @interface
|
24
|
+
// This is a stable class, and may not change except for emergencies. It
|
25
|
+
// is provided in stable builds.
|
26
|
+
// If file exists, populates properties. CZMQ supports portable symbolic
|
27
|
+
// links, which are files with the extension ".ln". A symbolic link is a
|
28
|
+
// text file containing one line, the filename of a target file. Reading
|
29
|
+
// data from the symbolic link actually reads from the target file. Path
|
30
|
+
// may be NULL, in which case it is not used.
|
31
|
+
CZMQ_EXPORT zfile_t *
|
32
|
+
zfile_new (const char *path, const char *name);
|
33
|
+
|
34
|
+
// Destroy a file item
|
35
|
+
CZMQ_EXPORT void
|
36
|
+
zfile_destroy (zfile_t **self_p);
|
37
|
+
|
38
|
+
// Duplicate a file item, returns a newly constructed item. If the file
|
39
|
+
// is null, or memory was exhausted, returns null.
|
40
|
+
// Caller owns return value and must destroy it when done.
|
41
|
+
CZMQ_EXPORT zfile_t *
|
42
|
+
zfile_dup (zfile_t *self);
|
43
|
+
|
44
|
+
// Return file name, remove path if provided
|
45
|
+
CZMQ_EXPORT const char *
|
46
|
+
zfile_filename (zfile_t *self, const char *path);
|
47
|
+
|
48
|
+
// Refresh file properties from disk; this is not done automatically
|
49
|
+
// on access methods, otherwise it is not possible to compare directory
|
50
|
+
// snapshots.
|
51
|
+
CZMQ_EXPORT void
|
52
|
+
zfile_restat (zfile_t *self);
|
53
|
+
|
54
|
+
// Return when the file was last modified. If you want this to reflect the
|
55
|
+
// current situation, call zfile_restat before checking this property.
|
56
|
+
CZMQ_EXPORT time_t
|
57
|
+
zfile_modified (zfile_t *self);
|
58
|
+
|
59
|
+
// Return the last-known size of the file. If you want this to reflect the
|
60
|
+
// current situation, call zfile_restat before checking this property.
|
61
|
+
CZMQ_EXPORT off_t
|
62
|
+
zfile_cursize (zfile_t *self);
|
63
|
+
|
64
|
+
// Return true if the file is a directory. If you want this to reflect
|
65
|
+
// any external changes, call zfile_restat before checking this property.
|
66
|
+
CZMQ_EXPORT bool
|
67
|
+
zfile_is_directory (zfile_t *self);
|
68
|
+
|
69
|
+
// Return true if the file is a regular file. If you want this to reflect
|
70
|
+
// any external changes, call zfile_restat before checking this property.
|
71
|
+
CZMQ_EXPORT bool
|
72
|
+
zfile_is_regular (zfile_t *self);
|
73
|
+
|
74
|
+
// Return true if the file is readable by this process. If you want this to
|
75
|
+
// reflect any external changes, call zfile_restat before checking this
|
76
|
+
// property.
|
77
|
+
CZMQ_EXPORT bool
|
78
|
+
zfile_is_readable (zfile_t *self);
|
79
|
+
|
80
|
+
// Return true if the file is writeable by this process. If you want this
|
81
|
+
// to reflect any external changes, call zfile_restat before checking this
|
82
|
+
// property.
|
83
|
+
CZMQ_EXPORT bool
|
84
|
+
zfile_is_writeable (zfile_t *self);
|
85
|
+
|
86
|
+
// Check if file has stopped changing and can be safely processed.
|
87
|
+
// Updates the file statistics from disk at every call.
|
88
|
+
CZMQ_EXPORT bool
|
89
|
+
zfile_is_stable (zfile_t *self);
|
90
|
+
|
91
|
+
// Return true if the file was changed on disk since the zfile_t object
|
92
|
+
// was created, or the last zfile_restat() call made on it.
|
93
|
+
CZMQ_EXPORT bool
|
94
|
+
zfile_has_changed (zfile_t *self);
|
95
|
+
|
96
|
+
// Remove the file from disk
|
97
|
+
CZMQ_EXPORT void
|
98
|
+
zfile_remove (zfile_t *self);
|
99
|
+
|
100
|
+
// Open file for reading
|
101
|
+
// Returns 0 if OK, -1 if not found or not accessible
|
102
|
+
CZMQ_EXPORT int
|
103
|
+
zfile_input (zfile_t *self);
|
104
|
+
|
105
|
+
// Open file for writing, creating directory if needed
|
106
|
+
// File is created if necessary; chunks can be written to file at any
|
107
|
+
// location. Returns 0 if OK, -1 if error.
|
108
|
+
CZMQ_EXPORT int
|
109
|
+
zfile_output (zfile_t *self);
|
110
|
+
|
111
|
+
// Read chunk from file at specified position. If this was the last chunk,
|
112
|
+
// sets the eof property. Returns a null chunk in case of error.
|
113
|
+
// Caller owns return value and must destroy it when done.
|
114
|
+
CZMQ_EXPORT zchunk_t *
|
115
|
+
zfile_read (zfile_t *self, size_t bytes, off_t offset);
|
116
|
+
|
117
|
+
// Returns true if zfile_read() just read the last chunk in the file.
|
118
|
+
CZMQ_EXPORT bool
|
119
|
+
zfile_eof (zfile_t *self);
|
120
|
+
|
121
|
+
// Write chunk to file at specified position
|
122
|
+
// Return 0 if OK, else -1
|
123
|
+
CZMQ_EXPORT int
|
124
|
+
zfile_write (zfile_t *self, zchunk_t *chunk, off_t offset);
|
125
|
+
|
126
|
+
// Read next line of text from file. Returns a pointer to the text line,
|
127
|
+
// or NULL if there was nothing more to read from the file.
|
128
|
+
CZMQ_EXPORT const char *
|
129
|
+
zfile_readln (zfile_t *self);
|
130
|
+
|
131
|
+
// Close file, if open
|
132
|
+
CZMQ_EXPORT void
|
133
|
+
zfile_close (zfile_t *self);
|
134
|
+
|
135
|
+
// Return file handle, if opened
|
136
|
+
CZMQ_EXPORT FILE *
|
137
|
+
zfile_handle (zfile_t *self);
|
138
|
+
|
139
|
+
// Calculate SHA1 digest for file, using zdigest class.
|
140
|
+
CZMQ_EXPORT const char *
|
141
|
+
zfile_digest (zfile_t *self);
|
142
|
+
|
143
|
+
// Self test of this class.
|
144
|
+
CZMQ_EXPORT void
|
145
|
+
zfile_test (bool verbose);
|
146
|
+
|
147
|
+
// @end
|
148
|
+
|
149
|
+
|
150
|
+
// @interface
|
151
|
+
// These methods are deprecated, and now moved to zsys class.
|
152
|
+
CZMQ_EXPORT bool
|
153
|
+
zfile_exists (const char *filename);
|
154
|
+
CZMQ_EXPORT ssize_t
|
155
|
+
zfile_size (const char *filename);
|
156
|
+
CZMQ_EXPORT mode_t
|
157
|
+
zfile_mode (const char *filename);
|
158
|
+
CZMQ_EXPORT int
|
159
|
+
zfile_delete (const char *filename);
|
160
|
+
CZMQ_EXPORT bool
|
161
|
+
zfile_stable (const char *filename);
|
162
|
+
CZMQ_EXPORT int
|
163
|
+
zfile_mkdir (const char *pathname);
|
164
|
+
CZMQ_EXPORT int
|
165
|
+
zfile_rmdir (const char *pathname);
|
166
|
+
CZMQ_EXPORT void
|
167
|
+
zfile_mode_private (void);
|
168
|
+
CZMQ_EXPORT void
|
169
|
+
zfile_mode_default (void);
|
170
|
+
// @end
|
171
|
+
|
172
|
+
#ifdef __cplusplus
|
173
|
+
}
|
174
|
+
#endif
|
175
|
+
|
176
|
+
|
177
|
+
#endif // __ZFILE_H_INCLUDED__
|
@@ -0,0 +1,176 @@
|
|
1
|
+
/* =========================================================================
|
2
|
+
zframe - working with single message frames
|
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
|
+
|
8
|
+
This Source Code Form is subject to the terms of the Mozilla Public
|
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/.
|
11
|
+
=========================================================================
|
12
|
+
*/
|
13
|
+
|
14
|
+
#ifndef __ZFRAME_H_INCLUDED__
|
15
|
+
#define __ZFRAME_H_INCLUDED__
|
16
|
+
|
17
|
+
#ifdef __cplusplus
|
18
|
+
extern "C" {
|
19
|
+
#endif
|
20
|
+
|
21
|
+
// @warning THE FOLLOWING @INTERFACE BLOCK IS AUTO-GENERATED BY ZPROJECT
|
22
|
+
// @warning Please edit the model at "api/zframe.api" to make changes.
|
23
|
+
// @interface
|
24
|
+
// This is a stable class, and may not change except for emergencies. It
|
25
|
+
// is provided in stable builds.
|
26
|
+
// This class has draft methods, which may change over time. They are not
|
27
|
+
// in stable releases, by default. Use --enable-drafts to enable.
|
28
|
+
#define ZFRAME_MORE 1 //
|
29
|
+
#define ZFRAME_REUSE 2 //
|
30
|
+
#define ZFRAME_DONTWAIT 4 //
|
31
|
+
|
32
|
+
// Create a new frame. If size is not null, allocates the frame data
|
33
|
+
// to the specified size. If additionally, data is not null, copies
|
34
|
+
// size octets from the specified data into the frame body.
|
35
|
+
CZMQ_EXPORT zframe_t *
|
36
|
+
zframe_new (const void *data, size_t size);
|
37
|
+
|
38
|
+
// Create an empty (zero-sized) frame
|
39
|
+
CZMQ_EXPORT zframe_t *
|
40
|
+
zframe_new_empty (void);
|
41
|
+
|
42
|
+
// Create a frame with a specified string content.
|
43
|
+
CZMQ_EXPORT zframe_t *
|
44
|
+
zframe_from (const char *string);
|
45
|
+
|
46
|
+
// Receive frame from socket, returns zframe_t object or NULL if the recv
|
47
|
+
// was interrupted. Does a blocking recv, if you want to not block then use
|
48
|
+
// zpoller or zloop.
|
49
|
+
CZMQ_EXPORT zframe_t *
|
50
|
+
zframe_recv (void *source);
|
51
|
+
|
52
|
+
// Destroy a frame
|
53
|
+
CZMQ_EXPORT void
|
54
|
+
zframe_destroy (zframe_t **self_p);
|
55
|
+
|
56
|
+
// Send a frame to a socket, destroy frame after sending.
|
57
|
+
// Return -1 on error, 0 on success.
|
58
|
+
CZMQ_EXPORT int
|
59
|
+
zframe_send (zframe_t **self_p, void *dest, int flags);
|
60
|
+
|
61
|
+
// Return number of bytes in frame data
|
62
|
+
CZMQ_EXPORT size_t
|
63
|
+
zframe_size (zframe_t *self);
|
64
|
+
|
65
|
+
// Return address of frame data
|
66
|
+
CZMQ_EXPORT byte *
|
67
|
+
zframe_data (zframe_t *self);
|
68
|
+
|
69
|
+
// Return meta data property for frame
|
70
|
+
// Caller must free string when finished with it.
|
71
|
+
CZMQ_EXPORT const char *
|
72
|
+
zframe_meta (zframe_t *self, const char *property);
|
73
|
+
|
74
|
+
// Create a new frame that duplicates an existing frame. If frame is null,
|
75
|
+
// or memory was exhausted, returns null.
|
76
|
+
// Caller owns return value and must destroy it when done.
|
77
|
+
CZMQ_EXPORT zframe_t *
|
78
|
+
zframe_dup (zframe_t *self);
|
79
|
+
|
80
|
+
// Return frame data encoded as printable hex string, useful for 0MQ UUIDs.
|
81
|
+
// Caller must free string when finished with it.
|
82
|
+
// Caller owns return value and must destroy it when done.
|
83
|
+
CZMQ_EXPORT char *
|
84
|
+
zframe_strhex (zframe_t *self);
|
85
|
+
|
86
|
+
// Return frame data copied into freshly allocated string
|
87
|
+
// Caller must free string when finished with it.
|
88
|
+
// Caller owns return value and must destroy it when done.
|
89
|
+
CZMQ_EXPORT char *
|
90
|
+
zframe_strdup (zframe_t *self);
|
91
|
+
|
92
|
+
// Return TRUE if frame body is equal to string, excluding terminator
|
93
|
+
CZMQ_EXPORT bool
|
94
|
+
zframe_streq (zframe_t *self, const char *string);
|
95
|
+
|
96
|
+
// Return frame MORE indicator (1 or 0), set when reading frame from socket
|
97
|
+
// or by the zframe_set_more() method
|
98
|
+
CZMQ_EXPORT int
|
99
|
+
zframe_more (zframe_t *self);
|
100
|
+
|
101
|
+
// Set frame MORE indicator (1 or 0). Note this is NOT used when sending
|
102
|
+
// frame to socket, you have to specify flag explicitly.
|
103
|
+
CZMQ_EXPORT void
|
104
|
+
zframe_set_more (zframe_t *self, int more);
|
105
|
+
|
106
|
+
// Return TRUE if two frames have identical size and data
|
107
|
+
// If either frame is NULL, equality is always false.
|
108
|
+
CZMQ_EXPORT bool
|
109
|
+
zframe_eq (zframe_t *self, zframe_t *other);
|
110
|
+
|
111
|
+
// Set new contents for frame
|
112
|
+
CZMQ_EXPORT void
|
113
|
+
zframe_reset (zframe_t *self, const void *data, size_t size);
|
114
|
+
|
115
|
+
// Send message to zsys log sink (may be stdout, or system facility as
|
116
|
+
// configured by zsys_set_logstream). Prefix shows before frame, if not null.
|
117
|
+
CZMQ_EXPORT void
|
118
|
+
zframe_print (zframe_t *self, const char *prefix);
|
119
|
+
|
120
|
+
// Probe the supplied object, and report if it looks like a zframe_t.
|
121
|
+
CZMQ_EXPORT bool
|
122
|
+
zframe_is (void *self);
|
123
|
+
|
124
|
+
// Self test of this class.
|
125
|
+
CZMQ_EXPORT void
|
126
|
+
zframe_test (bool verbose);
|
127
|
+
|
128
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
129
|
+
// *** Draft method, for development use, may change without warning ***
|
130
|
+
// Return frame routing ID, if the frame came from a ZMQ_SERVER socket.
|
131
|
+
// Else returns zero.
|
132
|
+
CZMQ_EXPORT uint32_t
|
133
|
+
zframe_routing_id (zframe_t *self);
|
134
|
+
|
135
|
+
// *** Draft method, for development use, may change without warning ***
|
136
|
+
// Set routing ID on frame. This is used if/when the frame is sent to a
|
137
|
+
// ZMQ_SERVER socket.
|
138
|
+
CZMQ_EXPORT void
|
139
|
+
zframe_set_routing_id (zframe_t *self, uint32_t routing_id);
|
140
|
+
|
141
|
+
// *** Draft method, for development use, may change without warning ***
|
142
|
+
// Return frame group of radio-dish pattern.
|
143
|
+
CZMQ_EXPORT const char *
|
144
|
+
zframe_group (zframe_t *self);
|
145
|
+
|
146
|
+
// *** Draft method, for development use, may change without warning ***
|
147
|
+
// Set group on frame. This is used if/when the frame is sent to a
|
148
|
+
// ZMQ_RADIO socket.
|
149
|
+
// Return -1 on error, 0 on success.
|
150
|
+
CZMQ_EXPORT int
|
151
|
+
zframe_set_group (zframe_t *self, const char *group);
|
152
|
+
|
153
|
+
#endif // CZMQ_BUILD_DRAFT_API
|
154
|
+
// @end
|
155
|
+
|
156
|
+
|
157
|
+
// DEPRECATED as poor style -- callers should use zloop or zpoller
|
158
|
+
// Receive a new frame off the socket. Returns newly allocated frame, or
|
159
|
+
// NULL if there was no input waiting, or if the read was interrupted.
|
160
|
+
CZMQ_EXPORT zframe_t *
|
161
|
+
zframe_recv_nowait (void *source);
|
162
|
+
|
163
|
+
// DEPRECATED as inconsistent; breaks principle that logging should all go
|
164
|
+
// to a single destination.
|
165
|
+
// Print contents of the frame to FILE stream.
|
166
|
+
CZMQ_EXPORT void
|
167
|
+
zframe_fprint (zframe_t *self, const char *prefix, FILE *file);
|
168
|
+
|
169
|
+
// Deprecated method aliases
|
170
|
+
#define zframe_print_to_stream(s,p,F) zframe_fprint(s,p,F)
|
171
|
+
|
172
|
+
#ifdef __cplusplus
|
173
|
+
}
|
174
|
+
#endif
|
175
|
+
|
176
|
+
#endif
|
@@ -0,0 +1,95 @@
|
|
1
|
+
/* =========================================================================
|
2
|
+
zgossip - zgossip server
|
3
|
+
|
4
|
+
** WARNING *************************************************************
|
5
|
+
THIS SOURCE FILE IS 100% GENERATED. If you edit this file, you will lose
|
6
|
+
your changes at the next build cycle. This is great for temporary printf
|
7
|
+
statements. DO NOT MAKE ANY CHANGES YOU WISH TO KEEP. The correct places
|
8
|
+
for commits are:
|
9
|
+
|
10
|
+
* The XML model used for this code generation: zgossip.xml, or
|
11
|
+
* The code generation script that built this file: zproto_server_c
|
12
|
+
************************************************************************
|
13
|
+
Copyright (c) the Contributors as noted in the AUTHORS file.
|
14
|
+
This file is part of CZMQ, the high-level C binding for 0MQ:
|
15
|
+
http://czmq.zeromq.org.
|
16
|
+
|
17
|
+
This Source Code Form is subject to the terms of the Mozilla Public
|
18
|
+
License, v. 2.0. If a copy of the MPL was not distributed with this
|
19
|
+
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
20
|
+
=========================================================================
|
21
|
+
*/
|
22
|
+
|
23
|
+
#ifndef ZGOSSIP_H_INCLUDED
|
24
|
+
#define ZGOSSIP_H_INCLUDED
|
25
|
+
|
26
|
+
#include "czmq.h"
|
27
|
+
|
28
|
+
#ifdef __cplusplus
|
29
|
+
extern "C" {
|
30
|
+
#endif
|
31
|
+
|
32
|
+
// @interface
|
33
|
+
// To work with zgossip, use the CZMQ zactor API:
|
34
|
+
//
|
35
|
+
// Create new zgossip instance, passing logging prefix:
|
36
|
+
//
|
37
|
+
// zactor_t *zgossip = zactor_new (zgossip, "myname");
|
38
|
+
//
|
39
|
+
// Destroy zgossip instance
|
40
|
+
//
|
41
|
+
// zactor_destroy (&zgossip);
|
42
|
+
//
|
43
|
+
// Enable verbose logging of commands and activity:
|
44
|
+
//
|
45
|
+
// zstr_send (zgossip, "VERBOSE");
|
46
|
+
//
|
47
|
+
// Bind zgossip to specified endpoint. TCP endpoints may specify
|
48
|
+
// the port number as "*" to aquire an ephemeral port:
|
49
|
+
//
|
50
|
+
// zstr_sendx (zgossip, "BIND", endpoint, NULL);
|
51
|
+
//
|
52
|
+
// Return assigned port number, specifically when BIND was done using an
|
53
|
+
// an ephemeral port:
|
54
|
+
//
|
55
|
+
// zstr_sendx (zgossip, "PORT", NULL);
|
56
|
+
// char *command, *port_str;
|
57
|
+
// zstr_recvx (zgossip, &command, &port_str, NULL);
|
58
|
+
// assert (streq (command, "PORT"));
|
59
|
+
//
|
60
|
+
// Specify configuration file to load, overwriting any previous loaded
|
61
|
+
// configuration file or options:
|
62
|
+
//
|
63
|
+
// zstr_sendx (zgossip, "LOAD", filename, NULL);
|
64
|
+
//
|
65
|
+
// Set configuration path value:
|
66
|
+
//
|
67
|
+
// zstr_sendx (zgossip, "SET", path, value, NULL);
|
68
|
+
//
|
69
|
+
// Save configuration data to config file on disk:
|
70
|
+
//
|
71
|
+
// zstr_sendx (zgossip, "SAVE", filename, NULL);
|
72
|
+
//
|
73
|
+
// Send zmsg_t instance to zgossip:
|
74
|
+
//
|
75
|
+
// zactor_send (zgossip, &msg);
|
76
|
+
//
|
77
|
+
// Receive zmsg_t instance from zgossip:
|
78
|
+
//
|
79
|
+
// zmsg_t *msg = zactor_recv (zgossip);
|
80
|
+
//
|
81
|
+
// This is the zgossip constructor as a zactor_fn:
|
82
|
+
//
|
83
|
+
CZMQ_EXPORT void
|
84
|
+
zgossip (zsock_t *pipe, void *args);
|
85
|
+
|
86
|
+
// Self test of this class
|
87
|
+
CZMQ_EXPORT void
|
88
|
+
zgossip_test (bool verbose);
|
89
|
+
// @end
|
90
|
+
|
91
|
+
#ifdef __cplusplus
|
92
|
+
}
|
93
|
+
#endif
|
94
|
+
|
95
|
+
#endif
|