Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
91394d27
Commit
91394d27
authored
May 03, 2016
by
Doron Somech
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1945 from bluca/draft_api
problem: no way to disable draft when compiling
parents
464d3fd3
b7413507
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
260 additions
and
105 deletions
+260
-105
.gitignore
.gitignore
+1
-0
.travis.yml
.travis.yml
+5
-5
CMakeLists.txt
CMakeLists.txt
+14
-0
Makefile.am
Makefile.am
+31
-28
ci_build.sh
ci_build.sh
+6
-0
configure.ac
configure.ac
+27
-0
zmq.h
include/zmq.h
+74
-60
libzmq.pc.cmake.in
src/libzmq.pc.cmake.in
+1
-1
libzmq.pc.in
src/libzmq.pc.in
+1
-1
precompiled.hpp
src/precompiled.hpp
+75
-1
CMakeLists.txt
tests/CMakeLists.txt
+13
-7
test_poller.cpp
tests/test_poller.cpp
+6
-0
test_use_fd_ipc.cpp
tests/test_use_fd_ipc.cpp
+2
-0
test_use_fd_tcp.cpp
tests/test_use_fd_tcp.cpp
+2
-0
testutil.hpp
tests/testutil.hpp
+2
-2
No files found.
.gitignore
View file @
91394d27
...
@@ -130,6 +130,7 @@ test_scatter_gather
...
@@ -130,6 +130,7 @@ test_scatter_gather
test_socketopt_hwm
test_socketopt_hwm
test_use_fd_ipc
test_use_fd_ipc
test_use_fd_tcp
test_use_fd_tcp
test_pub_invert_matching
tests/test*.log
tests/test*.log
tests/test*.trs
tests/test*.trs
src/platform.hpp*
src/platform.hpp*
...
...
.travis.yml
View file @
91394d27
...
@@ -9,19 +9,19 @@ os:
...
@@ -9,19 +9,19 @@ os:
dist
:
trusty
dist
:
trusty
env
:
env
:
-
BUILD_TYPE=default CURVE=tweetnacl
-
BUILD_TYPE=default CURVE=tweetnacl
DRAFT=enabled
-
BUILD_TYPE=android CURVE=tweetnacl
-
BUILD_TYPE=android CURVE=tweetnacl
-
BUILD_TYPE=cmake CURVE=tweetnacl
-
BUILD_TYPE=cmake CURVE=tweetnacl
-
BUILD_TYPE=default CURVE=libsodium
-
BUILD_TYPE=default CURVE=libsodium
-
BUILD_TYPE=default
-
BUILD_TYPE=default
-
BUILD_TYPE=coverage CURVE=tweetnacl
-
BUILD_TYPE=coverage CURVE=tweetnacl
DRAFT=enabled
-
BUILD_TYPE=valgrind CURVE=tweetnacl
-
BUILD_TYPE=valgrind CURVE=tweetnacl
DRAFT=enabled
matrix
:
matrix
:
exclude
:
exclude
:
-
env
:
BUILD_TYPE=coverage CURVE=tweetnacl
-
env
:
BUILD_TYPE=coverage CURVE=tweetnacl
DRAFT=enabled
os
:
osx
os
:
osx
-
env
:
BUILD_TYPE=valgrind CURVE=tweetnacl
-
env
:
BUILD_TYPE=valgrind CURVE=tweetnacl
DRAFT=enabled
os
:
osx
os
:
osx
include
:
include
:
-
env
:
BUILD_TYPE=default CURVE=tweetnacl IPv6=ON
-
env
:
BUILD_TYPE=default CURVE=tweetnacl IPv6=ON
...
...
CMakeLists.txt
View file @
91394d27
...
@@ -57,6 +57,20 @@ else ()
...
@@ -57,6 +57,20 @@ else ()
set
(
ZMQ_HAVE_CURVE 1
)
set
(
ZMQ_HAVE_CURVE 1
)
endif
()
endif
()
set
(
SOURCE_DIR
"
${
CMAKE_CURRENT_SOURCE_DIR
}
"
)
if
(
EXISTS
"
${
SOURCE_DIR
}
/.git"
)
OPTION
(
ENABLE_DRAFTS
"Build and install draft classes and methods"
ON
)
else
()
OPTION
(
ENABLE_DRAFTS
"Build and install draft classes and methods"
OFF
)
endif
()
IF
(
ENABLE_DRAFTS
)
ADD_DEFINITIONS
(
-DZMQ_BUILD_DRAFT_API
)
set
(
pkg_config_defines
"-DZMQ_BUILD_DRAFT_API=1"
)
ELSE
(
ENABLE_DRAFTS
)
set
(
pkg_config_defines
""
)
ENDIF
(
ENABLE_DRAFTS
)
set
(
POLLER
""
CACHE STRING
"Choose polling system. valid values are
set
(
POLLER
""
CACHE STRING
"Choose polling system. valid values are
kqueue, epoll, devpoll, poll or select [default=autodetect]"
)
kqueue, epoll, devpoll, poll or select [default=autodetect]"
)
...
...
Makefile.am
View file @
91394d27
...
@@ -391,16 +391,9 @@ test_apps = \
...
@@ -391,16 +391,9 @@ test_apps = \
tests/test_xpub_manual
\
tests/test_xpub_manual
\
tests/test_xpub_welcome_msg
\
tests/test_xpub_welcome_msg
\
tests/test_atomics
\
tests/test_atomics
\
tests/test_client_server
\
tests/test_thread_safe
\
tests/test_sockopt_hwm
\
tests/test_sockopt_hwm
\
tests/test_heartbeats
\
tests/test_heartbeats
\
tests/test_stream_exceeds_buffer
\
tests/test_stream_exceeds_buffer
\
tests/test_poller
\
tests/test_timers
\
tests/test_radio_dish
\
tests/test_udp
\
tests/test_scatter_gather
\
tests/test_pub_invert_matching
tests/test_pub_invert_matching
tests_test_system_SOURCES
=
tests/test_system.cpp
tests_test_system_SOURCES
=
tests/test_system.cpp
...
@@ -588,12 +581,6 @@ tests_test_xpub_welcome_msg_LDADD = src/libzmq.la
...
@@ -588,12 +581,6 @@ tests_test_xpub_welcome_msg_LDADD = src/libzmq.la
tests_test_atomics_SOURCES
=
tests/test_atomics.cpp
tests_test_atomics_SOURCES
=
tests/test_atomics.cpp
tests_test_atomics_LDADD
=
src/libzmq.la
tests_test_atomics_LDADD
=
src/libzmq.la
tests_test_client_server_SOURCES
=
tests/test_client_server.cpp
tests_test_client_server_LDADD
=
src/libzmq.la
tests_test_thread_safe_SOURCES
=
tests/test_thread_safe.cpp
tests_test_thread_safe_LDADD
=
src/libzmq.la
tests_test_sockopt_hwm_SOURCES
=
tests/test_sockopt_hwm.cpp
tests_test_sockopt_hwm_SOURCES
=
tests/test_sockopt_hwm.cpp
tests_test_sockopt_hwm_LDADD
=
src/libzmq.la
tests_test_sockopt_hwm_LDADD
=
src/libzmq.la
...
@@ -606,21 +593,6 @@ tests_test_heartbeats_LDADD = src/libzmq.la
...
@@ -606,21 +593,6 @@ tests_test_heartbeats_LDADD = src/libzmq.la
tests_test_stream_exceeds_buffer_SOURCES
=
tests/test_stream_exceeds_buffer.cpp
tests_test_stream_exceeds_buffer_SOURCES
=
tests/test_stream_exceeds_buffer.cpp
tests_test_stream_exceeds_buffer_LDADD
=
src/libzmq.la
tests_test_stream_exceeds_buffer_LDADD
=
src/libzmq.la
tests_test_poller_SOURCES
=
tests/test_poller.cpp
tests_test_poller_LDADD
=
src/libzmq.la
tests_test_timers_SOURCES
=
tests/test_timers.cpp
tests_test_timers_LDADD
=
src/libzmq.la
tests_test_radio_dish_SOURCES
=
tests/test_radio_dish.cpp
tests_test_radio_dish_LDADD
=
src/libzmq.la
tests_test_udp_SOURCES
=
tests/test_udp.cpp
tests_test_udp_LDADD
=
src/libzmq.la
tests_test_scatter_gather_SOURCES
=
tests/test_scatter_gather.cpp
tests_test_scatter_gather_LDADD
=
src/libzmq.la
tests_test_pub_invert_matching_SOURCES
=
tests/test_pub_invert_matching.cpp
tests_test_pub_invert_matching_SOURCES
=
tests/test_pub_invert_matching.cpp
tests_test_pub_invert_matching_LDADD
=
src/libzmq.la
tests_test_pub_invert_matching_LDADD
=
src/libzmq.la
...
@@ -740,6 +712,37 @@ test_reqrep_vmci_CXXFLAGS = @LIBZMQ_VMCI_CXXFLAGS@
...
@@ -740,6 +712,37 @@ test_reqrep_vmci_CXXFLAGS = @LIBZMQ_VMCI_CXXFLAGS@
endif
endif
if
ENABLE_DRAFTS
test_apps
+=
tests/test_poller
\
tests/test_client_server
\
tests/test_thread_safe
\
tests/test_timers
\
tests/test_radio_dish
\
tests/test_udp
\
tests/test_scatter_gather
tests_test_poller_SOURCES
=
tests/test_poller.cpp
tests_test_poller_LDADD
=
src/libzmq.la
tests_test_client_server_SOURCES
=
tests/test_client_server.cpp
tests_test_client_server_LDADD
=
src/libzmq.la
tests_test_thread_safe_SOURCES
=
tests/test_thread_safe.cpp
tests_test_thread_safe_LDADD
=
src/libzmq.la
tests_test_timers_SOURCES
=
tests/test_timers.cpp
tests_test_timers_LDADD
=
src/libzmq.la
tests_test_radio_dish_SOURCES
=
tests/test_radio_dish.cpp
tests_test_radio_dish_LDADD
=
src/libzmq.la
tests_test_udp_SOURCES
=
tests/test_udp.cpp
tests_test_udp_LDADD
=
src/libzmq.la
tests_test_scatter_gather_SOURCES
=
tests/test_scatter_gather.cpp
tests_test_scatter_gather_LDADD
=
src/libzmq.la
endif
check_PROGRAMS
=
${
test_apps
}
check_PROGRAMS
=
${
test_apps
}
# Run the test cases
# Run the test cases
...
...
ci_build.sh
View file @
91394d27
...
@@ -23,6 +23,12 @@ if [ $BUILD_TYPE == "default" ]; then
...
@@ -23,6 +23,12 @@ if [ $BUILD_TYPE == "default" ]; then
(
cd
libsodium
;
./autogen.sh
;
./configure
--prefix
=
$BUILD_PREFIX
;
make check
;
make
install
)
(
cd
libsodium
;
./autogen.sh
;
./configure
--prefix
=
$BUILD_PREFIX
;
make check
;
make
install
)
fi
fi
if
[
-z
$DRAFT
]
||
[
$DRAFT
==
"disabled"
]
;
then
CONFIG_OPTS+
=(
"--enable-drafts=no"
)
elif
[
$DRAFT
==
"enabled"
]
;
then
CONFIG_OPTS+
=(
"--enable-drafts=yes"
)
fi
# Build and check this project
# Build and check this project
(
(
./autogen.sh
&&
./autogen.sh
&&
...
...
configure.ac
View file @
91394d27
...
@@ -605,6 +605,33 @@ LIBZMQ_CHECK_TCP_KEEPALIVE([
...
@@ -605,6 +605,33 @@ LIBZMQ_CHECK_TCP_KEEPALIVE([
AM_CONDITIONAL(HAVE_FORK, test "x$ac_cv_func_fork" = "xyes")
AM_CONDITIONAL(HAVE_FORK, test "x$ac_cv_func_fork" = "xyes")
if test "x$cross_compiling" = "xyes"; then
# Enable draft by default when cross-compiling
defaultval=yes
else
# enable draft API by default if we're in a git repository
# else disable it by default; then allow --enable-drafts=yes/no override
AC_CHECK_FILE($srcdir/.git, [defaultval=yes], [defaultval=no])
fi
AC_ARG_ENABLE([drafts],
AS_HELP_STRING([--enable-drafts],
[Build and install draft classes and methods [default=yes]]),
[enable_drafts=$enableval],
[enable_drafts=$defaultval])
AM_CONDITIONAL([ENABLE_DRAFTS], [test x$enable_drafts != xno])
if test "x$enable_drafts" = "xyes"; then
AC_MSG_NOTICE([Building stable and legacy API + draft API])
AC_DEFINE(ZMQ_BUILD_DRAFT_API, 1, [Provide draft classes and methods])
AC_SUBST(pkg_config_defines, "-DZMQ_BUILD_DRAFT_API=1")
# CPPFLAGS="-DZMQ_BUILD_DRAFT_API=1 $CPPFLAGS"
else
AC_MSG_NOTICE([Building stable and legacy API (no draft API)])
AC_SUBST(pkg_config_defines, "")
fi
# Subst LIBZMQ_EXTRA_CFLAGS & CXXFLAGS & LDFLAGS
# Subst LIBZMQ_EXTRA_CFLAGS & CXXFLAGS & LDFLAGS
AC_SUBST(LIBZMQ_EXTRA_CFLAGS)
AC_SUBST(LIBZMQ_EXTRA_CFLAGS)
AC_SUBST(LIBZMQ_EXTRA_CXXFLAGS)
AC_SUBST(LIBZMQ_EXTRA_CXXFLAGS)
...
...
include/zmq.h
View file @
91394d27
...
@@ -260,12 +260,6 @@ ZMQ_EXPORT const char *zmq_msg_group (zmq_msg_t *msg);
...
@@ -260,12 +260,6 @@ ZMQ_EXPORT const char *zmq_msg_group (zmq_msg_t *msg);
#define ZMQ_XPUB 9
#define ZMQ_XPUB 9
#define ZMQ_XSUB 10
#define ZMQ_XSUB 10
#define ZMQ_STREAM 11
#define ZMQ_STREAM 11
#define ZMQ_SERVER 12
#define ZMQ_CLIENT 13
#define ZMQ_RADIO 14
#define ZMQ_DISH 15
#define ZMQ_GATHER 16
#define ZMQ_SCATTER 17
/* Deprecated aliases */
/* Deprecated aliases */
#define ZMQ_XREQ ZMQ_DEALER
#define ZMQ_XREQ ZMQ_DEALER
...
@@ -410,8 +404,6 @@ ZMQ_EXPORT int zmq_send (void *s, const void *buf, size_t len, int flags);
...
@@ -410,8 +404,6 @@ ZMQ_EXPORT int zmq_send (void *s, const void *buf, size_t len, int flags);
ZMQ_EXPORT
int
zmq_send_const
(
void
*
s
,
const
void
*
buf
,
size_t
len
,
int
flags
);
ZMQ_EXPORT
int
zmq_send_const
(
void
*
s
,
const
void
*
buf
,
size_t
len
,
int
flags
);
ZMQ_EXPORT
int
zmq_recv
(
void
*
s
,
void
*
buf
,
size_t
len
,
int
flags
);
ZMQ_EXPORT
int
zmq_recv
(
void
*
s
,
void
*
buf
,
size_t
len
,
int
flags
);
ZMQ_EXPORT
int
zmq_socket_monitor
(
void
*
s
,
const
char
*
addr
,
int
events
);
ZMQ_EXPORT
int
zmq_socket_monitor
(
void
*
s
,
const
char
*
addr
,
int
events
);
ZMQ_EXPORT
int
zmq_join
(
void
*
s
,
const
char
*
group
);
ZMQ_EXPORT
int
zmq_leave
(
void
*
s
,
const
char
*
group
);
/******************************************************************************/
/******************************************************************************/
...
@@ -439,58 +431,6 @@ typedef struct zmq_pollitem_t
...
@@ -439,58 +431,6 @@ typedef struct zmq_pollitem_t
ZMQ_EXPORT
int
zmq_poll
(
zmq_pollitem_t
*
items
,
int
nitems
,
long
timeout
);
ZMQ_EXPORT
int
zmq_poll
(
zmq_pollitem_t
*
items
,
int
nitems
,
long
timeout
);
/******************************************************************************/
/* Poller polling on sockets,fd and thread-safe sockets */
/******************************************************************************/
#define ZMQ_HAVE_POLLER
typedef
struct
zmq_poller_event_t
{
void
*
socket
;
#if defined _WIN32
SOCKET
fd
;
#else
int
fd
;
#endif
void
*
user_data
;
short
events
;
}
zmq_poller_event_t
;
ZMQ_EXPORT
void
*
zmq_poller_new
(
void
);
ZMQ_EXPORT
int
zmq_poller_destroy
(
void
**
poller_p
);
ZMQ_EXPORT
int
zmq_poller_add
(
void
*
poller
,
void
*
socket
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify
(
void
*
poller
,
void
*
socket
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove
(
void
*
poller
,
void
*
socket
);
ZMQ_EXPORT
int
zmq_poller_wait
(
void
*
poller
,
zmq_poller_event_t
*
event
,
long
timeout
);
#if defined _WIN32
ZMQ_EXPORT
int
zmq_poller_add_fd
(
void
*
poller
,
SOCKET
fd
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify_fd
(
void
*
poller
,
SOCKET
fd
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove_fd
(
void
*
poller
,
SOCKET
fd
);
#else
ZMQ_EXPORT
int
zmq_poller_add_fd
(
void
*
poller
,
int
fd
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify_fd
(
void
*
poller
,
int
fd
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove_fd
(
void
*
poller
,
int
fd
);
#endif
/******************************************************************************/
/* Scheduling timers */
/******************************************************************************/
#define ZMQ_HAVE_TIMERS
typedef
void
(
zmq_timer_fn
)(
int
timer_id
,
void
*
arg
);
ZMQ_EXPORT
void
*
zmq_timers_new
(
void
);
ZMQ_EXPORT
int
zmq_timers_destroy
(
void
**
timers_p
);
ZMQ_EXPORT
int
zmq_timers_add
(
void
*
timers
,
size_t
interval
,
zmq_timer_fn
handler
,
void
*
arg
);
ZMQ_EXPORT
int
zmq_timers_cancel
(
void
*
timers
,
int
timer_id
);
ZMQ_EXPORT
int
zmq_timers_set_interval
(
void
*
timers
,
int
timer_id
,
size_t
interval
);
ZMQ_EXPORT
int
zmq_timers_reset
(
void
*
timers
,
int
timer_id
);
ZMQ_EXPORT
long
zmq_timers_timeout
(
void
*
timers
);
ZMQ_EXPORT
int
zmq_timers_execute
(
void
*
timers
);
/******************************************************************************/
/******************************************************************************/
/* Message proxying */
/* Message proxying */
/******************************************************************************/
/******************************************************************************/
...
@@ -575,6 +515,80 @@ ZMQ_EXPORT void *zmq_threadstart (zmq_thread_fn* func, void* arg);
...
@@ -575,6 +515,80 @@ ZMQ_EXPORT void *zmq_threadstart (zmq_thread_fn* func, void* arg);
ZMQ_EXPORT
void
zmq_threadclose
(
void
*
thread
);
ZMQ_EXPORT
void
zmq_threadclose
(
void
*
thread
);
/******************************************************************************/
/* These functions are DRAFT and disabled in stable releases, and subject to */
/* change at ANY time until declared stable. */
/******************************************************************************/
#ifdef ZMQ_BUILD_DRAFT_API
/* DRAFT Socket types. */
#define ZMQ_SERVER 12
#define ZMQ_CLIENT 13
#define ZMQ_RADIO 14
#define ZMQ_DISH 15
#define ZMQ_GATHER 16
#define ZMQ_SCATTER 17
/* DRAFT Socket events. */
ZMQ_EXPORT
int
zmq_join
(
void
*
s
,
const
char
*
group
);
ZMQ_EXPORT
int
zmq_leave
(
void
*
s
,
const
char
*
group
);
/******************************************************************************/
/* Poller polling on sockets,fd and thread-safe sockets */
/******************************************************************************/
#define ZMQ_HAVE_POLLER
typedef
struct
zmq_poller_event_t
{
void
*
socket
;
#if defined _WIN32
SOCKET
fd
;
#else
int
fd
;
#endif
void
*
user_data
;
short
events
;
}
zmq_poller_event_t
;
ZMQ_EXPORT
void
*
zmq_poller_new
(
void
);
ZMQ_EXPORT
int
zmq_poller_destroy
(
void
**
poller_p
);
ZMQ_EXPORT
int
zmq_poller_add
(
void
*
poller
,
void
*
socket
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify
(
void
*
poller
,
void
*
socket
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove
(
void
*
poller
,
void
*
socket
);
ZMQ_EXPORT
int
zmq_poller_wait
(
void
*
poller
,
zmq_poller_event_t
*
event
,
long
timeout
);
#if defined _WIN32
ZMQ_EXPORT
int
zmq_poller_add_fd
(
void
*
poller
,
SOCKET
fd
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify_fd
(
void
*
poller
,
SOCKET
fd
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove_fd
(
void
*
poller
,
SOCKET
fd
);
#else
ZMQ_EXPORT
int
zmq_poller_add_fd
(
void
*
poller
,
int
fd
,
void
*
user_data
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_modify_fd
(
void
*
poller
,
int
fd
,
short
events
);
ZMQ_EXPORT
int
zmq_poller_remove_fd
(
void
*
poller
,
int
fd
);
#endif
/******************************************************************************/
/* Scheduling timers */
/******************************************************************************/
#define ZMQ_HAVE_TIMERS
typedef
void
(
zmq_timer_fn
)(
int
timer_id
,
void
*
arg
);
ZMQ_EXPORT
void
*
zmq_timers_new
(
void
);
ZMQ_EXPORT
int
zmq_timers_destroy
(
void
**
timers_p
);
ZMQ_EXPORT
int
zmq_timers_add
(
void
*
timers
,
size_t
interval
,
zmq_timer_fn
handler
,
void
*
arg
);
ZMQ_EXPORT
int
zmq_timers_cancel
(
void
*
timers
,
int
timer_id
);
ZMQ_EXPORT
int
zmq_timers_set_interval
(
void
*
timers
,
int
timer_id
,
size_t
interval
);
ZMQ_EXPORT
int
zmq_timers_reset
(
void
*
timers
,
int
timer_id
);
ZMQ_EXPORT
long
zmq_timers_timeout
(
void
*
timers
);
ZMQ_EXPORT
int
zmq_timers_execute
(
void
*
timers
);
#endif // ZMQ_BUILD_DRAFT_API
#undef ZMQ_EXPORT
#undef ZMQ_EXPORT
#ifdef __cplusplus
#ifdef __cplusplus
...
...
src/libzmq.pc.cmake.in
View file @
91394d27
...
@@ -8,4 +8,4 @@ Description: 0MQ c++ library
...
@@ -8,4 +8,4 @@ Description: 0MQ c++ library
Version: @ZMQ_VERSION_MAJOR@.@ZMQ_VERSION_MINOR@.@ZMQ_VERSION_PATCH@
Version: @ZMQ_VERSION_MAJOR@.@ZMQ_VERSION_MINOR@.@ZMQ_VERSION_PATCH@
Libs: -L${libdir} -lzmq
Libs: -L${libdir} -lzmq
Libs.private: -lstdc++
Libs.private: -lstdc++
Cflags: -I${includedir}
Cflags: -I${includedir}
@pkg_config_defines@
src/libzmq.pc.in
View file @
91394d27
...
@@ -8,4 +8,4 @@ Description: 0MQ c++ library
...
@@ -8,4 +8,4 @@ Description: 0MQ c++ library
Version: @VERSION@
Version: @VERSION@
Libs: -L${libdir} -lzmq
Libs: -L${libdir} -lzmq
Libs.private: -lstdc++
Libs.private: -lstdc++
Cflags: -I${includedir}
Cflags: -I${includedir}
@pkg_config_defines@
src/precompiled.hpp
View file @
91394d27
...
@@ -138,10 +138,84 @@
...
@@ -138,10 +138,84 @@
#include <string>
#include <string>
#include <vector>
#include <vector>
#endif // _MSC_VER
// 0MQ definitions and exported functions
// 0MQ definitions and exported functions
#include "platform.hpp"
#include "../include/zmq.h"
#include "../include/zmq.h"
#endif // _MSC_VER
/******************************************************************************/
/* These functions are DRAFT and disabled in stable releases, and subject to */
/* change at ANY time until declared stable. */
/******************************************************************************/
#ifndef ZMQ_BUILD_DRAFT_API
/* DRAFT Socket types. */
#define ZMQ_SERVER 12
#define ZMQ_CLIENT 13
#define ZMQ_RADIO 14
#define ZMQ_DISH 15
#define ZMQ_GATHER 16
#define ZMQ_SCATTER 17
/* DRAFT Socket events. */
int
zmq_join
(
void
*
s
,
const
char
*
group
);
int
zmq_leave
(
void
*
s
,
const
char
*
group
);
/******************************************************************************/
/* Poller polling on sockets,fd and thread-safe sockets */
/******************************************************************************/
#define ZMQ_HAVE_POLLER
typedef
struct
zmq_poller_event_t
{
void
*
socket
;
#if defined _WIN32
SOCKET
fd
;
#else
int
fd
;
#endif
void
*
user_data
;
short
events
;
}
zmq_poller_event_t
;
void
*
zmq_poller_new
(
void
);
int
zmq_poller_destroy
(
void
**
poller_p
);
int
zmq_poller_add
(
void
*
poller
,
void
*
socket
,
void
*
user_data
,
short
events
);
int
zmq_poller_modify
(
void
*
poller
,
void
*
socket
,
short
events
);
int
zmq_poller_remove
(
void
*
poller
,
void
*
socket
);
int
zmq_poller_wait
(
void
*
poller
,
zmq_poller_event_t
*
event
,
long
timeout
);
#if defined _WIN32
int
zmq_poller_add_fd
(
void
*
poller
,
SOCKET
fd
,
void
*
user_data
,
short
events
);
int
zmq_poller_modify_fd
(
void
*
poller
,
SOCKET
fd
,
short
events
);
int
zmq_poller_remove_fd
(
void
*
poller
,
SOCKET
fd
);
#else
int
zmq_poller_add_fd
(
void
*
poller
,
int
fd
,
void
*
user_data
,
short
events
);
int
zmq_poller_modify_fd
(
void
*
poller
,
int
fd
,
short
events
);
int
zmq_poller_remove_fd
(
void
*
poller
,
int
fd
);
#endif
/******************************************************************************/
/* Scheduling timers */
/******************************************************************************/
#define ZMQ_HAVE_TIMERS
typedef
void
(
zmq_timer_fn
)(
int
timer_id
,
void
*
arg
);
void
*
zmq_timers_new
(
void
);
int
zmq_timers_destroy
(
void
**
timers_p
);
int
zmq_timers_add
(
void
*
timers
,
size_t
interval
,
zmq_timer_fn
handler
,
void
*
arg
);
int
zmq_timers_cancel
(
void
*
timers
,
int
timer_id
);
int
zmq_timers_set_interval
(
void
*
timers
,
int
timer_id
,
size_t
interval
);
int
zmq_timers_reset
(
void
*
timers
,
int
timer_id
);
long
zmq_timers_timeout
(
void
*
timers
);
int
zmq_timers_execute
(
void
*
timers
);
#endif // ZMQ_BUILD_DRAFT_API
#endif //ifndef __ZMQ_PRECOMPILED_HPP_INCLUDED__
#endif //ifndef __ZMQ_PRECOMPILED_HPP_INCLUDED__
tests/CMakeLists.txt
View file @
91394d27
...
@@ -52,12 +52,9 @@ set(tests
...
@@ -52,12 +52,9 @@ set(tests
test_connect_rid
test_connect_rid
test_xpub_nodrop
test_xpub_nodrop
test_pub_invert_matching
test_pub_invert_matching
test_thread_safe
test_client_server
test_setsockopt
test_setsockopt
test_sockopt_hwm
test_sockopt_hwm
test_heartbeats
test_heartbeats
test_poller
test_atomics
test_atomics
test_bind_src_address
test_bind_src_address
test_capabilities
test_capabilities
...
@@ -67,10 +64,6 @@ set(tests
...
@@ -67,10 +64,6 @@ set(tests
test_stream_timeout
test_stream_timeout
test_xpub_manual
test_xpub_manual
test_xpub_welcome_msg
test_xpub_welcome_msg
test_timers
test_radio_dish
test_udp
test_scatter_gather
)
)
if
(
NOT WIN32
)
if
(
NOT WIN32
)
list
(
APPEND tests
list
(
APPEND tests
...
@@ -117,6 +110,19 @@ if(WITH_VMCI)
...
@@ -117,6 +110,19 @@ if(WITH_VMCI)
)
)
endif
()
endif
()
IF
(
ENABLE_DRAFTS
)
list
(
APPEND tests
test_poller
test_thread_safe
test_client_server
test_timers
test_radio_dish
test_udp
test_scatter_gather
)
ENDIF
(
ENABLE_DRAFTS
)
# add location of platform.hpp for Windows builds
# add location of platform.hpp for Windows builds
if
(
WIN32
)
if
(
WIN32
)
add_definitions
(
-DZMQ_CUSTOM_PLATFORM_HPP
)
add_definitions
(
-DZMQ_CUSTOM_PLATFORM_HPP
)
...
...
tests/test_poller.cpp
View file @
91394d27
...
@@ -50,6 +50,7 @@ int main (void)
...
@@ -50,6 +50,7 @@ int main (void)
void
*
bowl
=
zmq_socket
(
ctx
,
ZMQ_PULL
);
void
*
bowl
=
zmq_socket
(
ctx
,
ZMQ_PULL
);
assert
(
bowl
);
assert
(
bowl
);
#if defined(ZMQ_SERVER) && defined(ZMQ_CLIENT)
void
*
server
=
zmq_socket
(
ctx
,
ZMQ_SERVER
);
void
*
server
=
zmq_socket
(
ctx
,
ZMQ_SERVER
);
assert
(
server
);
assert
(
server
);
rc
=
zmq_bind
(
server
,
"tcp://127.0.0.1:55557"
);
rc
=
zmq_bind
(
server
,
"tcp://127.0.0.1:55557"
);
...
@@ -57,6 +58,7 @@ int main (void)
...
@@ -57,6 +58,7 @@ int main (void)
void
*
client
=
zmq_socket
(
ctx
,
ZMQ_CLIENT
);
void
*
client
=
zmq_socket
(
ctx
,
ZMQ_CLIENT
);
assert
(
client
);
assert
(
client
);
#endif
// Set up poller
// Set up poller
void
*
poller
=
zmq_poller_new
();
void
*
poller
=
zmq_poller_new
();
...
@@ -116,6 +118,7 @@ int main (void)
...
@@ -116,6 +118,7 @@ int main (void)
assert
(
event
.
user_data
==
bowl
);
assert
(
event
.
user_data
==
bowl
);
zmq_poller_remove_fd
(
poller
,
fd
);
zmq_poller_remove_fd
(
poller
,
fd
);
#if defined(ZMQ_SERVER) && defined(ZMQ_CLIENT)
// Polling on thread safe sockets
// Polling on thread safe sockets
rc
=
zmq_poller_add
(
poller
,
server
,
NULL
,
ZMQ_POLLIN
);
rc
=
zmq_poller_add
(
poller
,
server
,
NULL
,
ZMQ_POLLIN
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
...
@@ -138,6 +141,7 @@ int main (void)
...
@@ -138,6 +141,7 @@ int main (void)
assert
(
event
.
socket
==
server
);
assert
(
event
.
socket
==
server
);
assert
(
event
.
user_data
==
NULL
);
assert
(
event
.
user_data
==
NULL
);
assert
(
event
.
events
==
ZMQ_POLLOUT
);
assert
(
event
.
events
==
ZMQ_POLLOUT
);
#endif
// Destory poller, sockets and ctx
// Destory poller, sockets and ctx
rc
=
zmq_poller_destroy
(
&
poller
);
rc
=
zmq_poller_destroy
(
&
poller
);
...
@@ -148,10 +152,12 @@ int main (void)
...
@@ -148,10 +152,12 @@ int main (void)
assert
(
rc
==
0
);
assert
(
rc
==
0
);
rc
=
zmq_close
(
bowl
);
rc
=
zmq_close
(
bowl
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
#if defined(ZMQ_SERVER) && defined(ZMQ_CLIENT)
rc
=
zmq_close
(
server
);
rc
=
zmq_close
(
server
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
rc
=
zmq_close
(
client
);
rc
=
zmq_close
(
client
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
#endif
rc
=
zmq_ctx_term
(
ctx
);
rc
=
zmq_ctx_term
(
ctx
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
...
...
tests/test_use_fd_ipc.cpp
View file @
91394d27
...
@@ -124,6 +124,7 @@ void test_pair ()
...
@@ -124,6 +124,7 @@ void test_pair ()
void
test_client_server
()
void
test_client_server
()
{
{
#if defined(ZMQ_SERVER) && defined(ZMQ_CLIENT)
void
*
ctx
=
zmq_ctx_new
();
void
*
ctx
=
zmq_ctx_new
();
assert
(
ctx
);
assert
(
ctx
);
...
@@ -200,6 +201,7 @@ void test_client_server ()
...
@@ -200,6 +201,7 @@ void test_client_server ()
rc
=
unlink
(
"/tmp/tester"
);
rc
=
unlink
(
"/tmp/tester"
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
#endif
}
}
int
main
(
void
)
int
main
(
void
)
...
...
tests/test_use_fd_tcp.cpp
View file @
91394d27
...
@@ -130,6 +130,7 @@ void test_pair ()
...
@@ -130,6 +130,7 @@ void test_pair ()
void
test_client_server
()
void
test_client_server
()
{
{
#if defined(ZMQ_SERVER) && defined(ZMQ_CLIENT)
void
*
ctx
=
zmq_ctx_new
();
void
*
ctx
=
zmq_ctx_new
();
assert
(
ctx
);
assert
(
ctx
);
...
@@ -203,6 +204,7 @@ void test_client_server ()
...
@@ -203,6 +204,7 @@ void test_client_server ()
rc
=
zmq_ctx_term
(
ctx
);
rc
=
zmq_ctx_term
(
ctx
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
#endif
}
}
int
main
(
void
)
int
main
(
void
)
...
...
tests/testutil.hpp
View file @
91394d27
...
@@ -30,13 +30,13 @@
...
@@ -30,13 +30,13 @@
#ifndef __TESTUTIL_HPP_INCLUDED__
#ifndef __TESTUTIL_HPP_INCLUDED__
#define __TESTUTIL_HPP_INCLUDED__
#define __TESTUTIL_HPP_INCLUDED__
#include "../include/zmq.h"
#include "../src/stdint.hpp"
#if defined ZMQ_CUSTOM_PLATFORM_HPP
#if defined ZMQ_CUSTOM_PLATFORM_HPP
# include "platform.hpp"
# include "platform.hpp"
#else
#else
# include "../src/platform.hpp"
# include "../src/platform.hpp"
#endif
#endif
#include "../include/zmq.h"
#include "../src/stdint.hpp"
// This defines the settle time used in tests; raise this if we
// This defines the settle time used in tests; raise this if we
// get test failures on slower systems due to binds/connects not
// get test failures on slower systems due to binds/connects not
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment