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
@@ -73,8 +73,8 @@ module CZMQ
|
|
73
73
|
end
|
74
74
|
|
75
75
|
# Receive C string from socket. Caller must free returned string using
|
76
|
-
# zstr_free(). Returns NULL if the context is being terminated or the
|
77
|
-
# process was interrupted.
|
76
|
+
# zstr_free(). Returns NULL if the context is being terminated or the
|
77
|
+
# process was interrupted.
|
78
78
|
#
|
79
79
|
# @param source [::FFI::Pointer, #to_ptr]
|
80
80
|
# @return [::FFI::AutoPointer]
|
@@ -84,13 +84,13 @@ module CZMQ
|
|
84
84
|
result
|
85
85
|
end
|
86
86
|
|
87
|
-
# Receive a series of strings (until NULL) from multipart data.
|
88
|
-
# Each string is allocated and filled with string data; if there
|
89
|
-
# are not enough frames, unallocated strings are set to NULL.
|
90
|
-
# Returns -1 if the message could not be read, else returns the
|
87
|
+
# Receive a series of strings (until NULL) from multipart data.
|
88
|
+
# Each string is allocated and filled with string data; if there
|
89
|
+
# are not enough frames, unallocated strings are set to NULL.
|
90
|
+
# Returns -1 if the message could not be read, else returns the
|
91
91
|
# number of strings filled, zero or more. Free each returned string
|
92
|
-
# using zstr_free(). If not enough strings are provided, remaining
|
93
|
-
# multipart frames in the message are dropped.
|
92
|
+
# using zstr_free(). If not enough strings are provided, remaining
|
93
|
+
# multipart frames in the message are dropped.
|
94
94
|
#
|
95
95
|
# @param source [::FFI::Pointer, #to_ptr]
|
96
96
|
# @param string_p [::FFI::Pointer, #to_ptr]
|
@@ -101,10 +101,23 @@ module CZMQ
|
|
101
101
|
result
|
102
102
|
end
|
103
103
|
|
104
|
-
#
|
104
|
+
# De-compress and receive C string from socket, received as a message
|
105
|
+
# with two frames: size of the uncompressed string, and the string itself.
|
106
|
+
# Caller must free returned string using zstr_free(). Returns NULL if the
|
107
|
+
# context is being terminated or the process was interrupted.
|
108
|
+
#
|
109
|
+
# @param source [::FFI::Pointer, #to_ptr]
|
110
|
+
# @return [::FFI::AutoPointer]
|
111
|
+
def self.recv_compress(source)
|
112
|
+
result = ::CZMQ::FFI.zstr_recv_compress(source)
|
113
|
+
result = ::FFI::AutoPointer.new(result, LibC.method(:free))
|
114
|
+
result
|
115
|
+
end
|
116
|
+
|
117
|
+
# Send a C string to a socket, as a frame. The string is sent without
|
105
118
|
# trailing null byte; to read this you can use zstr_recv, or a similar
|
106
|
-
# method that adds a null terminator on the received string. String
|
107
|
-
# may be NULL, which is sent as "".
|
119
|
+
# method that adds a null terminator on the received string. String
|
120
|
+
# may be NULL, which is sent as "".
|
108
121
|
#
|
109
122
|
# @param dest [::FFI::Pointer, #to_ptr]
|
110
123
|
# @param string [String, #to_s, nil]
|
@@ -115,7 +128,7 @@ module CZMQ
|
|
115
128
|
end
|
116
129
|
|
117
130
|
# Send a C string to a socket, as zstr_send(), with a MORE flag, so that
|
118
|
-
# you can send further strings in the same multi-part message.
|
131
|
+
# you can send further strings in the same multi-part message.
|
119
132
|
#
|
120
133
|
# @param dest [::FFI::Pointer, #to_ptr]
|
121
134
|
# @param string [String, #to_s, nil]
|
@@ -126,8 +139,8 @@ module CZMQ
|
|
126
139
|
end
|
127
140
|
|
128
141
|
# Send a formatted string to a socket. Note that you should NOT use
|
129
|
-
# user-supplied strings in the format (they may contain '%' which
|
130
|
-
# will create security holes).
|
142
|
+
# user-supplied strings in the format (they may contain '%' which
|
143
|
+
# will create security holes).
|
131
144
|
#
|
132
145
|
# @param dest [::FFI::Pointer, #to_ptr]
|
133
146
|
# @param format [String, #to_s, nil]
|
@@ -138,9 +151,9 @@ module CZMQ
|
|
138
151
|
result
|
139
152
|
end
|
140
153
|
|
141
|
-
# Send a formatted string to a socket, as for zstr_sendf(), with a
|
154
|
+
# Send a formatted string to a socket, as for zstr_sendf(), with a
|
142
155
|
# MORE flag, so that you can send further strings in the same multi-part
|
143
|
-
# message.
|
156
|
+
# message.
|
144
157
|
#
|
145
158
|
# @param dest [::FFI::Pointer, #to_ptr]
|
146
159
|
# @param format [String, #to_s, nil]
|
@@ -151,7 +164,7 @@ module CZMQ
|
|
151
164
|
result
|
152
165
|
end
|
153
166
|
|
154
|
-
# Send a series of strings (until NULL) as multipart data
|
167
|
+
# Send a series of strings (until NULL) as multipart data
|
155
168
|
# Returns 0 if the strings could be sent OK, or -1 on error.
|
156
169
|
#
|
157
170
|
# @param dest [::FFI::Pointer, #to_ptr]
|
@@ -163,8 +176,34 @@ module CZMQ
|
|
163
176
|
result
|
164
177
|
end
|
165
178
|
|
179
|
+
# Compress and send a C string to a socket, as a message with two frames:
|
180
|
+
# size of the uncompressed string, and the string itself. The string is
|
181
|
+
# sent without trailing null byte; to read this you can use
|
182
|
+
# zstr_recv_compress, or a similar method that de-compresses and adds a
|
183
|
+
# null terminator on the received string.
|
184
|
+
#
|
185
|
+
# @param dest [::FFI::Pointer, #to_ptr]
|
186
|
+
# @param string [String, #to_s, nil]
|
187
|
+
# @return [Integer]
|
188
|
+
def self.send_compress(dest, string)
|
189
|
+
result = ::CZMQ::FFI.zstr_send_compress(dest, string)
|
190
|
+
result
|
191
|
+
end
|
192
|
+
|
193
|
+
# Compress and send a C string to a socket, as zstr_send_compress(),
|
194
|
+
# with a MORE flag, so that you can send further strings in the same
|
195
|
+
# multi-part message.
|
196
|
+
#
|
197
|
+
# @param dest [::FFI::Pointer, #to_ptr]
|
198
|
+
# @param string [String, #to_s, nil]
|
199
|
+
# @return [Integer]
|
200
|
+
def self.sendm_compress(dest, string)
|
201
|
+
result = ::CZMQ::FFI.zstr_sendm_compress(dest, string)
|
202
|
+
result
|
203
|
+
end
|
204
|
+
|
166
205
|
# Accepts a void pointer and returns a fresh character string. If source
|
167
|
-
# is null, returns an empty string.
|
206
|
+
# is null, returns an empty string.
|
168
207
|
#
|
169
208
|
# @param source [::FFI::Pointer, #to_ptr]
|
170
209
|
# @return [::FFI::AutoPointer]
|
@@ -175,7 +214,7 @@ module CZMQ
|
|
175
214
|
end
|
176
215
|
|
177
216
|
# Free a provided string, and nullify the parent pointer. Safe to call on
|
178
|
-
# a null pointer.
|
217
|
+
# a null pointer.
|
179
218
|
#
|
180
219
|
# @param string_p [::FFI::Pointer, #to_ptr]
|
181
220
|
# @return [void]
|
@@ -0,0 +1,836 @@
|
|
1
|
+
################################################################################
|
2
|
+
# THIS FILE IS 100% GENERATED BY ZPROJECT; DO NOT EDIT EXCEPT EXPERIMENTALLY #
|
3
|
+
# Read the zproject/README.md for information about making permanent changes. #
|
4
|
+
################################################################################
|
5
|
+
|
6
|
+
module CZMQ
|
7
|
+
module FFI
|
8
|
+
|
9
|
+
#
|
10
|
+
# @note This class is 100% generated using zproject.
|
11
|
+
class Zsys
|
12
|
+
# Raised when one tries to use an instance of {Zsys} after
|
13
|
+
# the internal pointer to the native object has been nullified.
|
14
|
+
class DestroyedError < RuntimeError; end
|
15
|
+
|
16
|
+
# Boilerplate for self pointer, initializer, and finalizer
|
17
|
+
class << self
|
18
|
+
alias :__new :new
|
19
|
+
end
|
20
|
+
# Attaches the pointer _ptr_ to this instance and defines a finalizer for
|
21
|
+
# it if necessary.
|
22
|
+
# @param ptr [::FFI::Pointer]
|
23
|
+
# @param finalize [Boolean]
|
24
|
+
def initialize(ptr, finalize = true)
|
25
|
+
@ptr = ptr
|
26
|
+
if @ptr.null?
|
27
|
+
@ptr = nil # Remove null pointers so we don't have to test for them.
|
28
|
+
elsif finalize
|
29
|
+
@finalizer = self.class.create_finalizer_for @ptr
|
30
|
+
ObjectSpace.define_finalizer self, @finalizer
|
31
|
+
end
|
32
|
+
end
|
33
|
+
# @return [Proc]
|
34
|
+
def self.create_finalizer_for(ptr)
|
35
|
+
Proc.new do
|
36
|
+
"WARNING: "\
|
37
|
+
"Objects of type #{self} cannot be destroyed implicitly. "\
|
38
|
+
"Please call the correct destroy method with the relevant arguments."
|
39
|
+
end
|
40
|
+
end
|
41
|
+
# @return [Boolean]
|
42
|
+
def null?
|
43
|
+
!@ptr or @ptr.null?
|
44
|
+
end
|
45
|
+
# Return internal pointer
|
46
|
+
# @return [::FFI::Pointer]
|
47
|
+
def __ptr
|
48
|
+
raise DestroyedError unless @ptr
|
49
|
+
@ptr
|
50
|
+
end
|
51
|
+
# So external Libraries can just pass the Object to a FFI function which expects a :pointer
|
52
|
+
alias_method :to_ptr, :__ptr
|
53
|
+
# Nullify internal pointer and return pointer pointer.
|
54
|
+
# @note This detaches the current instance from the native object
|
55
|
+
# and thus makes it unusable.
|
56
|
+
# @return [::FFI::MemoryPointer] the pointer pointing to a pointer
|
57
|
+
# pointing to the native object
|
58
|
+
def __ptr_give_ref
|
59
|
+
raise DestroyedError unless @ptr
|
60
|
+
ptr_ptr = ::FFI::MemoryPointer.new :pointer
|
61
|
+
ptr_ptr.write_pointer @ptr
|
62
|
+
__undef_finalizer if @finalizer
|
63
|
+
@ptr = nil
|
64
|
+
ptr_ptr
|
65
|
+
end
|
66
|
+
# Undefines the finalizer for this object.
|
67
|
+
# @note Only use this if you need to and can guarantee that the native
|
68
|
+
# object will be freed by other means.
|
69
|
+
# @return [void]
|
70
|
+
def __undef_finalizer
|
71
|
+
ObjectSpace.undefine_finalizer self
|
72
|
+
@finalizer = nil
|
73
|
+
end
|
74
|
+
|
75
|
+
# Create a new callback of the following type:
|
76
|
+
# Callback for interrupt signal handler
|
77
|
+
# typedef void (zsys_handler_fn) (
|
78
|
+
# int signal_value);
|
79
|
+
#
|
80
|
+
# @note WARNING: If your Ruby code doesn't retain a reference to the
|
81
|
+
# FFI::Function object after passing it to a C function call,
|
82
|
+
# it may be garbage collected while C still holds the pointer,
|
83
|
+
# potentially resulting in a segmentation fault.
|
84
|
+
def self.handler_fn
|
85
|
+
::FFI::Function.new :void, [:int], blocking: true do |signal_value|
|
86
|
+
result = yield signal_value
|
87
|
+
result
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
# Initialize CZMQ zsys layer; this happens automatically when you create
|
92
|
+
# a socket or an actor; however this call lets you force initialization
|
93
|
+
# earlier, so e.g. logging is properly set-up before you start working.
|
94
|
+
# Not threadsafe, so call only from main thread. Safe to call multiple
|
95
|
+
# times. Returns global CZMQ context.
|
96
|
+
#
|
97
|
+
# @return [::FFI::Pointer]
|
98
|
+
def self.init()
|
99
|
+
result = ::CZMQ::FFI.zsys_init()
|
100
|
+
result
|
101
|
+
end
|
102
|
+
|
103
|
+
# Optionally shut down the CZMQ zsys layer; this normally happens automatically
|
104
|
+
# when the process exits; however this call lets you force a shutdown
|
105
|
+
# earlier, avoiding any potential problems with atexit() ordering, especially
|
106
|
+
# with Windows dlls.
|
107
|
+
#
|
108
|
+
# @return [void]
|
109
|
+
def self.shutdown()
|
110
|
+
result = ::CZMQ::FFI.zsys_shutdown()
|
111
|
+
result
|
112
|
+
end
|
113
|
+
|
114
|
+
# Get a new ZMQ socket, automagically creating a ZMQ context if this is
|
115
|
+
# the first time. Caller is responsible for destroying the ZMQ socket
|
116
|
+
# before process exits, to avoid a ZMQ deadlock. Note: you should not use
|
117
|
+
# this method in CZMQ apps, use zsock_new() instead.
|
118
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
119
|
+
#
|
120
|
+
# @param type [Integer, #to_int, #to_i]
|
121
|
+
# @param filename [String, #to_s, nil]
|
122
|
+
# @param line_nbr [Integer, #to_int, #to_i]
|
123
|
+
# @return [::FFI::Pointer]
|
124
|
+
def self.socket(type, filename, line_nbr)
|
125
|
+
type = Integer(type)
|
126
|
+
line_nbr = Integer(line_nbr)
|
127
|
+
result = ::CZMQ::FFI.zsys_socket(type, filename, line_nbr)
|
128
|
+
result
|
129
|
+
end
|
130
|
+
|
131
|
+
# Destroy/close a ZMQ socket. You should call this for every socket you
|
132
|
+
# create using zsys_socket().
|
133
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
134
|
+
#
|
135
|
+
# @param handle [::FFI::Pointer, #to_ptr]
|
136
|
+
# @param filename [String, #to_s, nil]
|
137
|
+
# @param line_nbr [Integer, #to_int, #to_i]
|
138
|
+
# @return [Integer]
|
139
|
+
def self.close(handle, filename, line_nbr)
|
140
|
+
line_nbr = Integer(line_nbr)
|
141
|
+
result = ::CZMQ::FFI.zsys_close(handle, filename, line_nbr)
|
142
|
+
result
|
143
|
+
end
|
144
|
+
|
145
|
+
# Return ZMQ socket name for socket type
|
146
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
147
|
+
#
|
148
|
+
# @param socktype [Integer, #to_int, #to_i]
|
149
|
+
# @return [::FFI::Pointer]
|
150
|
+
def self.sockname(socktype)
|
151
|
+
socktype = Integer(socktype)
|
152
|
+
result = ::CZMQ::FFI.zsys_sockname(socktype)
|
153
|
+
result
|
154
|
+
end
|
155
|
+
|
156
|
+
# Create a pipe, which consists of two PAIR sockets connected over inproc.
|
157
|
+
# The pipe is configured to use the zsys_pipehwm setting. Returns the
|
158
|
+
# frontend socket successful, NULL if failed.
|
159
|
+
#
|
160
|
+
# @param backend_p [#__ptr_give_ref]
|
161
|
+
# @return [Zsock]
|
162
|
+
def self.create_pipe(backend_p)
|
163
|
+
backend_p = backend_p.__ptr_give_ref
|
164
|
+
result = ::CZMQ::FFI.zsys_create_pipe(backend_p)
|
165
|
+
result = Zsock.__new result, false
|
166
|
+
result
|
167
|
+
end
|
168
|
+
|
169
|
+
# Set interrupt handler; this saves the default handlers so that a
|
170
|
+
# zsys_handler_reset () can restore them. If you call this multiple times
|
171
|
+
# then the last handler will take affect. If handler_fn is NULL, disables
|
172
|
+
# default SIGINT/SIGTERM handling in CZMQ.
|
173
|
+
#
|
174
|
+
# @param handler_fn [::FFI::Pointer, #to_ptr]
|
175
|
+
# @return [void]
|
176
|
+
def self.handler_set(handler_fn)
|
177
|
+
result = ::CZMQ::FFI.zsys_handler_set(handler_fn)
|
178
|
+
result
|
179
|
+
end
|
180
|
+
|
181
|
+
# Reset interrupt handler, call this at exit if needed
|
182
|
+
#
|
183
|
+
# @return [void]
|
184
|
+
def self.handler_reset()
|
185
|
+
result = ::CZMQ::FFI.zsys_handler_reset()
|
186
|
+
result
|
187
|
+
end
|
188
|
+
|
189
|
+
# Set default interrupt handler, so Ctrl-C or SIGTERM will set
|
190
|
+
# zsys_interrupted. Idempotent; safe to call multiple times.
|
191
|
+
# Can be supressed by ZSYS_SIGHANDLER=false
|
192
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
193
|
+
#
|
194
|
+
# @return [void]
|
195
|
+
def self.catch_interrupts()
|
196
|
+
result = ::CZMQ::FFI.zsys_catch_interrupts()
|
197
|
+
result
|
198
|
+
end
|
199
|
+
|
200
|
+
# Return 1 if file exists, else zero
|
201
|
+
#
|
202
|
+
# @param filename [String, #to_s, nil]
|
203
|
+
# @return [Boolean]
|
204
|
+
def self.file_exists(filename)
|
205
|
+
result = ::CZMQ::FFI.zsys_file_exists(filename)
|
206
|
+
result
|
207
|
+
end
|
208
|
+
|
209
|
+
# Return file modification time. Returns 0 if the file does not exist.
|
210
|
+
#
|
211
|
+
# @param filename [String, #to_s, nil]
|
212
|
+
# @return [::FFI::Pointer]
|
213
|
+
def self.file_modified(filename)
|
214
|
+
result = ::CZMQ::FFI.zsys_file_modified(filename)
|
215
|
+
result
|
216
|
+
end
|
217
|
+
|
218
|
+
# Return file mode; provides at least support for the POSIX S_ISREG(m)
|
219
|
+
# and S_ISDIR(m) macros and the S_IRUSR and S_IWUSR bits, on all boxes.
|
220
|
+
# Returns a mode_t cast to int, or -1 in case of error.
|
221
|
+
#
|
222
|
+
# @param filename [String, #to_s, nil]
|
223
|
+
# @return [Integer]
|
224
|
+
def self.file_mode(filename)
|
225
|
+
result = ::CZMQ::FFI.zsys_file_mode(filename)
|
226
|
+
result
|
227
|
+
end
|
228
|
+
|
229
|
+
# Delete file. Does not complain if the file is absent
|
230
|
+
#
|
231
|
+
# @param filename [String, #to_s, nil]
|
232
|
+
# @return [Integer]
|
233
|
+
def self.file_delete(filename)
|
234
|
+
result = ::CZMQ::FFI.zsys_file_delete(filename)
|
235
|
+
result
|
236
|
+
end
|
237
|
+
|
238
|
+
# Check if file is 'stable'
|
239
|
+
#
|
240
|
+
# @param filename [String, #to_s, nil]
|
241
|
+
# @return [Boolean]
|
242
|
+
def self.file_stable(filename)
|
243
|
+
result = ::CZMQ::FFI.zsys_file_stable(filename)
|
244
|
+
result
|
245
|
+
end
|
246
|
+
|
247
|
+
# Create a file path if it doesn't exist. The file path is treated as
|
248
|
+
# printf format.
|
249
|
+
#
|
250
|
+
# @param pathname [String, #to_s, nil]
|
251
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
252
|
+
# @return [Integer]
|
253
|
+
def self.dir_create(pathname, *args)
|
254
|
+
result = ::CZMQ::FFI.zsys_dir_create(pathname, *args)
|
255
|
+
result
|
256
|
+
end
|
257
|
+
|
258
|
+
# Remove a file path if empty; the pathname is treated as printf format.
|
259
|
+
#
|
260
|
+
# @param pathname [String, #to_s, nil]
|
261
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
262
|
+
# @return [Integer]
|
263
|
+
def self.dir_delete(pathname, *args)
|
264
|
+
result = ::CZMQ::FFI.zsys_dir_delete(pathname, *args)
|
265
|
+
result
|
266
|
+
end
|
267
|
+
|
268
|
+
# Move to a specified working directory. Returns 0 if OK, -1 if this failed.
|
269
|
+
#
|
270
|
+
# @param pathname [String, #to_s, nil]
|
271
|
+
# @return [Integer]
|
272
|
+
def self.dir_change(pathname)
|
273
|
+
result = ::CZMQ::FFI.zsys_dir_change(pathname)
|
274
|
+
result
|
275
|
+
end
|
276
|
+
|
277
|
+
# Set private file creation mode; all files created from here will be
|
278
|
+
# readable/writable by the owner only.
|
279
|
+
#
|
280
|
+
# @return [void]
|
281
|
+
def self.file_mode_private()
|
282
|
+
result = ::CZMQ::FFI.zsys_file_mode_private()
|
283
|
+
result
|
284
|
+
end
|
285
|
+
|
286
|
+
# Reset default file creation mode; all files created from here will use
|
287
|
+
# process file mode defaults.
|
288
|
+
#
|
289
|
+
# @return [void]
|
290
|
+
def self.file_mode_default()
|
291
|
+
result = ::CZMQ::FFI.zsys_file_mode_default()
|
292
|
+
result
|
293
|
+
end
|
294
|
+
|
295
|
+
# Return the CZMQ version for run-time API detection; returns version
|
296
|
+
# number into provided fields, providing reference isn't null in each case.
|
297
|
+
#
|
298
|
+
# @param major [::FFI::Pointer, #to_ptr]
|
299
|
+
# @param minor [::FFI::Pointer, #to_ptr]
|
300
|
+
# @param patch [::FFI::Pointer, #to_ptr]
|
301
|
+
# @return [void]
|
302
|
+
def self.version(major, minor, patch)
|
303
|
+
result = ::CZMQ::FFI.zsys_version(major, minor, patch)
|
304
|
+
result
|
305
|
+
end
|
306
|
+
|
307
|
+
# Format a string using printf formatting, returning a freshly allocated
|
308
|
+
# buffer. If there was insufficient memory, returns NULL. Free the returned
|
309
|
+
# string using zstr_free().
|
310
|
+
#
|
311
|
+
# @param format [String, #to_s, nil]
|
312
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
313
|
+
# @return [::FFI::Pointer]
|
314
|
+
def self.sprintf(format, *args)
|
315
|
+
result = ::CZMQ::FFI.zsys_sprintf(format, *args)
|
316
|
+
result
|
317
|
+
end
|
318
|
+
|
319
|
+
# Format a string with a va_list argument, returning a freshly allocated
|
320
|
+
# buffer. If there was insufficient memory, returns NULL. Free the returned
|
321
|
+
# string using zstr_free().
|
322
|
+
#
|
323
|
+
# @param format [String, #to_s, nil]
|
324
|
+
# @param argptr [::FFI::Pointer, #to_ptr]
|
325
|
+
# @return [::FFI::Pointer]
|
326
|
+
def self.vprintf(format, argptr)
|
327
|
+
result = ::CZMQ::FFI.zsys_vprintf(format, argptr)
|
328
|
+
result
|
329
|
+
end
|
330
|
+
|
331
|
+
# Create UDP beacon socket; if the routable option is true, uses
|
332
|
+
# multicast (not yet implemented), else uses broadcast. This method
|
333
|
+
# and related ones might _eventually_ be moved to a zudp class.
|
334
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
335
|
+
#
|
336
|
+
# @param routable [Boolean]
|
337
|
+
# @return [Integer or FFI::Pointer]
|
338
|
+
def self.udp_new(routable)
|
339
|
+
routable = !(0==routable||!routable) # boolean
|
340
|
+
result = ::CZMQ::FFI.zsys_udp_new(routable)
|
341
|
+
result
|
342
|
+
end
|
343
|
+
|
344
|
+
# Close a UDP socket
|
345
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
346
|
+
#
|
347
|
+
# @param handle [Integer or FFI::Pointer]
|
348
|
+
# @return [Integer]
|
349
|
+
def self.udp_close(handle)
|
350
|
+
result = ::CZMQ::FFI.zsys_udp_close(handle)
|
351
|
+
result
|
352
|
+
end
|
353
|
+
|
354
|
+
# Send zframe to UDP socket, return -1 if sending failed due to
|
355
|
+
# interface having disappeared (happens easily with WiFi)
|
356
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
357
|
+
#
|
358
|
+
# @param udpsock [Integer or FFI::Pointer]
|
359
|
+
# @param frame [Zframe, #__ptr]
|
360
|
+
# @param address [::FFI::Pointer, #to_ptr]
|
361
|
+
# @param addrlen [Integer, #to_int, #to_i]
|
362
|
+
# @return [Integer]
|
363
|
+
def self.udp_send(udpsock, frame, address, addrlen)
|
364
|
+
frame = frame.__ptr if frame
|
365
|
+
addrlen = Integer(addrlen)
|
366
|
+
result = ::CZMQ::FFI.zsys_udp_send(udpsock, frame, address, addrlen)
|
367
|
+
result
|
368
|
+
end
|
369
|
+
|
370
|
+
# Receive zframe from UDP socket, and set address of peer that sent it
|
371
|
+
# The peername must be a char [INET_ADDRSTRLEN] array if IPv6 is disabled or
|
372
|
+
# NI_MAXHOST if it's enabled. Returns NULL when failing to get peer address.
|
373
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
374
|
+
#
|
375
|
+
# @param udpsock [Integer or FFI::Pointer]
|
376
|
+
# @param peername [::FFI::Pointer, #to_ptr]
|
377
|
+
# @param peerlen [Integer, #to_int, #to_i]
|
378
|
+
# @return [Zframe]
|
379
|
+
def self.udp_recv(udpsock, peername, peerlen)
|
380
|
+
peerlen = Integer(peerlen)
|
381
|
+
result = ::CZMQ::FFI.zsys_udp_recv(udpsock, peername, peerlen)
|
382
|
+
result = Zframe.__new result, false
|
383
|
+
result
|
384
|
+
end
|
385
|
+
|
386
|
+
# Handle an I/O error on some socket operation; will report and die on
|
387
|
+
# fatal errors, and continue silently on "try again" errors.
|
388
|
+
# *** This is for CZMQ internal use only and may change arbitrarily ***
|
389
|
+
#
|
390
|
+
# @param reason [String, #to_s, nil]
|
391
|
+
# @return [void]
|
392
|
+
def self.socket_error(reason)
|
393
|
+
result = ::CZMQ::FFI.zsys_socket_error(reason)
|
394
|
+
result
|
395
|
+
end
|
396
|
+
|
397
|
+
# Return current host name, for use in public tcp:// endpoints. Caller gets
|
398
|
+
# a freshly allocated string, should free it using zstr_free(). If the host
|
399
|
+
# name is not resolvable, returns NULL.
|
400
|
+
#
|
401
|
+
# @return [::FFI::Pointer]
|
402
|
+
def self.hostname()
|
403
|
+
result = ::CZMQ::FFI.zsys_hostname()
|
404
|
+
result
|
405
|
+
end
|
406
|
+
|
407
|
+
# Move the current process into the background. The precise effect depends
|
408
|
+
# on the operating system. On POSIX boxes, moves to a specified working
|
409
|
+
# directory (if specified), closes all file handles, reopens stdin, stdout,
|
410
|
+
# and stderr to the null device, and sets the process to ignore SIGHUP. On
|
411
|
+
# Windows, does nothing. Returns 0 if OK, -1 if there was an error.
|
412
|
+
#
|
413
|
+
# @param workdir [String, #to_s, nil]
|
414
|
+
# @return [Integer]
|
415
|
+
def self.daemonize(workdir)
|
416
|
+
result = ::CZMQ::FFI.zsys_daemonize(workdir)
|
417
|
+
result
|
418
|
+
end
|
419
|
+
|
420
|
+
# Drop the process ID into the lockfile, with exclusive lock, and switch
|
421
|
+
# the process to the specified group and/or user. Any of the arguments
|
422
|
+
# may be null, indicating a no-op. Returns 0 on success, -1 on failure.
|
423
|
+
# Note if you combine this with zsys_daemonize, run after, not before
|
424
|
+
# that method, or the lockfile will hold the wrong process ID.
|
425
|
+
#
|
426
|
+
# @param lockfile [String, #to_s, nil]
|
427
|
+
# @param group [String, #to_s, nil]
|
428
|
+
# @param user [String, #to_s, nil]
|
429
|
+
# @return [Integer]
|
430
|
+
def self.run_as(lockfile, group, user)
|
431
|
+
result = ::CZMQ::FFI.zsys_run_as(lockfile, group, user)
|
432
|
+
result
|
433
|
+
end
|
434
|
+
|
435
|
+
# Returns true if the underlying libzmq supports CURVE security.
|
436
|
+
# Uses a heuristic probe according to the version of libzmq being used.
|
437
|
+
#
|
438
|
+
# @return [Boolean]
|
439
|
+
def self.has_curve()
|
440
|
+
result = ::CZMQ::FFI.zsys_has_curve()
|
441
|
+
result
|
442
|
+
end
|
443
|
+
|
444
|
+
# Configure the number of I/O threads that ZeroMQ will use. A good
|
445
|
+
# rule of thumb is one thread per gigabit of traffic in or out. The
|
446
|
+
# default is 1, sufficient for most applications. If the environment
|
447
|
+
# variable ZSYS_IO_THREADS is defined, that provides the default.
|
448
|
+
# Note that this method is valid only before any socket is created.
|
449
|
+
#
|
450
|
+
# @param io_threads [Integer, #to_int, #to_i]
|
451
|
+
# @return [void]
|
452
|
+
def self.set_io_threads(io_threads)
|
453
|
+
io_threads = Integer(io_threads)
|
454
|
+
result = ::CZMQ::FFI.zsys_set_io_threads(io_threads)
|
455
|
+
result
|
456
|
+
end
|
457
|
+
|
458
|
+
# Configure the scheduling policy of the ZMQ context thread pool.
|
459
|
+
# Not available on Windows. See the sched_setscheduler man page or sched.h
|
460
|
+
# for more information. If the environment variable ZSYS_THREAD_SCHED_POLICY
|
461
|
+
# is defined, that provides the default.
|
462
|
+
# Note that this method is valid only before any socket is created.
|
463
|
+
#
|
464
|
+
# @param policy [Integer, #to_int, #to_i]
|
465
|
+
# @return [void]
|
466
|
+
def self.set_thread_sched_policy(policy)
|
467
|
+
policy = Integer(policy)
|
468
|
+
result = ::CZMQ::FFI.zsys_set_thread_sched_policy(policy)
|
469
|
+
result
|
470
|
+
end
|
471
|
+
|
472
|
+
# Configure the scheduling priority of the ZMQ context thread pool.
|
473
|
+
# Not available on Windows. See the sched_setscheduler man page or sched.h
|
474
|
+
# for more information. If the environment variable ZSYS_THREAD_PRIORITY is
|
475
|
+
# defined, that provides the default.
|
476
|
+
# Note that this method is valid only before any socket is created.
|
477
|
+
#
|
478
|
+
# @param priority [Integer, #to_int, #to_i]
|
479
|
+
# @return [void]
|
480
|
+
def self.set_thread_priority(priority)
|
481
|
+
priority = Integer(priority)
|
482
|
+
result = ::CZMQ::FFI.zsys_set_thread_priority(priority)
|
483
|
+
result
|
484
|
+
end
|
485
|
+
|
486
|
+
# Configure the number of sockets that ZeroMQ will allow. The default
|
487
|
+
# is 1024. The actual limit depends on the system, and you can query it
|
488
|
+
# by using zsys_socket_limit (). A value of zero means "maximum".
|
489
|
+
# Note that this method is valid only before any socket is created.
|
490
|
+
#
|
491
|
+
# @param max_sockets [Integer, #to_int, #to_i]
|
492
|
+
# @return [void]
|
493
|
+
def self.set_max_sockets(max_sockets)
|
494
|
+
max_sockets = Integer(max_sockets)
|
495
|
+
result = ::CZMQ::FFI.zsys_set_max_sockets(max_sockets)
|
496
|
+
result
|
497
|
+
end
|
498
|
+
|
499
|
+
# Return maximum number of ZeroMQ sockets that the system will support.
|
500
|
+
#
|
501
|
+
# @return [Integer]
|
502
|
+
def self.socket_limit()
|
503
|
+
result = ::CZMQ::FFI.zsys_socket_limit()
|
504
|
+
result
|
505
|
+
end
|
506
|
+
|
507
|
+
# Configure the maximum allowed size of a message sent.
|
508
|
+
# The default is INT_MAX.
|
509
|
+
#
|
510
|
+
# @param max_msgsz [Integer, #to_int, #to_i]
|
511
|
+
# @return [void]
|
512
|
+
def self.set_max_msgsz(max_msgsz)
|
513
|
+
max_msgsz = Integer(max_msgsz)
|
514
|
+
result = ::CZMQ::FFI.zsys_set_max_msgsz(max_msgsz)
|
515
|
+
result
|
516
|
+
end
|
517
|
+
|
518
|
+
# Return maximum message size.
|
519
|
+
#
|
520
|
+
# @return [Integer]
|
521
|
+
def self.max_msgsz()
|
522
|
+
result = ::CZMQ::FFI.zsys_max_msgsz()
|
523
|
+
result
|
524
|
+
end
|
525
|
+
|
526
|
+
# Configure the threshold value of filesystem object age per st_mtime
|
527
|
+
# that should elapse until we consider that object "stable" at the
|
528
|
+
# current zclock_time() moment.
|
529
|
+
# The default is S_DEFAULT_ZSYS_FILE_STABLE_AGE_MSEC defined in zsys.c
|
530
|
+
# which generally depends on host OS, with fallback value of 5000.
|
531
|
+
#
|
532
|
+
# @param file_stable_age_msec [::FFI::Pointer, #to_ptr]
|
533
|
+
# @return [void]
|
534
|
+
def self.set_file_stable_age_msec(file_stable_age_msec)
|
535
|
+
result = ::CZMQ::FFI.zsys_set_file_stable_age_msec(file_stable_age_msec)
|
536
|
+
result
|
537
|
+
end
|
538
|
+
|
539
|
+
# Return current threshold value of file stable age in msec.
|
540
|
+
# This can be used in code that chooses to wait for this timeout
|
541
|
+
# before testing if a filesystem object is "stable" or not.
|
542
|
+
#
|
543
|
+
# @return [::FFI::Pointer]
|
544
|
+
def self.file_stable_age_msec()
|
545
|
+
result = ::CZMQ::FFI.zsys_file_stable_age_msec()
|
546
|
+
result
|
547
|
+
end
|
548
|
+
|
549
|
+
# Configure the default linger timeout in msecs for new zsock instances.
|
550
|
+
# You can also set this separately on each zsock_t instance. The default
|
551
|
+
# linger time is zero, i.e. any pending messages will be dropped. If the
|
552
|
+
# environment variable ZSYS_LINGER is defined, that provides the default.
|
553
|
+
# Note that process exit will typically be delayed by the linger time.
|
554
|
+
#
|
555
|
+
# @param linger [Integer, #to_int, #to_i]
|
556
|
+
# @return [void]
|
557
|
+
def self.set_linger(linger)
|
558
|
+
linger = Integer(linger)
|
559
|
+
result = ::CZMQ::FFI.zsys_set_linger(linger)
|
560
|
+
result
|
561
|
+
end
|
562
|
+
|
563
|
+
# Configure the default outgoing pipe limit (HWM) for new zsock instances.
|
564
|
+
# You can also set this separately on each zsock_t instance. The default
|
565
|
+
# HWM is 1,000, on all versions of ZeroMQ. If the environment variable
|
566
|
+
# ZSYS_SNDHWM is defined, that provides the default. Note that a value of
|
567
|
+
# zero means no limit, i.e. infinite memory consumption.
|
568
|
+
#
|
569
|
+
# @param sndhwm [Integer, #to_int, #to_i]
|
570
|
+
# @return [void]
|
571
|
+
def self.set_sndhwm(sndhwm)
|
572
|
+
sndhwm = Integer(sndhwm)
|
573
|
+
result = ::CZMQ::FFI.zsys_set_sndhwm(sndhwm)
|
574
|
+
result
|
575
|
+
end
|
576
|
+
|
577
|
+
# Configure the default incoming pipe limit (HWM) for new zsock instances.
|
578
|
+
# You can also set this separately on each zsock_t instance. The default
|
579
|
+
# HWM is 1,000, on all versions of ZeroMQ. If the environment variable
|
580
|
+
# ZSYS_RCVHWM is defined, that provides the default. Note that a value of
|
581
|
+
# zero means no limit, i.e. infinite memory consumption.
|
582
|
+
#
|
583
|
+
# @param rcvhwm [Integer, #to_int, #to_i]
|
584
|
+
# @return [void]
|
585
|
+
def self.set_rcvhwm(rcvhwm)
|
586
|
+
rcvhwm = Integer(rcvhwm)
|
587
|
+
result = ::CZMQ::FFI.zsys_set_rcvhwm(rcvhwm)
|
588
|
+
result
|
589
|
+
end
|
590
|
+
|
591
|
+
# Configure the default HWM for zactor internal pipes; this is set on both
|
592
|
+
# ends of the pipe, for outgoing messages only (sndhwm). The default HWM is
|
593
|
+
# 1,000, on all versions of ZeroMQ. If the environment var ZSYS_ACTORHWM is
|
594
|
+
# defined, that provides the default. Note that a value of zero means no
|
595
|
+
# limit, i.e. infinite memory consumption.
|
596
|
+
#
|
597
|
+
# @param pipehwm [Integer, #to_int, #to_i]
|
598
|
+
# @return [void]
|
599
|
+
def self.set_pipehwm(pipehwm)
|
600
|
+
pipehwm = Integer(pipehwm)
|
601
|
+
result = ::CZMQ::FFI.zsys_set_pipehwm(pipehwm)
|
602
|
+
result
|
603
|
+
end
|
604
|
+
|
605
|
+
# Return the HWM for zactor internal pipes.
|
606
|
+
#
|
607
|
+
# @return [Integer]
|
608
|
+
def self.pipehwm()
|
609
|
+
result = ::CZMQ::FFI.zsys_pipehwm()
|
610
|
+
result
|
611
|
+
end
|
612
|
+
|
613
|
+
# Configure use of IPv6 for new zsock instances. By default sockets accept
|
614
|
+
# and make only IPv4 connections. When you enable IPv6, sockets will accept
|
615
|
+
# and connect to both IPv4 and IPv6 peers. You can override the setting on
|
616
|
+
# each zsock_t instance. The default is IPv4 only (ipv6 set to 0). If the
|
617
|
+
# environment variable ZSYS_IPV6 is defined (as 1 or 0), this provides the
|
618
|
+
# default. Note: has no effect on ZMQ v2.
|
619
|
+
#
|
620
|
+
# @param ipv6 [Integer, #to_int, #to_i]
|
621
|
+
# @return [void]
|
622
|
+
def self.set_ipv6(ipv6)
|
623
|
+
ipv6 = Integer(ipv6)
|
624
|
+
result = ::CZMQ::FFI.zsys_set_ipv6(ipv6)
|
625
|
+
result
|
626
|
+
end
|
627
|
+
|
628
|
+
# Return use of IPv6 for zsock instances.
|
629
|
+
#
|
630
|
+
# @return [Integer]
|
631
|
+
def self.ipv6()
|
632
|
+
result = ::CZMQ::FFI.zsys_ipv6()
|
633
|
+
result
|
634
|
+
end
|
635
|
+
|
636
|
+
# Set network interface name to use for broadcasts, particularly zbeacon.
|
637
|
+
# This lets the interface be configured for test environments where required.
|
638
|
+
# For example, on Mac OS X, zbeacon cannot bind to 255.255.255.255 which is
|
639
|
+
# the default when there is no specified interface. If the environment
|
640
|
+
# variable ZSYS_INTERFACE is set, use that as the default interface name.
|
641
|
+
# Setting the interface to "*" means "use all available interfaces".
|
642
|
+
#
|
643
|
+
# @param value [String, #to_s, nil]
|
644
|
+
# @return [void]
|
645
|
+
def self.set_interface(value)
|
646
|
+
result = ::CZMQ::FFI.zsys_set_interface(value)
|
647
|
+
result
|
648
|
+
end
|
649
|
+
|
650
|
+
# Return network interface to use for broadcasts, or "" if none was set.
|
651
|
+
#
|
652
|
+
# @return [String]
|
653
|
+
def self.interface()
|
654
|
+
result = ::CZMQ::FFI.zsys_interface()
|
655
|
+
result
|
656
|
+
end
|
657
|
+
|
658
|
+
# Set IPv6 address to use zbeacon socket, particularly for receiving zbeacon.
|
659
|
+
# This needs to be set IPv6 is enabled as IPv6 can have multiple addresses
|
660
|
+
# on a given interface. If the environment variable ZSYS_IPV6_ADDRESS is set,
|
661
|
+
# use that as the default IPv6 address.
|
662
|
+
#
|
663
|
+
# @param value [String, #to_s, nil]
|
664
|
+
# @return [void]
|
665
|
+
def self.set_ipv6_address(value)
|
666
|
+
result = ::CZMQ::FFI.zsys_set_ipv6_address(value)
|
667
|
+
result
|
668
|
+
end
|
669
|
+
|
670
|
+
# Return IPv6 address to use for zbeacon reception, or "" if none was set.
|
671
|
+
#
|
672
|
+
# @return [String]
|
673
|
+
def self.ipv6_address()
|
674
|
+
result = ::CZMQ::FFI.zsys_ipv6_address()
|
675
|
+
result
|
676
|
+
end
|
677
|
+
|
678
|
+
# Set IPv6 milticast address to use for sending zbeacon messages. This needs
|
679
|
+
# to be set if IPv6 is enabled. If the environment variable
|
680
|
+
# ZSYS_IPV6_MCAST_ADDRESS is set, use that as the default IPv6 multicast
|
681
|
+
# address.
|
682
|
+
#
|
683
|
+
# @param value [String, #to_s, nil]
|
684
|
+
# @return [void]
|
685
|
+
def self.set_ipv6_mcast_address(value)
|
686
|
+
result = ::CZMQ::FFI.zsys_set_ipv6_mcast_address(value)
|
687
|
+
result
|
688
|
+
end
|
689
|
+
|
690
|
+
# Return IPv6 multicast address to use for sending zbeacon, or "" if none was
|
691
|
+
# set.
|
692
|
+
#
|
693
|
+
# @return [String]
|
694
|
+
def self.ipv6_mcast_address()
|
695
|
+
result = ::CZMQ::FFI.zsys_ipv6_mcast_address()
|
696
|
+
result
|
697
|
+
end
|
698
|
+
|
699
|
+
# Configure the automatic use of pre-allocated FDs when creating new sockets.
|
700
|
+
# If 0 (default), nothing will happen. Else, when a new socket is bound, the
|
701
|
+
# system API will be used to check if an existing pre-allocated FD with a
|
702
|
+
# matching port (if TCP) or path (if IPC) exists, and if it does it will be
|
703
|
+
# set via the ZMQ_USE_FD socket option so that the library will use it
|
704
|
+
# instead of creating a new socket.
|
705
|
+
#
|
706
|
+
# @param auto_use_fd [Integer, #to_int, #to_i]
|
707
|
+
# @return [void]
|
708
|
+
def self.set_auto_use_fd(auto_use_fd)
|
709
|
+
auto_use_fd = Integer(auto_use_fd)
|
710
|
+
result = ::CZMQ::FFI.zsys_set_auto_use_fd(auto_use_fd)
|
711
|
+
result
|
712
|
+
end
|
713
|
+
|
714
|
+
# Return use of automatic pre-allocated FDs for zsock instances.
|
715
|
+
#
|
716
|
+
# @return [Integer]
|
717
|
+
def self.auto_use_fd()
|
718
|
+
result = ::CZMQ::FFI.zsys_auto_use_fd()
|
719
|
+
result
|
720
|
+
end
|
721
|
+
|
722
|
+
# Set log identity, which is a string that prefixes all log messages sent
|
723
|
+
# by this process. The log identity defaults to the environment variable
|
724
|
+
# ZSYS_LOGIDENT, if that is set.
|
725
|
+
#
|
726
|
+
# @param value [String, #to_s, nil]
|
727
|
+
# @return [void]
|
728
|
+
def self.set_logident(value)
|
729
|
+
result = ::CZMQ::FFI.zsys_set_logident(value)
|
730
|
+
result
|
731
|
+
end
|
732
|
+
|
733
|
+
# Set stream to receive log traffic. By default, log traffic is sent to
|
734
|
+
# stdout. If you set the stream to NULL, no stream will receive the log
|
735
|
+
# traffic (it may still be sent to the system facility).
|
736
|
+
#
|
737
|
+
# @param stream [::FFI::Pointer, #to_ptr]
|
738
|
+
# @return [void]
|
739
|
+
def self.set_logstream(stream)
|
740
|
+
result = ::CZMQ::FFI.zsys_set_logstream(stream)
|
741
|
+
result
|
742
|
+
end
|
743
|
+
|
744
|
+
# Sends log output to a PUB socket bound to the specified endpoint. To
|
745
|
+
# collect such log output, create a SUB socket, subscribe to the traffic
|
746
|
+
# you care about, and connect to the endpoint. Log traffic is sent as a
|
747
|
+
# single string frame, in the same format as when sent to stdout. The
|
748
|
+
# log system supports a single sender; multiple calls to this method will
|
749
|
+
# bind the same sender to multiple endpoints. To disable the sender, call
|
750
|
+
# this method with a null argument.
|
751
|
+
#
|
752
|
+
# @param endpoint [String, #to_s, nil]
|
753
|
+
# @return [void]
|
754
|
+
def self.set_logsender(endpoint)
|
755
|
+
result = ::CZMQ::FFI.zsys_set_logsender(endpoint)
|
756
|
+
result
|
757
|
+
end
|
758
|
+
|
759
|
+
# Enable or disable logging to the system facility (syslog on POSIX boxes,
|
760
|
+
# event log on Windows). By default this is disabled.
|
761
|
+
#
|
762
|
+
# @param logsystem [Boolean]
|
763
|
+
# @return [void]
|
764
|
+
def self.set_logsystem(logsystem)
|
765
|
+
logsystem = !(0==logsystem||!logsystem) # boolean
|
766
|
+
result = ::CZMQ::FFI.zsys_set_logsystem(logsystem)
|
767
|
+
result
|
768
|
+
end
|
769
|
+
|
770
|
+
# Log error condition - highest priority
|
771
|
+
#
|
772
|
+
# @param format [String, #to_s, nil]
|
773
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
774
|
+
# @return [void]
|
775
|
+
def self.error(format, *args)
|
776
|
+
result = ::CZMQ::FFI.zsys_error(format, *args)
|
777
|
+
result
|
778
|
+
end
|
779
|
+
|
780
|
+
# Log warning condition - high priority
|
781
|
+
#
|
782
|
+
# @param format [String, #to_s, nil]
|
783
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
784
|
+
# @return [void]
|
785
|
+
def self.warning(format, *args)
|
786
|
+
result = ::CZMQ::FFI.zsys_warning(format, *args)
|
787
|
+
result
|
788
|
+
end
|
789
|
+
|
790
|
+
# Log normal, but significant, condition - normal priority
|
791
|
+
#
|
792
|
+
# @param format [String, #to_s, nil]
|
793
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
794
|
+
# @return [void]
|
795
|
+
def self.notice(format, *args)
|
796
|
+
result = ::CZMQ::FFI.zsys_notice(format, *args)
|
797
|
+
result
|
798
|
+
end
|
799
|
+
|
800
|
+
# Log informational message - low priority
|
801
|
+
#
|
802
|
+
# @param format [String, #to_s, nil]
|
803
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
804
|
+
# @return [void]
|
805
|
+
def self.info(format, *args)
|
806
|
+
result = ::CZMQ::FFI.zsys_info(format, *args)
|
807
|
+
result
|
808
|
+
end
|
809
|
+
|
810
|
+
# Log debug-level message - lowest priority
|
811
|
+
#
|
812
|
+
# @param format [String, #to_s, nil]
|
813
|
+
# @param args [Array<Object>] see https://github.com/ffi/ffi/wiki/examples#using-varargs
|
814
|
+
# @return [void]
|
815
|
+
def self.debug(format, *args)
|
816
|
+
result = ::CZMQ::FFI.zsys_debug(format, *args)
|
817
|
+
result
|
818
|
+
end
|
819
|
+
|
820
|
+
# Self test of this class.
|
821
|
+
#
|
822
|
+
# @param verbose [Boolean]
|
823
|
+
# @return [void]
|
824
|
+
def self.test(verbose)
|
825
|
+
verbose = !(0==verbose||!verbose) # boolean
|
826
|
+
result = ::CZMQ::FFI.zsys_test(verbose)
|
827
|
+
result
|
828
|
+
end
|
829
|
+
end
|
830
|
+
end
|
831
|
+
end
|
832
|
+
|
833
|
+
################################################################################
|
834
|
+
# THIS FILE IS 100% GENERATED BY ZPROJECT; DO NOT EDIT EXCEPT EXPERIMENTALLY #
|
835
|
+
# Read the zproject/README.md for information about making permanent changes. #
|
836
|
+
################################################################################
|