This file is indexed.

/usr/share/zproject/czmq/zsys.api is in libczmq-dev 4.1.0-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
<class name = "zsys" state = "stable">
    <!--
    Copyright (c) the Contributors as noted in the AUTHORS file.
    This file is part of CZMQ, the high-level C binding for 0MQ:
    http://czmq.zeromq.org.

    This Source Code Form is subject to the terms of the Mozilla Public
    License, v. 2.0. If a copy of the MPL was not distributed with this
    file, You can obtain one at http://mozilla.org/MPL/2.0/.
    -->

    <callback_type name = "handler_fn">
        Callback for interrupt signal handler
        <argument name = "signal_value" type = "integer" />
    </callback_type>

    <method name = "init" singleton = "1">
        Initialize CZMQ zsys layer; this happens automatically when you create
        a socket or an actor; however this call lets you force initialization
        earlier, so e.g. logging is properly set-up before you start working.
        Not threadsafe, so call only from main thread. Safe to call multiple
        times. Returns global CZMQ context.
        <return type = "anything" />
    </method>

    <method name = "shutdown" singleton = "1">
        Optionally shut down the CZMQ zsys layer; this normally happens automatically
        when the process exits; however this call lets you force a shutdown
        earlier, avoiding any potential problems with atexit() ordering, especially
        with Windows dlls.
    </method>

    <method name = "socket" singleton = "1">
        Get a new ZMQ socket, automagically creating a ZMQ context if this is
        the first time. Caller is responsible for destroying the ZMQ socket
        before process exits, to avoid a ZMQ deadlock. Note: you should not use
        this method in CZMQ apps, use zsock_new() instead.
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "type" type = "integer" />
        <argument name = "filename" type = "string" />
        <argument name = "line_nbr" type = "size" />
        <return type = "anything" />
    </method>

    <method name = "close" singleton = "1">
        Destroy/close a ZMQ socket. You should call this for every socket you
        create using zsys_socket().
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "handle" type = "anything" />
        <argument name = "filename" type = "string" />
        <argument name = "line_nbr" type = "size" />
        <return type = "integer" />
    </method>

    <method name = "sockname" singleton = "1">
        Return ZMQ socket name for socket type
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "socktype" type = "integer" />
        <return type = "string" mutable = "1" />
    </method>

    <method name = "create pipe" singleton = "1">
        Create a pipe, which consists of two PAIR sockets connected over inproc.
        The pipe is configured to use the zsys_pipehwm setting. Returns the
        frontend socket successful, NULL if failed.
        <argument name = "backend_p" type = "zsock" by_reference = "1" />
        <return type = "zsock" />
    </method>

    <method name = "handler set" singleton = "1">
        Set interrupt handler; this saves the default handlers so that a
        zsys_handler_reset () can restore them. If you call this multiple times
        then the last handler will take affect. If handler_fn is NULL, disables
        default SIGINT/SIGTERM handling in CZMQ.
        <argument name = "handler_fn" type = "zsys_handler_fn" callback = "1" by_reference = "1" />
    </method>

    <method name = "handler reset" singleton = "1">
        Reset interrupt handler, call this at exit if needed
    </method>

    <method name = "catch interrupts" singleton = "1">
        Set default interrupt handler, so Ctrl-C or SIGTERM will set
        zsys_interrupted. Idempotent; safe to call multiple times.
        Can be supressed by ZSYS_SIGHANDLER=false
        *** This is for CZMQ internal use only and may change arbitrarily ***
    </method>

    <method name = "file exists" singleton = "1">
        Return 1 if file exists, else zero
        <argument name = "filename" type = "string" />
        <return type = "boolean" />
    </method>

    <method name = "file modified" singleton = "1">
        Return file modification time. Returns 0 if the file does not exist.
        <argument name = "filename" type = "string" />
        <return type = "time" />
    </method>

    <method name = "file mode" singleton = "1">
        Return file mode; provides at least support for the POSIX S_ISREG(m)
        and S_ISDIR(m) macros and the S_IRUSR and S_IWUSR bits, on all boxes.
        Returns a mode_t cast to int, or -1 in case of error.
        <argument name = "filename" type = "string" />
        <return type = "integer" />
    </method>

    <method name = "file delete" singleton = "1">
        Delete file. Does not complain if the file is absent
        <argument name = "filename" type = "string" />
        <return type = "integer" />
    </method>

    <method name = "file stable" singleton = "1">
        Check if file is 'stable'
        <argument name = "filename" type = "string" />
        <return type = "boolean" />
    </method>

    <method name = "dir create" singleton = "1" polymorphic = "1">
        Create a file path if it doesn't exist. The file path is treated as
        printf format.
        <argument name = "pathname" type = "string" variadic = "1" />
        <return type = "integer" />
    </method>

    <method name = "dir delete" singleton = "1" polymorphic = "1">
        Remove a file path if empty; the pathname is treated as printf format.
        <argument name = "pathname" type = "string" variadic = "1" />
        <return type = "integer" />
    </method>

    <method name = "dir change" singleton = "1">
        Move to a specified working directory. Returns 0 if OK, -1 if this failed.
        <argument name = "pathname" type = "string" />
        <return type = "integer" />
    </method>

    <method name = "file mode private" singleton = "1">
        Set private file creation mode; all files created from here will be
        readable/writable by the owner only.
    </method>

    <method name = "file mode default" singleton = "1">
        Reset default file creation mode; all files created from here will use
        process file mode defaults.
    </method>

    <method name = "version" singleton = "1">
        Return the CZMQ version for run-time API detection; returns version
        number into provided fields, providing reference isn't null in each case.
        <argument name = "major" type = "integer" by_reference = "1" />
        <argument name = "minor" type = "integer" by_reference = "1" />
        <argument name = "patch" type = "integer" by_reference = "1" />
    </method>

    <method name = "sprintf" singleton = "1" polymorphic = "1">
        Format a string using printf formatting, returning a freshly allocated
        buffer. If there was insufficient memory, returns NULL. Free the returned
        string using zstr_free().
        <argument name = "format" type = "string" variadic = "1" />
        <return type = "string" mutable = "1" />
    </method>

    <method name = "vprintf" singleton = "1" polymorphic = "1">
        Format a string with a va_list argument, returning a freshly allocated
        buffer. If there was insufficient memory, returns NULL. Free the returned
        string using zstr_free().
        <argument name = "format" type = "string"/>
        <argument name = "argptr" type = "va_list" />
        <return type = "string" mutable = "1" />
    </method>

    <method name = "udp new" singleton = "1">
        Create UDP beacon socket; if the routable option is true, uses
        multicast (not yet implemented), else uses broadcast. This method
        and related ones might _eventually_ be moved to a zudp class.
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "routable" type = "boolean" />
        <return type = "socket" />
    </method>

    <method name = "udp close" singleton = "1">
        Close a UDP socket
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "handle" type = "socket" />
        <return type = "integer" />
    </method>

    <method name = "udp send" singleton = "1">
        Send zframe to UDP socket, return -1 if sending failed due to
        interface having disappeared (happens easily with WiFi)
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "udpsock" type = "socket" />
        <argument name = "frame" type = "zframe" />
        <argument name = "address" type = "anything" c_type = "inaddr_t *" />
        <argument name = "addrlen" type = "integer" />
        <return type = "integer" />
    </method>

    <method name = "udp recv" singleton = "1">
        Receive zframe from UDP socket, and set address of peer that sent it
        The peername must be a char [INET_ADDRSTRLEN] array if IPv6 is disabled or
        NI_MAXHOST if it's enabled. Returns NULL when failing to get peer address.
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "udpsock" type = "socket" />
        <argument name = "peername" type = "string" mutable = "1" />
        <argument name = "peerlen" type = "integer" />
        <return type = "zframe" />
    </method>

    <method name = "socket error" singleton = "1">
        Handle an I/O error on some socket operation; will report and die on
        fatal errors, and continue silently on "try again" errors.
        *** This is for CZMQ internal use only and may change arbitrarily ***
        <argument name = "reason" type = "string" />
    </method>

    <method name = "hostname" singleton = "1">
        Return current host name, for use in public tcp:// endpoints. Caller gets
        a freshly allocated string, should free it using zstr_free(). If the host
        name is not resolvable, returns NULL.
        <return type = "string" mutable = "1" />
    </method>

    <method name = "daemonize" singleton = "1">
        Move the current process into the background. The precise effect depends
        on the operating system. On POSIX boxes, moves to a specified working
        directory (if specified), closes all file handles, reopens stdin, stdout,
        and stderr to the null device, and sets the process to ignore SIGHUP. On
        Windows, does nothing. Returns 0 if OK, -1 if there was an error.
        <argument name = "workdir" type = "string" />
        <return type = "integer" />
    </method>

    <method name = "run as" singleton = "1">
        Drop the process ID into the lockfile, with exclusive lock, and switch
        the process to the specified group and/or user. Any of the arguments
        may be null, indicating a no-op. Returns 0 on success, -1 on failure.
        Note if you combine this with zsys_daemonize, run after, not before
        that method, or the lockfile will hold the wrong process ID.
        <argument name = "lockfile" type = "string" />
        <argument name = "group" type = "string" />
        <argument name = "user" type = "string" />
        <return type = "integer" />
    </method>

    <method name = "has curve" singleton = "1">
        Returns true if the underlying libzmq supports CURVE security.
        Uses a heuristic probe according to the version of libzmq being used.
        <return type = "boolean" />
    </method>

    <method name = "set io threads" singleton = "1">
        Configure the number of I/O threads that ZeroMQ will use. A good
        rule of thumb is one thread per gigabit of traffic in or out. The
        default is 1, sufficient for most applications. If the environment
        variable ZSYS_IO_THREADS is defined, that provides the default.
        Note that this method is valid only before any socket is created.
        <argument name = "io_threads" type = "size" />
    </method>

    <method name = "set thread sched policy" singleton = "1">
        Configure the scheduling policy of the ZMQ context thread pool.
        Not available on Windows. See the sched_setscheduler man page or sched.h
        for more information. If the environment variable ZSYS_THREAD_SCHED_POLICY
        is defined, that provides the default.
        Note that this method is valid only before any socket is created.
        <argument name = "policy" type = "integer" />
    </method>

    <method name = "set thread priority" singleton = "1">
        Configure the scheduling priority of the ZMQ context thread pool.
        Not available on Windows. See the sched_setscheduler man page or sched.h
        for more information. If the environment variable ZSYS_THREAD_PRIORITY is
        defined, that provides the default.
        Note that this method is valid only before any socket is created.
        <argument name = "priority" type = "integer" />
    </method>

    <method name = "set max sockets" singleton = "1">
        Configure the number of sockets that ZeroMQ will allow. The default
        is 1024. The actual limit depends on the system, and you can query it
        by using zsys_socket_limit (). A value of zero means "maximum".
        Note that this method is valid only before any socket is created.
        <argument name = "max sockets" type = "size" />
    </method>

    <method name = "socket limit" singleton = "1">
        Return maximum number of ZeroMQ sockets that the system will support.
        <return type = "size" />
    </method>

    <method name = "set max msgsz" singleton = "1">
        Configure the maximum allowed size of a message sent.
        The default is INT_MAX.
        <argument name = "max msgsz" type = "integer" />
    </method>

    <method name = "max msgsz" singleton = "1">
        Return maximum message size.
        <return type = "integer" />
    </method>

    <method name = "set file stable age msec" singleton = "1" state = "draft">
        Configure the threshold value of filesystem object age per st_mtime
        that should elapse until we consider that object "stable" at the
        current zclock_time() moment.
        The default is S_DEFAULT_ZSYS_FILE_STABLE_AGE_MSEC defined in zsys.c
        which generally depends on host OS, with fallback value of 5000.
        <argument name = "file stable age msec" type = "msecs" />
    </method>

    <method name = "file stable age msec" singleton = "1" state = "draft">
        Return current threshold value of file stable age in msec.
        This can be used in code that chooses to wait for this timeout
        before testing if a filesystem object is "stable" or not.
        <return type = "msecs" />
    </method>

    <method name = "set linger" singleton = "1">
        Configure the default linger timeout in msecs for new zsock instances.
        You can also set this separately on each zsock_t instance. The default
        linger time is zero, i.e. any pending messages will be dropped. If the
        environment variable ZSYS_LINGER is defined, that provides the default.
        Note that process exit will typically be delayed by the linger time.
        <argument name = "linger" type = "size" />
    </method>

    <method name = "set sndhwm" singleton = "1">
        Configure the default outgoing pipe limit (HWM) for new zsock instances.
        You can also set this separately on each zsock_t instance. The default
        HWM is 1,000, on all versions of ZeroMQ. If the environment variable
        ZSYS_SNDHWM is defined, that provides the default. Note that a value of
        zero means no limit, i.e. infinite memory consumption.
        <argument name = "sndhwm" type = "size" />
    </method>

    <method name = "set rcvhwm" singleton = "1">
        Configure the default incoming pipe limit (HWM) for new zsock instances.
        You can also set this separately on each zsock_t instance. The default
        HWM is 1,000, on all versions of ZeroMQ. If the environment variable
        ZSYS_RCVHWM is defined, that provides the default. Note that a value of
        zero means no limit, i.e. infinite memory consumption.
        <argument name = "rcvhwm" type = "size" />
    </method>

    <method name = "set pipehwm" singleton = "1">
        Configure the default HWM for zactor internal pipes; this is set on both
        ends of the pipe, for outgoing messages only (sndhwm). The default HWM is
        1,000, on all versions of ZeroMQ. If the environment var ZSYS_ACTORHWM is
        defined, that provides the default. Note that a value of zero means no
        limit, i.e. infinite memory consumption.
        <argument name = "pipehwm" type = "size" />
    </method>

    <method name = "pipehwm" singleton = "1">
        Return the HWM for zactor internal pipes.
        <return type = "size" />
    </method>

    <method name = "set ipv6" singleton = "1">
        Configure use of IPv6 for new zsock instances. By default sockets accept
        and make only IPv4 connections. When you enable IPv6, sockets will accept
        and connect to both IPv4 and IPv6 peers. You can override the setting on
        each zsock_t instance. The default is IPv4 only (ipv6 set to 0). If the
        environment variable ZSYS_IPV6 is defined (as 1 or 0), this provides the
        default. Note: has no effect on ZMQ v2.
        <argument name = "ipv6" type = "integer" />
    </method>

    <method name = "ipv6" singleton = "1">
        Return use of IPv6 for zsock instances.
        <return type = "integer" />
    </method>

    <method name = "set interface" singleton = "1">
        Set network interface name to use for broadcasts, particularly zbeacon.
        This lets the interface be configured for test environments where required.
        For example, on Mac OS X, zbeacon cannot bind to 255.255.255.255 which is
        the default when there is no specified interface. If the environment
        variable ZSYS_INTERFACE is set, use that as the default interface name.
        Setting the interface to "*" means "use all available interfaces".
        <argument name = "value" type = "string" />
    </method>

    <method name = "interface" singleton = "1">
        Return network interface to use for broadcasts, or "" if none was set.
        <return type = "string" />
    </method>

    <method name = "set ipv6 address" singleton = "1">
        Set IPv6 address to use zbeacon socket, particularly for receiving zbeacon.
        This needs to be set IPv6 is enabled as IPv6 can have multiple addresses
        on a given interface. If the environment variable ZSYS_IPV6_ADDRESS is set,
        use that as the default IPv6 address.
        <argument name = "value" type = "string" />
    </method>

    <method name = "ipv6 address" singleton = "1">
        Return IPv6 address to use for zbeacon reception, or "" if none was set.
        <return type = "string" />
    </method>

    <method name = "set ipv6 mcast address" singleton = "1">
        Set IPv6 milticast address to use for sending zbeacon messages. This needs
        to be set if IPv6 is enabled. If the environment variable
        ZSYS_IPV6_MCAST_ADDRESS is set, use that as the default IPv6 multicast
        address.
        <argument name = "value" type = "string" />
    </method>

    <method name = "ipv6 mcast address" singleton = "1">
        Return IPv6 multicast address to use for sending zbeacon, or "" if none was
        set.
        <return type = "string" />
    </method>

    <method name = "set auto use fd" singleton = "1">
        Configure the automatic use of pre-allocated FDs when creating new sockets.
        If 0 (default), nothing will happen. Else, when a new socket is bound, the
        system API will be used to check if an existing pre-allocated FD with a
        matching port (if TCP) or path (if IPC) exists, and if it does it will be
        set via the ZMQ_USE_FD socket option so that the library will use it
        instead of creating a new socket.
        <argument name = "auto use fd" type = "integer" />
    </method>

    <method name = "auto use fd" singleton = "1">
        Return use of automatic pre-allocated FDs for zsock instances.
        <return type = "integer" />
    </method>

    <method name = "set logident" singleton = "1">
        Set log identity, which is a string that prefixes all log messages sent
        by this process. The log identity defaults to the environment variable
        ZSYS_LOGIDENT, if that is set.
        <argument name = "value" type = "string" />
    </method>

    <method name = "set logstream" singleton = "1">
        Set stream to receive log traffic. By default, log traffic is sent to
        stdout. If you set the stream to NULL, no stream will receive the log
        traffic (it may still be sent to the system facility).
        <argument name = "stream" type = "FILE" />
    </method>

    <method name = "set logsender" singleton = "1">
        Sends log output to a PUB socket bound to the specified endpoint. To
        collect such log output, create a SUB socket, subscribe to the traffic
        you care about, and connect to the endpoint. Log traffic is sent as a
        single string frame, in the same format as when sent to stdout. The
        log system supports a single sender; multiple calls to this method will
        bind the same sender to multiple endpoints. To disable the sender, call
        this method with a null argument.
        <argument name = "endpoint" type = "string" />
    </method>

    <method name = "set logsystem" singleton = "1">
        Enable or disable logging to the system facility (syslog on POSIX boxes,
        event log on Windows). By default this is disabled.
        <argument name = "logsystem" type = "boolean" />
    </method>

    <method name = "error" singleton = "1" polymorphic = "1">
        Log error condition - highest priority
        <argument name = "format" type = "string" variadic = "1" />
    </method>

    <method name = "warning" singleton = "1" polymorphic = "1">
        Log warning condition - high priority
        <argument name = "format" type = "string" variadic = "1" />
    </method>

    <method name = "notice" singleton = "1" polymorphic = "1">
        Log normal, but significant, condition - normal priority
        <argument name = "format" type = "string" variadic = "1" />
    </method>

    <method name = "info" singleton = "1" polymorphic = "1">
        Log informational message - low priority
        <argument name = "format" type = "string" variadic = "1" />
    </method>

    <method name = "debug" singleton = "1" polymorphic = "1">
        Log debug-level message - lowest priority
        <argument name = "format" type = "string" variadic = "1" />
    </method>
</class>