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
700de65a
Commit
700de65a
authored
Feb 11, 2016
by
Luca Boccassi
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1791 from hintjens/master
Problem: autotools platform.hpp is not compatible with CMake
parents
dd4b93dd
9f8ced3f
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
91 additions
and
103 deletions
+91
-103
acinclude.m4
acinclude.m4
+86
-99
configure.ac
configure.ac
+5
-4
No files found.
acinclude.m4
View file @
700de65a
...
@@ -781,20 +781,17 @@ dnl # LIBZMQ_CHECK_POLLER_KQUEUE([action-if-found], [action-if-not-found])
...
@@ -781,20 +781,17 @@ dnl # LIBZMQ_CHECK_POLLER_KQUEUE([action-if-found], [action-if-not-found])
dnl # Checks kqueue polling system #
dnl # Checks kqueue polling system #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER_KQUEUE], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER_KQUEUE], [{
AC_LINK_IFELSE(
AC_LINK_IFELSE([
[AC_LANG_PROGRAM(
AC_LANG_PROGRAM([
[
#include <sys/types.h>
#include <sys/types.h>
#include <sys/event.h>
#include <sys/event.h>
#include <sys/time.h>
#include <sys/time.h>
],
],[[
[[
struct kevent t_kev;
struct kevent t_kev;
kqueue();
kqueue();
]]
]])],
)],
[$1], [$2]
[libzmq_cv_have_poller_kqueue="yes" ; $1],
)
[libzmq_cv_have_poller_kqueue="no" ; $2])
}])
}])
dnl ################################################################################
dnl ################################################################################
...
@@ -803,35 +800,27 @@ dnl # Checks epoll polling system can actually run #
...
@@ -803,35 +800,27 @@ dnl # Checks epoll polling system can actually run #
dnl # For cross-compile, only requires that epoll can link #
dnl # For cross-compile, only requires that epoll can link #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER_EPOLL], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER_EPOLL], [{
AC_RUN_IFELSE(
AC_RUN_IFELSE([
[AC_LANG_PROGRAM(
AC_LANG_PROGRAM([
[
#include <sys/epoll.h>
#include <sys/epoll.h>
],
],[[
[[
struct epoll_event t_ev;
struct epoll_event t_ev;
int r;
int r;
r = epoll_create(10);
r = epoll_create(10);
return(r < 0);
return(r < 0);
]]
]])],
)],
[$1],[$2],[
[libzmq_cv_have_poller_epoll="yes" ; $1],
AC_LINK_IFELSE([
[libzmq_cv_have_poller_epoll="no" ; $2],
AC_LANG_PROGRAM([
[
AC_LINK_IFELSE(
[AC_LANG_PROGRAM(
[
#include <sys/epoll.h>
#include <sys/epoll.h>
],
],[[
[[
struct epoll_event t_ev;
struct epoll_event t_ev;
epoll_create(10);
epoll_create(10);
]])],
]]
[$1], [$2]
)],
)
[libzmq_cv_have_poller_epoll="yes" ; $1],
]
[libzmq_cv_have_poller_epoll="no" ; $2])
)
])
}])
}])
dnl ################################################################################
dnl ################################################################################
...
@@ -839,18 +828,15 @@ dnl # LIBZMQ_CHECK_POLLER_DEVPOLL([action-if-found], [action-if-not-found])
...
@@ -839,18 +828,15 @@ dnl # LIBZMQ_CHECK_POLLER_DEVPOLL([action-if-found], [action-if-not-found])
dnl # Checks devpoll polling system #
dnl # Checks devpoll polling system #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER_DEVPOLL], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER_DEVPOLL], [{
AC_LINK_IFELSE(
AC_LINK_IFELSE([
[AC_LANG_PROGRAM(
AC_LANG_PROGRAM([
[
#include <sys/devpoll.h>
#include <sys/devpoll.h>
],
],[[
[[
struct pollfd t_devpoll;
struct pollfd t_devpoll;
int fd = open("/dev/poll", O_RDWR);
int fd = open("/dev/poll", O_RDWR);
]]
]])],
)],
[$1], [$2]
[libzmq_cv_have_poller_devpoll="yes" ; $1],
)
[libzmq_cv_have_poller_devpoll="no" ; $2])
}])
}])
dnl ################################################################################
dnl ################################################################################
...
@@ -858,18 +844,15 @@ dnl # LIBZMQ_CHECK_POLLER_POLL([action-if-found], [action-if-not-found])
...
@@ -858,18 +844,15 @@ dnl # LIBZMQ_CHECK_POLLER_POLL([action-if-found], [action-if-not-found])
dnl # Checks poll polling system #
dnl # Checks poll polling system #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER_POLL], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER_POLL], [{
AC_LINK_IFELSE(
AC_LINK_IFELSE([
[AC_LANG_PROGRAM(
AC_LANG_PROGRAM([
[
#include <poll.h>
#include <poll.h>
],
],[[
[[
struct pollfd t_poll;
struct pollfd t_poll;
poll(&t_poll, 1, 1);
poll(&t_poll, 1, 1);
]]
]])],
)],
[$1], [$2]
[libzmq_cv_have_poller_poll="yes" ; $1],
)
[libzmq_cv_have_poller_poll="no" ; $2])
}])
}])
dnl ################################################################################
dnl ################################################################################
...
@@ -877,9 +860,8 @@ dnl # LIBZMQ_CHECK_POLLER_SELECT([action-if-found], [action-if-not-found])
...
@@ -877,9 +860,8 @@ dnl # LIBZMQ_CHECK_POLLER_SELECT([action-if-found], [action-if-not-found])
dnl # Checks select polling system #
dnl # Checks select polling system #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER_SELECT], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER_SELECT], [{
AC_LINK_IFELSE(
AC_LINK_IFELSE([
[AC_LANG_PROGRAM(
AC_LANG_PROGRAM([
[
#ifdef ZMQ_HAVE_WINDOWS
#ifdef ZMQ_HAVE_WINDOWS
#include "winsock2.h"
#include "winsock2.h"
#elif defined ZMQ_HAVE_OPENVMS
#elif defined ZMQ_HAVE_OPENVMS
...
@@ -888,79 +870,84 @@ AC_DEFUN([LIBZMQ_CHECK_POLLER_SELECT], [{
...
@@ -888,79 +870,84 @@ AC_DEFUN([LIBZMQ_CHECK_POLLER_SELECT], [{
#else
#else
#include <sys/select.h>
#include <sys/select.h>
#endif
#endif
],
],[[
[[
fd_set t_rfds;
fd_set t_rfds;
struct timeval tv;
struct timeval tv;
FD_ZERO(&t_rfds);
FD_ZERO(&t_rfds);
FD_SET(0, &t_rfds);
FD_SET(0, &t_rfds);
tv.tv_sec = 5;
tv.tv_sec = 5;
tv.tv_usec = 0;
tv.tv_usec = 0;
select(1, &t_rfds, NULL, NULL, &tv);
select(1, &t_rfds, NULL, NULL, &tv);
]]
]])],
)],
[$1],[$2]
[libzmq_cv_have_poller_select="yes" ; $1],
)
[libzmq_cv_have_poller_select="no" ; $2])
}])
}])
dnl ################################################################################
dnl ################################################################################
dnl # LIBZMQ_CHECK_POLLER([action-if-found], [action-if-not-found]) #
dnl # LIBZMQ_CHECK_POLLER([action-if-found], [action-if-not-found]) #
dnl # Choose polling system #
dnl # Choose polling system #
dnl ################################################################################
dnl ################################################################################
AC_DEFUN([LIBZMQ_CHECK_POLLER], [{
AC_DEFUN([LIBZMQ_CHECK_POLLER], [{
# Allow user to override poller autodetection
# Allow user to override poller autodetection
AC_ARG_WITH([poller], [AS_HELP_STRING([--with-poller],
AC_ARG_WITH([poller],
[choose polling system manually. valid values are kqueue, epoll, devpoll, poll or select [default=autodetect]])])
[AS_HELP_STRING([--with-poller],
[choose polling system manually. Valid values are 'kqueue', 'epoll', 'devpoll', 'poll', 'select', or 'auto'. [default=auto]])])
case "${with_poller}" in
kqueue|epoll|devpoll|poll|select)
# User has chosen polling system
AC_MSG_CHECKING([for suitable polling system skipped for preselect])
libzmq_cv_poller="${with_poller}"
;;
*)
if test "x$with_poller" == "x"; then
# try to find suitable polling system. the order of testing is:
pollers=auto
# kqueue -> epoll -> devpoll -> poll -> select
else
AC_MSG_CHECKING([for suitable polling system])
pollers=$with_poller
for subsystem in kqueue epoll devpoll poll select; do
fi
if test "$pollers" == "auto"; then
# We search for pollers in this order
pollers="kqueue epoll devpoll poll select"
fi
case "${subsystem}" in
# try to find suitable polling system. the order of testing is:
AC_MSG_NOTICE([Choosing polling system from '$pollers'...])
poller_found=0
for poller in $pollers; do
case "$poller" in
kqueue)
kqueue)
LIBZMQ_CHECK_POLLER_KQUEUE([libzmq_cv_poller=$subsystem], [])
LIBZMQ_CHECK_POLLER_KQUEUE([
AC_MSG_NOTICE([Using 'kqueue' polling system])
AC_DEFINE(ZMQ_USE_KQUEUE, 1, [Use 'kqueue' polling system])
poller_found=1
])
;;
;;
epoll)
epoll)
LIBZMQ_CHECK_POLLER_EPOLL([libzmq_cv_poller=$subsystem], [])
LIBZMQ_CHECK_POLLER_EPOLL([
AC_MSG_NOTICE([Using 'epoll' polling system])
AC_DEFINE(ZMQ_USE_EPOLL, 1, [Use 'epoll' polling system])
poller_found=1
])
;;
;;
devpoll)
devpoll)
LIBZMQ_CHECK_POLLER_DEVPOLL([libzmq_cv_poller=$subsystem], [])
LIBZMQ_CHECK_POLLER_DEVPOLL([
AC_MSG_NOTICE([Using 'devpoll' polling system])
AC_DEFINE(ZMQ_USE_DEVPOLL, 1, [Use 'devpoll' polling system])
poller_found=1
])
;;
;;
poll)
poll)
LIBZMQ_CHECK_POLLER_POLL([libzmq_cv_poller=$subsystem], [])
LIBZMQ_CHECK_POLLER_POLL([
AC_MSG_NOTICE([Using 'poll' polling system])
AC_DEFINE(ZMQ_USE_POLL, 1, [Use 'poll' polling system])
poller_found=1
])
;;
;;
select)
select)
LIBZMQ_CHECK_POLLER_SELECT([libzmq_cv_poller=$subsystem], [])
LIBZMQ_CHECK_POLLER_SELECT([
AC_MSG_NOTICE([Using 'select' polling system])
AC_DEFINE(ZMQ_USE_SELECT, 1, [Use 'select' polling system])
poller_found=1
])
;;
;;
esac
esac
test $poller_found -eq 1 && break
if test "x${libzmq_cv_poller}" != "x"; then
break
fi
done
done
;;
if test $poller_found -eq 0; then
esac
AC_MSG_ERROR([None of '$pollers' are valid pollers on this platform])
fi
libzmq_cv_poller_flag=`echo "ZMQ_USE_${libzmq_cv_poller}" | tr a-z A-Z`
AS_IF([test "x${libzmq_cv_poller}" != "x"],
[AC_MSG_RESULT([using $libzmq_cv_poller]) ; $1], [AC_MSG_RESULT(no suitable polling system found) ; $2])
}])
}])
configure.ac
View file @
700de65a
...
@@ -320,9 +320,8 @@ esac
...
@@ -320,9 +320,8 @@ esac
# Check whether to build docs / install man pages
# Check whether to build docs / install man pages
LIBZMQ_CHECK_DOC_BUILD
LIBZMQ_CHECK_DOC_BUILD
# Check polling system
# Check polling system, set appropriate macro in src/platform.hpp
LIBZMQ_CHECK_POLLER([CPPFLAGS="${CPPFLAGS} -D${libzmq_cv_poller_flag}"],
LIBZMQ_CHECK_POLLER
[AC_MSG_ERROR([Unable to continue without polling system])])
# Checks for header files.
# Checks for header files.
AC_HEADER_STDC
AC_HEADER_STDC
...
@@ -498,6 +497,7 @@ AC_ARG_WITH([norm],
...
@@ -498,6 +497,7 @@ AC_ARG_WITH([norm],
AC_MSG_CHECKING("with_norm_ext = ${with_norm_ext}")
AC_MSG_CHECKING("with_norm_ext = ${with_norm_ext}")
if test "x$with_norm_ext" != "xno"; then
if test "x$with_norm_ext" != "xno"; then
AC_MSG_RESULT([yes])
AC_DEFINE(ZMQ_HAVE_NORM, 1, [Have NORM protocol extension])
AC_DEFINE(ZMQ_HAVE_NORM, 1, [Have NORM protocol extension])
if test "x$with_norm_ext" != "xyes"; then
if test "x$with_norm_ext" != "xyes"; then
...
@@ -505,8 +505,9 @@ if test "x$with_norm_ext" != "xno"; then
...
@@ -505,8 +505,9 @@ if test "x$with_norm_ext" != "xno"; then
LIBZMQ_EXTRA_CXXFLAGS="-I${norm_path}/include ${LIBZMQ_EXTRA_CXXFLAGS}"
LIBZMQ_EXTRA_CXXFLAGS="-I${norm_path}/include ${LIBZMQ_EXTRA_CXXFLAGS}"
LIBZMQ_EXTRA_LDFLAGS="-I${norm_path}/include ${LIBZMQ_EXTRA_LDFLAGS}"
LIBZMQ_EXTRA_LDFLAGS="-I${norm_path}/include ${LIBZMQ_EXTRA_LDFLAGS}"
fi
fi
LIBS="-lnorm $LIBS"
LIBS="-lnorm $LIBS"
else
AC_MSG_RESULT([no])
fi
fi
# build using vmci
# build using vmci
...
...
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