zmq_utils.h 3.5 KB
Newer Older
1
/*
2
    Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
3 4 5 6

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
7
    the terms of the GNU Lesser General Public License as published by
8 9 10 11 12 13
    the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.

    0MQ is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
    GNU Lesser General Public License for more details.
15

16
    You should have received a copy of the GNU Lesser General Public License
17 18 19
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

20 21 22
#ifndef __ZMQ_UTILS_H_INCLUDED__
#define __ZMQ_UTILS_H_INCLUDED__

23 24 25 26
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

27 28 29 30 31 32 33 34 35 36 37 38 39 40
/*  Define integer types needed for event interface                          */
#if defined ZMQ_HAVE_SOLARIS || defined ZMQ_HAVE_OPENVMS
#   include <inttypes.h>
#elif defined _MSC_VER && _MSC_VER < 1600
#   ifndef int32_t
typedef __int32 int32_t;
#   endif
#   ifndef uint16_t
typedef unsigned __int16 uint16_t;
#   endif
#else
#   include <stdint.h>
#endif

Martin Sustrik's avatar
Martin Sustrik committed
41 42 43 44
#ifdef __cplusplus
extern "C" {
#endif

45
/*  Handle DSO symbol visibility                                             */
46
#if defined _WIN32
47 48 49
#   if defined ZMQ_STATIC
#       define ZMQ_EXPORT
#   elif defined DLL_EXPORT
50 51 52 53 54
#       define ZMQ_EXPORT __declspec(dllexport)
#   else
#       define ZMQ_EXPORT __declspec(dllimport)
#   endif
#else
55 56 57 58 59 60
#   if defined __SUNPRO_C  || defined __SUNPRO_CC
#       define ZMQ_EXPORT __global
#   elif (defined __GNUC__ && __GNUC__ >= 4) || defined __INTEL_COMPILER
#       define ZMQ_EXPORT __attribute__ ((visibility("default")))
#   else
#       define ZMQ_EXPORT
61
#   endif
62
#endif
63

64 65 66 67 68 69 70 71 72 73 74 75
/* These functions are documented by man pages                                */

/* Encode data with Z85 encoding. Returns encoded data                        */
ZMQ_EXPORT char *zmq_z85_encode (char *dest, uint8_t *data, size_t size);

/* Decode data with Z85 encoding. Returns decoded data                        */
ZMQ_EXPORT uint8_t *zmq_z85_decode (uint8_t *dest, char *string);

/* Generate z85-encoded public and private keypair with libsodium.            */
/* Returns 0 on success.                                                      */
ZMQ_EXPORT int zmq_curve_keypair (char *z85_public_key, char *z85_secret_key);

76 77
typedef void (zmq_thread_fn) (void*);

78 79
/*  These functions are not documented by man pages                           */

80 81 82 83
/*  Helper functions are used by perf tests so that they don't have to care   */
/*  about minutiae of time-related functions on different OS platforms.       */

/*  Starts the stopwatch. Returns the handle to the watch.                    */
84
ZMQ_EXPORT void *zmq_stopwatch_start (void);
85 86 87

/*  Stops the stopwatch. Returns the number of microseconds elapsed since     */
/*  the stopwatch was started.                                                */
88
ZMQ_EXPORT unsigned long zmq_stopwatch_stop (void *watch_);
89 90

/*  Sleeps for specified number of seconds.                                   */
91 92
ZMQ_EXPORT void zmq_sleep (int seconds_);

93
/* Start a thread. Returns a handle to the thread.                            */
94
ZMQ_EXPORT void *zmq_threadstart (zmq_thread_fn* func, void* arg);
95 96

/* Wait for thread to complete then free up resources.                        */
97
ZMQ_EXPORT void zmq_threadclose (void* thread);
98

99
#undef ZMQ_EXPORT
100

Martin Sustrik's avatar
Martin Sustrik committed
101 102 103 104
#ifdef __cplusplus
}
#endif

105
#endif