From 96b0a8a4749f56244b9d6841de3696ab7fe1fd0e Mon Sep 17 00:00:00 2001 From: Toni Uhlig Date: Sun, 10 Sep 2023 19:11:58 +0200 Subject: Add event I/O abstraction. * required to support non-Linux OS e.g. Mac OS X / BSD * see Github issue #19 Signed-off-by: Toni Uhlig --- cmake/CheckEpoll.cmake | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 cmake/CheckEpoll.cmake (limited to 'cmake') diff --git a/cmake/CheckEpoll.cmake b/cmake/CheckEpoll.cmake new file mode 100644 index 000000000..766d7470f --- /dev/null +++ b/cmake/CheckEpoll.cmake @@ -0,0 +1,28 @@ +# - Check if the system supports epoll. +# CHECK_EPOLL() +# - variable to store the result +# (1 for success, empty for failure) + +#============================================================================= +# This software is in the public domain, furnished "as is", without technical +# support, and with no warranty, express or implied, as to its usefulness for +# any purpose. +#============================================================================= + +macro(CHECK_EPOLL VARIABLE) + if(UNIX) + if("${VARIABLE}" MATCHES "^${VARIABLE}$") + message(STATUS "Check if the system supports epoll") + include(CheckSymbolExists) + check_symbol_exists(epoll_create "sys/epoll.h" EPOLL_PROTOTYPE_EXISTS) + + if(EPOLL_PROTOTYPE_EXISTS) + message(STATUS "Check if the system supports epoll - yes") + set(${VARIABLE} 1 CACHE INTERNAL "Result of CHECK_EPOLL" FORCE) + else(EPOLL_PROTOTYPE_EXISTS) + message(STATUS "Check if the system supports epoll - no") + set(${VARIABLE} "" CACHE INTERNAL "Result of CHECK_EPOLL" FORCE) + endif(EPOLL_PROTOTYPE_EXISTS) + endif("${VARIABLE}" MATCHES "^${VARIABLE}$") + endif(UNIX) +endmacro(CHECK_EPOLL) -- cgit v1.2.3