message(STATUS "Cmake version ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}")
include(CheckFunctionExists)
+include(CheckTypeSize)
include(CheckIncludeFile)
include(CheckIncludeFiles)
include(CheckLibraryExists)
TEST_BIG_ENDIAN(BIGENDIAN)
include(FindGraphviz)
+if(enable_pcre)
include(FindPCRE)
+endif(enable_pcre)
if(enable_gtnets)
include(FindGTnets)
endif(enable_gtnets)
CHECK_INCLUDE_FILE("string.h" HAVE_STRING_H)
CHECK_INCLUDE_FILE("ucontext.h" HAVE_UCONTEXT_H)
CHECK_INCLUDE_FILE("stdio.h" HAVE_STDIO_H)
+CHECK_INCLUDE_FILE("linux/futex.h" HAVE_FUTEX_H)
+
CHECK_FUNCTION_EXISTS(gettimeofday HAVE_GETTIMEOFDAY)
CHECK_FUNCTION_EXISTS(usleep HAVE_USLEEP)
set(CONTEXT_UCONTEXT 0)
SET(CONTEXT_THREADS 0)
-SET(HAVE_RUBY 0)
-set(HAVE_LUA 0)
SET(HAVE_TRACING 0)
if(enable_tracing)
SET(MMALLOC_WANT_OVERIDE_LEGACY 0)
endif(enable_model-checking AND HAVE_MMAP)
-if(enable_lua)
- if(LUA51_FOUND)
- set(HAVE_LUA 1)
- SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS}-I${LUA_INCLUDE_DIR} ")
- SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS}-L${LUA_LIBRARY_DIR} ")
- else(LUA51_FOUND)
- message(STATUS "Warning : Lua need version 5.1")
- endif(LUA51_FOUND)
-endif(enable_lua)
-
#--------------------------------------------------------------------------------------------------
-### Initialize of Smpi
+### Check for some architecture dependent values
+CHECK_TYPE_SIZE(int SIZEOF_INT)
+CHECK_TYPE_SIZE(void* SIZEOF_VOIDP)
-if(enable_smpi)
- if(HAVE_F2C_H)
- string(REGEX MATCH "-I${HAVE_F2C_H} " operation "${CMAKE_C_FLAGS}")
- if(NOT operation)
- SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS}-I${HAVE_F2C_H} ")
- endif(NOT operation)
- else(HAVE_F2C_H)
- message(STATUS "Warning : You should install f2c before use smpi.")
- endif(HAVE_F2C_H)
-endif(enable_smpi)
#--------------------------------------------------------------------------------------------------
### Initialize of CONTEXT THREADS
endif(HAVE_WINDOWS_H)
endif(mcsc MATCHES "no" AND pthread)
-if(with_context MATCHES "ucontext" AND mcsc MATCHES "no")
- message(FATAL_ERROR "-Dwith-context=ucontext specified but ucontext unusable.")
-endif(with_context MATCHES "ucontext" AND mcsc MATCHES "no")
+#Only windows
-set(with_context_ok 0)
-if(with_context MATCHES "windows")
- set(with_context_ok 1)
+if(WIN32)
if(NOT HAVE_WINDOWS_H)
message(FATAL_ERROR "no appropriate backend found windows")
endif(NOT HAVE_WINDOWS_H)
-endif(with_context MATCHES "windows")
-
-if(with_context MATCHES "pthreads")
- set(with_context_ok 1)
- set(with_context "pthread")
-endif(with_context MATCHES "pthreads")
-
-if(with_context MATCHES "auto")
- set(with_context_ok 1)
- set(with_context "ucontext")
- message(STATUS "With_context auto change to ucontext")
-endif(with_context MATCHES "auto")
-
-if(with_context MATCHES "ucontext")
- set(with_context_ok 1)
- if(mcsc)
- set(CONTEXT_UCONTEXT 1)
- else(mcsc)
- if(windows_context MATCHES "yes")
- set(with_context "windows")
- message(STATUS "With_context ucontext change to windows")
- else(windows_context MATCHES "yes")
- set(with_context "pthread")
- message(STATUS "With_context ucontext change to pthread")
- endif(windows_context MATCHES "yes")
- endif(mcsc)
-endif(with_context MATCHES "ucontext")
-
-if(with_context MATCHES "pthread")
- set(with_context_ok 1)
- if(NOT pthread)
- message(FATAL_ERROR "Cannot find pthreads (try -Dwith_context=ucontext if you haven't already tried).")
- endif(NOT pthread)
- SET(CONTEXT_THREADS 1)
-endif(with_context MATCHES "pthread")
-
-if(with_context MATCHES "ucontext")
- SET(CONTEXT_THREADS 0)
-endif(with_context MATCHES "ucontext")
-
-if(NOT with_context_ok)
- message(FATAL_ERROR "-Dwith-context must be either ucontext or pthread")
-endif(NOT with_context_ok)
+endif(WIN32)
+
+if(windows_context MATCHES "yes")
+ message(STATUS "Context change to windows")
+endif(windows_context MATCHES "yes")
+
+#If can have both context
+
+if(mcsc)
+ set(CONTEXT_UCONTEXT 1)
+endif(mcsc)
+
+if(pthread)
+ set(CONTEXT_THREADS 1)
+endif(pthread)
+
###############
## SVN version check