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
@@ -132,7 +132,7 @@ module CZMQ
|
|
132
132
|
result
|
133
133
|
end
|
134
134
|
|
135
|
-
# Set timer interval. Returns 0 if OK, -1 on failure.
|
135
|
+
# Set timer interval. Returns 0 if OK, -1 on failure.
|
136
136
|
# This method is slow, canceling the timer and adding a new one yield better performance.
|
137
137
|
#
|
138
138
|
# @param timer_id [Integer, #to_int, #to_i]
|
@@ -148,7 +148,7 @@ module CZMQ
|
|
148
148
|
end
|
149
149
|
|
150
150
|
# Reset timer to start interval counting from current time. Returns 0 if OK, -1 on failure.
|
151
|
-
# This method is slow, canceling the timer and adding a new one yield better performance.
|
151
|
+
# This method is slow, canceling the timer and adding a new one yield better performance.
|
152
152
|
#
|
153
153
|
# @param timer_id [Integer, #to_int, #to_i]
|
154
154
|
# @return [Integer]
|
@@ -160,9 +160,9 @@ module CZMQ
|
|
160
160
|
result
|
161
161
|
end
|
162
162
|
|
163
|
-
# Return the time until the next interval.
|
163
|
+
# Return the time until the next interval.
|
164
164
|
# Should be used as timeout parameter for the zpoller wait method.
|
165
|
-
# The timeout is in msec.
|
165
|
+
# The timeout is in msec.
|
166
166
|
#
|
167
167
|
# @return [Integer]
|
168
168
|
def timeout()
|
@@ -173,8 +173,8 @@ module CZMQ
|
|
173
173
|
end
|
174
174
|
|
175
175
|
# Invoke callback function of all timers which their interval has elapsed.
|
176
|
-
# Should be call after zpoller wait method.
|
177
|
-
# Returns 0 if OK, -1 on failure.
|
176
|
+
# Should be call after zpoller wait method.
|
177
|
+
# Returns 0 if OK, -1 on failure.
|
178
178
|
#
|
179
179
|
# @return [Integer]
|
180
180
|
def execute()
|
@@ -76,7 +76,7 @@ module CZMQ
|
|
76
76
|
# Create a new callback of the following type:
|
77
77
|
# Callback function for ztrie_node to destroy node data.
|
78
78
|
# typedef void (ztrie_destroy_data_fn) (
|
79
|
-
# void **data);
|
79
|
+
# void **data);
|
80
80
|
#
|
81
81
|
# @note WARNING: If your Ruby code doesn't retain a reference to the
|
82
82
|
# FFI::Function object after passing it to a C function call,
|
@@ -107,9 +107,9 @@ module CZMQ
|
|
107
107
|
result
|
108
108
|
end
|
109
109
|
|
110
|
-
# Inserts a new route into the tree and attaches the data. Returns -1
|
110
|
+
# Inserts a new route into the tree and attaches the data. Returns -1
|
111
111
|
# if the route already exists, otherwise 0. This method takes ownership of
|
112
|
-
# the provided data if a destroy_data_fn is provided.
|
112
|
+
# the provided data if a destroy_data_fn is provided.
|
113
113
|
#
|
114
114
|
# @param path [String, #to_s, nil]
|
115
115
|
# @param data [::FFI::Pointer, #to_ptr]
|
@@ -123,8 +123,8 @@ module CZMQ
|
|
123
123
|
end
|
124
124
|
|
125
125
|
# Removes a route from the trie and destroys its data. Returns -1 if the
|
126
|
-
# route does not exists, otherwise 0.
|
127
|
-
# the start of the list call zlist_first (). Advances the cursor.
|
126
|
+
# route does not exists, otherwise 0.
|
127
|
+
# the start of the list call zlist_first (). Advances the cursor.
|
128
128
|
#
|
129
129
|
# @param path [String, #to_s, nil]
|
130
130
|
# @return [Integer]
|
@@ -147,8 +147,8 @@ module CZMQ
|
|
147
147
|
end
|
148
148
|
|
149
149
|
# Returns the data of a matched route from last ztrie_matches. If the path
|
150
|
-
# did not match, returns NULL. Do not delete the data as it's owned by
|
151
|
-
# ztrie.
|
150
|
+
# did not match, returns NULL. Do not delete the data as it's owned by
|
151
|
+
# ztrie.
|
152
152
|
#
|
153
153
|
# @return [::FFI::Pointer]
|
154
154
|
def hit_data()
|
@@ -168,9 +168,9 @@ module CZMQ
|
|
168
168
|
result
|
169
169
|
end
|
170
170
|
|
171
|
-
# Returns the parameters of a matched route with named regexes from last
|
171
|
+
# Returns the parameters of a matched route with named regexes from last
|
172
172
|
# ztrie_matches. If the path did not match or the route did not contain any
|
173
|
-
# named regexes, returns NULL.
|
173
|
+
# named regexes, returns NULL.
|
174
174
|
#
|
175
175
|
# @return [Zhashx]
|
176
176
|
def hit_parameters()
|
@@ -182,7 +182,7 @@ module CZMQ
|
|
182
182
|
end
|
183
183
|
|
184
184
|
# Returns the asterisk matched part of a route, if there has been no match
|
185
|
-
# or no asterisk match, returns NULL.
|
185
|
+
# or no asterisk match, returns NULL.
|
186
186
|
#
|
187
187
|
# @return [String]
|
188
188
|
def hit_asterisk_match()
|
@@ -110,7 +110,7 @@ module CZMQ
|
|
110
110
|
end
|
111
111
|
|
112
112
|
# Set UUID to new supplied string value skipping '-' and '{' '}'
|
113
|
-
# optional delimiters. Return 0 if OK, else returns -1.
|
113
|
+
# optional delimiters. Return 0 if OK, else returns -1.
|
114
114
|
#
|
115
115
|
# @param source [String, #to_s, nil]
|
116
116
|
# @return [Integer]
|
@@ -152,8 +152,8 @@ module CZMQ
|
|
152
152
|
end
|
153
153
|
|
154
154
|
# Return UUID in the canonical string format: 8-4-4-4-12, in lower
|
155
|
-
# case. Caller does not modify or free returned value. See
|
156
|
-
# http://en.wikipedia.org/wiki/Universally_unique_identifier
|
155
|
+
# case. Caller does not modify or free returned value. See
|
156
|
+
# http://en.wikipedia.org/wiki/Universally_unique_identifier
|
157
157
|
#
|
158
158
|
# @return [String]
|
159
159
|
def str_canonical()
|
@@ -197,7 +197,7 @@ module CZMQ
|
|
197
197
|
end
|
198
198
|
|
199
199
|
# Make copy of UUID object; if uuid is null, or memory was exhausted,
|
200
|
-
# returns null.
|
200
|
+
# returns null.
|
201
201
|
#
|
202
202
|
# @return [Zuuid]
|
203
203
|
def dup()
|
data/lib/czmq-ffi-gen/vendor.rb
CHANGED
@@ -1,5 +1,13 @@
|
|
1
1
|
base_dir = File.expand_path(File.join(__dir__, "..", ".."))
|
2
2
|
vendor_bin_dir = File.join(base_dir, "vendor", "local", "bin")
|
3
3
|
if File.exist?(vendor_bin_dir)
|
4
|
-
|
4
|
+
# On Windows, RubyInstaller2 uses kernel32's SetDefaultDllDirectories
|
5
|
+
# and AddDllDirectory, which disables the lookup of DLLs in the PATH, see
|
6
|
+
# https://github.com/oneclick/rubyinstaller2/wiki/For-gem-developers#dll-loading
|
7
|
+
begin
|
8
|
+
require 'ruby_installer'
|
9
|
+
RubyInstaller::Runtime.add_dll_directory vendor_bin_dir
|
10
|
+
rescue LoadError
|
11
|
+
ENV["PATH"] = [vendor_bin_dir, ENV["PATH"]].join(File::PATH_SEPARATOR)
|
12
|
+
end
|
5
13
|
end
|
Binary file
|
Binary file
|
Binary file
|
data/vendor/local/bin/libzmq.dll
CHANGED
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
@@ -1,13 +1,13 @@
|
|
1
1
|
/* =========================================================================
|
2
2
|
czmq - generated layer of public API
|
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
|
# THIS FILE IS 100% GENERATED BY ZPROJECT; DO NOT EDIT EXCEPT EXPERIMENTALLY #
|
@@ -52,7 +52,7 @@
|
|
52
52
|
# define CZMQ_PRIVATE
|
53
53
|
#else
|
54
54
|
# define CZMQ_EXPORT
|
55
|
-
# if (defined __GNUC__ && __GNUC__ >= 4) || defined __INTEL_COMPILER
|
55
|
+
# if (defined __GNUC__ && __GNUC__ >= 4 && !defined __CYGWIN__) || defined __INTEL_COMPILER
|
56
56
|
# define CZMQ_PRIVATE __attribute__ ((visibility ("hidden")))
|
57
57
|
# else
|
58
58
|
# define CZMQ_PRIVATE
|
@@ -105,6 +105,8 @@ typedef struct _zsock_t zsock_t;
|
|
105
105
|
#define ZSOCK_T_DEFINED
|
106
106
|
typedef struct _zstr_t zstr_t;
|
107
107
|
#define ZSTR_T_DEFINED
|
108
|
+
typedef struct _zsys_t zsys_t;
|
109
|
+
#define ZSYS_T_DEFINED
|
108
110
|
typedef struct _zuuid_t zuuid_t;
|
109
111
|
#define ZUUID_T_DEFINED
|
110
112
|
typedef struct _zauth_t zauth_t;
|
@@ -119,10 +121,10 @@ typedef struct _zproxy_t zproxy_t;
|
|
119
121
|
#define ZPROXY_T_DEFINED
|
120
122
|
typedef struct _zrex_t zrex_t;
|
121
123
|
#define ZREX_T_DEFINED
|
122
|
-
typedef struct _zsys_t zsys_t;
|
123
|
-
#define ZSYS_T_DEFINED
|
124
124
|
// Draft classes are by default not built in stable releases
|
125
125
|
#ifdef CZMQ_BUILD_DRAFT_API
|
126
|
+
typedef struct _zargs_t zargs_t;
|
127
|
+
#define ZARGS_T_DEFINED
|
126
128
|
typedef struct _zproc_t zproc_t;
|
127
129
|
#define ZPROC_T_DEFINED
|
128
130
|
typedef struct _ztimerset_t ztimerset_t;
|
@@ -155,6 +157,7 @@ typedef struct _ztrie_t ztrie_t;
|
|
155
157
|
#include "zpoller.h"
|
156
158
|
#include "zsock.h"
|
157
159
|
#include "zstr.h"
|
160
|
+
#include "zsys.h"
|
158
161
|
#include "zuuid.h"
|
159
162
|
#include "zauth.h"
|
160
163
|
#include "zbeacon.h"
|
@@ -162,13 +165,19 @@ typedef struct _ztrie_t ztrie_t;
|
|
162
165
|
#include "zmonitor.h"
|
163
166
|
#include "zproxy.h"
|
164
167
|
#include "zrex.h"
|
165
|
-
#include "zsys.h"
|
166
168
|
#ifdef CZMQ_BUILD_DRAFT_API
|
169
|
+
#include "zargs.h"
|
167
170
|
#include "zproc.h"
|
168
171
|
#include "ztimerset.h"
|
169
172
|
#include "ztrie.h"
|
170
173
|
#endif // CZMQ_BUILD_DRAFT_API
|
171
174
|
|
175
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
176
|
+
// Self test for private classes
|
177
|
+
CZMQ_EXPORT void
|
178
|
+
czmq_private_selftest (bool verbose);
|
179
|
+
#endif // CZMQ_BUILD_DRAFT_API
|
180
|
+
|
172
181
|
#endif
|
173
182
|
/*
|
174
183
|
################################################################################
|
@@ -17,7 +17,8 @@
|
|
17
17
|
//- Establish the compiler and computer system ------------------------------
|
18
18
|
/*
|
19
19
|
* Defines zero or more of these symbols, for use in any non-portable
|
20
|
-
* code
|
20
|
+
* code (for pre-defined values see e.g. build-system headers as well
|
21
|
+
* as output of GNU C preprocessor via `cpp -dM < /dev/null`):
|
21
22
|
*
|
22
23
|
* __WINDOWS__ Microsoft C/C++ with Windows calls
|
23
24
|
* __MSDOS__ System is MS-DOS (set if __WINDOWS__ set)
|
@@ -164,7 +165,7 @@
|
|
164
165
|
#elif (defined (Mips))
|
165
166
|
# define __UTYPE_MIPS
|
166
167
|
# define __UNIX__
|
167
|
-
#elif (defined (FreeBSD) || defined (__FreeBSD__))
|
168
|
+
#elif (defined (FreeBSD) || defined (__FreeBSD__) || defined (__FreeBSD_kernel__))
|
168
169
|
# define __UTYPE_FREEBSD
|
169
170
|
# define __UNIX__
|
170
171
|
#elif (defined (NetBSD) || defined (__NetBSD__))
|
@@ -193,10 +194,12 @@
|
|
193
194
|
#elif (defined (sinix))
|
194
195
|
# define __UTYPE_SINIX
|
195
196
|
# define __UNIX__
|
196
|
-
#elif (defined (SOLARIS) || defined (__SVR4)
|
197
|
+
#elif (defined (SOLARIS) || defined (__SVR4) || defined (SVR4) || defined (__SVR4__) || defined (__svr4) || defined (svr4) || defined (__svr4__))
|
198
|
+
// Note: this rule and below should match legacy SunOS and Solaris
|
199
|
+
// on builds without the GNU toolchain; with one you get __UTYPE_GNU
|
197
200
|
# define __UTYPE_SUNSOLARIS
|
198
201
|
# define __UNIX__
|
199
|
-
#elif (defined (SUNOS) || defined (SUN) || defined (sun))
|
202
|
+
#elif (defined (SUNOS) || defined (SUN) || defined (sun) || defined (__sun) || defined (__sun__))
|
200
203
|
# define __UTYPE_SUNOS
|
201
204
|
# define __UNIX__
|
202
205
|
#elif (defined (__USLC__) || defined (UnixWare))
|
@@ -419,21 +422,89 @@ typedef struct {
|
|
419
422
|
|
420
423
|
#define streq(s1,s2) (!strcmp ((s1), (s2)))
|
421
424
|
#define strneq(s1,s2) (strcmp ((s1), (s2)))
|
422
|
-
|
423
|
-
|
424
|
-
//
|
425
|
-
//
|
426
|
-
|
425
|
+
#define freen(x) do {free(x); x = NULL;} while(0)
|
426
|
+
|
427
|
+
// randof(num) : Provide random number from 0..(num-1)
|
428
|
+
// ASSUMES that "num" itself is at most an int (bit size no more than float
|
429
|
+
// on the host platform), and non-negative; may be a "function()" token.
|
430
|
+
// For practical reasons, "num" should be under 50M or so.
|
431
|
+
// The math libraries on different platforms and capabilities in HW are a
|
432
|
+
// nightmare. Seems we have to drown the code in casts to have reasonable
|
433
|
+
// results... Also note that the 32-bit float has a hard time representing
|
434
|
+
// values close to UINT32_MAX that we had before, so now limit to UINT16_MAX.
|
435
|
+
// Platforms where RAND_MAX is comparable to even signed INT32_MAX were
|
436
|
+
// rigged with problems here: even if the code used double-precision, the
|
437
|
+
// corner-case factors (divident close to INT32_MAX and close to divisor)
|
438
|
+
// were too close to 1.0, so the final product was "num" rather than "num-1".
|
439
|
+
// Finally note that on some platforms RAND_MAX can be smallish, like 32767,
|
440
|
+
// so we should use it if small enough.
|
441
|
+
|
442
|
+
// Precision for our calculations impacts the MAX values we can use below
|
443
|
+
// Still, say UINT64_MAX is overkill. But smaller MAXes can yield better
|
444
|
+
// distribution of values with e.g. double.
|
445
|
+
#if !defined (ZSYS_RANDOF_FLT)
|
446
|
+
# define ZSYS_RANDOF_FLT float
|
447
|
+
#endif // ZSYS_RANDOF_FLT is defined by caller... trust them or explode later
|
448
|
+
|
449
|
+
// Implementations vary... Note that many will get __UTYPE_GNU nowadays.
|
450
|
+
#if !defined (ZSYS_RANDOF_FUNC)
|
451
|
+
# if defined (ZSYS_RANDOF_FUNC_BITS)
|
452
|
+
# undef ZSYS_RANDOF_FUNC_BITS
|
453
|
+
# endif
|
454
|
+
# if (defined (__WINDOWS__)) || (defined (__UTYPE_IBMAIX)) \
|
427
455
|
|| (defined (__UTYPE_HPUX)) || (defined (__UTYPE_SUNOS)) || (defined (__UTYPE_SOLARIS))
|
428
|
-
# define
|
429
|
-
#
|
430
|
-
# if defined(RAND_MAX)
|
431
|
-
# define randof(num) (int) ((float) (num) * (random () % RAND_MAX) / (RAND_MAX + 1.0))
|
456
|
+
# define ZSYS_RANDOF_FUNC rand
|
457
|
+
# define ZSYS_RANDOF_FUNC_BITS 15
|
432
458
|
# else
|
433
|
-
# define
|
459
|
+
# define ZSYS_RANDOF_FUNC random
|
460
|
+
# define ZSYS_RANDOF_FUNC_BITS 32
|
461
|
+
# endif
|
462
|
+
#endif // ZSYS_RANDOF_FUNC is defined by caller... trust them or explode later
|
463
|
+
|
464
|
+
// Limits below were experimented for 32-bit floats on x86 with test_randof
|
465
|
+
// Due to discrete rounding, greater values caused collisions with the
|
466
|
+
// fraction s_randof_factor() defined below returning 1.0.
|
467
|
+
#if !defined (ZSYS_RANDOF_MAX)
|
468
|
+
# if (ZSYS_RANDOF_FUNC_BITS >= 26)
|
469
|
+
// Assume that random() is at least 32-bit as it is on most platforms
|
470
|
+
# define ZSYS_RANDOF_MAX (UINT32_MAX>>6)
|
471
|
+
# else
|
472
|
+
# if defined (RAND_MAX)
|
473
|
+
# if (RAND_MAX > (UINT32_MAX>>6))
|
474
|
+
# define ZSYS_RANDOF_MAX (UINT32_MAX>>6)
|
475
|
+
# else // RAND_MAX is small enough to not overflow our calculations
|
476
|
+
# define ZSYS_RANDOF_MAX RAND_MAX
|
477
|
+
# endif
|
478
|
+
# else // No RAND_MAX - use a smaller safer limit, but with values too discrete
|
479
|
+
# define ZSYS_RANDOF_MAX INT16_MAX
|
480
|
+
# endif
|
481
|
+
# endif // not random()
|
482
|
+
#endif // ZSYS_RANDOF_MAX is defined by caller... trust them or explode later
|
483
|
+
|
484
|
+
#define s_randof_factor() (ZSYS_RANDOF_FLT)( (ZSYS_RANDOF_FLT)(ZSYS_RANDOF_FUNC() % (ZSYS_RANDOF_MAX - 1)) / ( (ZSYS_RANDOF_FLT)(ZSYS_RANDOF_MAX) ) )
|
485
|
+
|
486
|
+
// Supplement the limited spectrum of ZSYS_RANDOF_MAX by stacking more random()s
|
487
|
+
// Note this can still be too little for very large "num" > ZSYS_RANDOF_MAX
|
488
|
+
// but we'd need a real randof() function to handle stacking in that case.
|
489
|
+
// Fuzziness added below (division by slightly more than a whole number) solves
|
490
|
+
// this wonderfully even for "num" ranges twice as big as the ZSYS_RANDOF_MAX.
|
491
|
+
#if (ZSYS_RANDOF_MAX > UINT16_MAX)
|
492
|
+
# define randof(num) (int) ( (ZSYS_RANDOF_FLT)(num) * s_randof_factor() / ( 1.0 + s_randof_factor() / 100.0 ) )
|
493
|
+
#else // boost dispersion
|
494
|
+
# if (ZSYS_RANDOF_MAX > INT16_MAX)
|
495
|
+
# define randof(num) (int) ( (ZSYS_RANDOF_FLT)(num) * ( s_randof_factor() + s_randof_factor() ) / ( 2.0 + s_randof_factor() / 2.0 ) )
|
496
|
+
# else
|
497
|
+
# if (ZSYS_RANDOF_MAX > UINT8_MAX)
|
498
|
+
# define randof(num) (int) ( (ZSYS_RANDOF_FLT)(num) * ( s_randof_factor() + s_randof_factor() + s_randof_factor() + s_randof_factor() ) / ( 4.0 + s_randof_factor() * 10.0 ) )
|
499
|
+
# else
|
500
|
+
# define randof(num) (int) ( (ZSYS_RANDOF_FLT)(num) * ( s_randof_factor() + s_randof_factor() + s_randof_factor() + s_randof_factor() + s_randof_factor() + s_randof_factor() ) / ( 6.0 + s_randof_factor() * 100.0 ) )
|
501
|
+
# endif
|
434
502
|
# endif
|
435
503
|
#endif
|
436
504
|
|
505
|
+
// That's it about the randof() macro definition...
|
506
|
+
|
507
|
+
|
437
508
|
// Windows MSVS doesn't have stdbool
|
438
509
|
#if (defined (_MSC_VER))
|
439
510
|
# if (!defined (__cplusplus) && (!defined (true)))
|
@@ -496,6 +567,18 @@ typedef intptr_t ssize_t;
|
|
496
567
|
# if (!defined (PRId64))
|
497
568
|
# define PRId64 "I64d"
|
498
569
|
# endif
|
570
|
+
# if (!defined (PRIi8))
|
571
|
+
# define PRIi8 "i"
|
572
|
+
# endif
|
573
|
+
# if (!defined (PRIi16))
|
574
|
+
# define PRIi16 "i"
|
575
|
+
# endif
|
576
|
+
# if (!defined (PRIi32))
|
577
|
+
# define PRIi32 "i"
|
578
|
+
# endif
|
579
|
+
# if (!defined (PRIi64))
|
580
|
+
# define PRIi64 "I64i"
|
581
|
+
# endif
|
499
582
|
# if (!defined (PRIu8))
|
500
583
|
# define PRIu8 "u"
|
501
584
|
# endif
|
@@ -512,7 +595,7 @@ typedef intptr_t ssize_t;
|
|
512
595
|
// MSVC does not support C99's va_copy so we use a regular assignment
|
513
596
|
# define va_copy(dest,src) (dest) = (src)
|
514
597
|
# endif
|
515
|
-
#elif (defined (__UTYPE_OSX))
|
598
|
+
#elif (defined (__UTYPE_OSX) || defined (__OpenBSD__))
|
516
599
|
typedef unsigned long ulong;
|
517
600
|
typedef unsigned int uint;
|
518
601
|
// This fixes header-order dependence problem with some Linux versions
|
@@ -571,7 +654,9 @@ typedef int SOCKET;
|
|
571
654
|
# define closesocket close
|
572
655
|
# define INVALID_SOCKET -1
|
573
656
|
# define SOCKET_ERROR -1
|
574
|
-
#
|
657
|
+
# if !defined O_BINARY
|
658
|
+
# define O_BINARY 0
|
659
|
+
# endif
|
575
660
|
#endif
|
576
661
|
|
577
662
|
//- Include non-portable header files based on platform.h -------------------
|
@@ -580,6 +665,9 @@ typedef int SOCKET;
|
|
580
665
|
# include <linux/wireless.h>
|
581
666
|
// This would normally come from net/if.h
|
582
667
|
unsigned int if_nametoindex (const char *ifname);
|
668
|
+
char *if_indextoname (unsigned int ifindex, char *ifname);
|
669
|
+
// 32 on Linux, 256 on Windows, pick largest to avoid overflows
|
670
|
+
# define IF_NAMESIZE 256
|
583
671
|
#else
|
584
672
|
# if defined (HAVE_NET_IF_H)
|
585
673
|
# include <net/if.h>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
/* =========================================================================
|
2
|
-
zactor - actor
|
2
|
+
zactor - actor
|
3
3
|
|
4
4
|
Copyright (c) the Contributors as noted in the AUTHORS file.
|
5
5
|
This file is part of CZMQ, the high-level C binding for 0MQ:
|
@@ -23,6 +23,8 @@ extern "C" {
|
|
23
23
|
// @interface
|
24
24
|
// This is a stable class, and may not change except for emergencies. It
|
25
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.
|
26
28
|
// Actors get a pipe and arguments from caller
|
27
29
|
typedef void (zactor_fn) (
|
28
30
|
zsock_t *pipe, void *args);
|
@@ -36,13 +38,13 @@ CZMQ_EXPORT void
|
|
36
38
|
zactor_destroy (zactor_t **self_p);
|
37
39
|
|
38
40
|
// Send a zmsg message to the actor, take ownership of the message
|
39
|
-
// and destroy when it has been sent.
|
41
|
+
// and destroy when it has been sent.
|
40
42
|
CZMQ_EXPORT int
|
41
43
|
zactor_send (zactor_t *self, zmsg_t **msg_p);
|
42
44
|
|
43
|
-
// Receive a zmsg message from the actor. Returns NULL if the actor
|
45
|
+
// Receive a zmsg message from the actor. Returns NULL if the actor
|
44
46
|
// was interrupted before the message could be received, or if there
|
45
|
-
// was a timeout on the actor.
|
47
|
+
// was a timeout on the actor.
|
46
48
|
// Caller owns return value and must destroy it when done.
|
47
49
|
CZMQ_EXPORT zmsg_t *
|
48
50
|
zactor_recv (zactor_t *self);
|
@@ -52,13 +54,13 @@ CZMQ_EXPORT bool
|
|
52
54
|
zactor_is (void *self);
|
53
55
|
|
54
56
|
// Probe the supplied reference. If it looks like a zactor_t instance,
|
55
|
-
// return the underlying libzmq actor handle; else if it looks like
|
56
|
-
// a libzmq actor handle, return the supplied value.
|
57
|
+
// return the underlying libzmq actor handle; else if it looks like
|
58
|
+
// a libzmq actor handle, return the supplied value.
|
57
59
|
CZMQ_EXPORT void *
|
58
60
|
zactor_resolve (void *self);
|
59
61
|
|
60
62
|
// Return the actor's zsock handle. Use this when you absolutely need
|
61
|
-
// to work with the zsock instance rather than the actor.
|
63
|
+
// to work with the zsock instance rather than the actor.
|
62
64
|
CZMQ_EXPORT zsock_t *
|
63
65
|
zactor_sock (zactor_t *self);
|
64
66
|
|
@@ -66,6 +68,22 @@ CZMQ_EXPORT zsock_t *
|
|
66
68
|
CZMQ_EXPORT void
|
67
69
|
zactor_test (bool verbose);
|
68
70
|
|
71
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
72
|
+
// Function to be called on zactor_destroy. Default behavior is to send zmsg_t with string "$TERM" in a first frame.
|
73
|
+
//
|
74
|
+
// An example - to send $KTHXBAI string
|
75
|
+
//
|
76
|
+
// if (zstr_send (self->pipe, "$KTHXBAI") == 0)
|
77
|
+
// zsock_wait (self->pipe);
|
78
|
+
typedef void (zactor_destructor_fn) (
|
79
|
+
zactor_t *self);
|
80
|
+
|
81
|
+
// *** Draft method, for development use, may change without warning ***
|
82
|
+
// Change default destructor by custom function. Actor MUST be able to handle new message instead of default $TERM.
|
83
|
+
CZMQ_EXPORT void
|
84
|
+
zactor_set_destructor (zactor_t *self, zactor_destructor_fn destructor);
|
85
|
+
|
86
|
+
#endif // CZMQ_BUILD_DRAFT_API
|
69
87
|
// @end
|
70
88
|
|
71
89
|
|