X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/12a3d01e7de3d8fdefa0aeedeb0cee96936567f0..9c2e8abab7fd2928b0cfb728f4f22f2d30cfa23f:/CMakeLists.txt diff --git a/CMakeLists.txt b/CMakeLists.txt index 333be68663..8e525e47ed 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -11,18 +11,30 @@ set(libsmpi_version "${release_version}") ### Find programs and paths FIND_PROGRAM(GCOV_PATH gcov) FIND_PROGRAM(VALGRIND_PATH valgrind) +include(FindPerl) ### SET THE PROJECT_DIRECTORY SET(PROJECT_DIRECTORY "${CMAKE_HOME_DIRECTORY}") +### SET THE LIBRARY EXTENSION +if(APPLE) + set(LIB_EXE "dylib") +else(APPLE) + set(LIB_EXE "so") +endif(APPLE) + ### Set some variables for Cmake SET(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR}/lib) -set(INCLUDES "-I${PROJECT_DIRECTORY} -I${PROJECT_DIRECTORY}/include -I${PROJECT_DIRECTORY}/src/include -I${PROJECT_DIRECTORY}/src -I${CMAKE_CURRENT_BINARY_DIR}/src/") +set(INCLUDES ${PROJECT_BINARY_DIR} ${PROJECT_BINARY_DIR}/include ${PROJECT_BINARY_DIR}/src/include ${PROJECT_BINARY_DIR}/src) +set(INCLUDES ${INCLUDES} ${PROJECT_DIRECTORY} ${PROJECT_DIRECTORY}/include ${PROJECT_DIRECTORY}/src/include ${PROJECT_DIRECTORY}/src ${CMAKE_CURRENT_BINARY_DIR}/src) +if(WIN32) + set(INCLUDES ${INCLUDES} ${PROJECT_DIRECTORY}/include/xbt ${PROJECT_DIRECTORY}/src/xbt) #for win32_ucontext.[ch] +endif(WIN32) set(CMAKE_SOURCE_DIR ${PROJECT_SOURCE_DIRECTORY}) -if(EXISTS /usr/include/) - set(INCLUDES "${INCLUDES} -I/usr/include/") -endif(EXISTS /usr/include/) +if(NOT CMAKE_CROSSCOMPILING AND EXISTS /usr/include/) + set(INCLUDES ${INCLUDES} /usr/include/) +endif(NOT CMAKE_CROSSCOMPILING AND EXISTS /usr/include/) ### Check 32bits or 64bits INCLUDE (CheckTypeSize) @@ -38,9 +50,18 @@ if(WIN32) set(INCLUDES_MORE $ENV{INCLUDE}) string(REPLACE "\\" "/" INCLUDES_MORE "${INCLUDES_MORE}") foreach(include_dir ${INCLUDES_MORE}) - set(INCLUDES "${INCLUDES} -I\"${include_dir}\"") + if(IS_DIRECTORY ${include_dir}) + string(REGEX MATCH ".*[ ].*" testoki "${include_dir}") + if(testoki) + string(REPLACE " " "\\ " include_dir "${include_dir}") + set(INCLUDES ${INCLUDES} \"${include_dir}\") + else(testoki) + set(INCLUDES ${INCLUDES} ${include_dir}) + endif(testoki) + else(IS_DIRECTORY ${include_dir}) + message(FATAL_ERROR "${include_dir} not find") + endif(IS_DIRECTORY ${include_dir}) endforeach(include_dir ${INCLUDES_MORE}) - set(INCLUDES "${INCLUDES} -I${PROJECT_DIRECTORY}/include/xbt -I${PROJECT_DIRECTORY}/src/xbt") #for win32_ucontext.[ch] if(BORLAND) ### BORLAND COMPILER set(__BORLANDC__ 1) @@ -61,6 +82,17 @@ if(WIN32) if(CMAKE_COMPILER_IS_GNUCC) set(__GNUC__ 1) + exec_program("${CMAKE_C_COMPILER} --version" OUTPUT_VARIABLE "COMPILER_C_VERSION") + string(REGEX MATCH "[0-9].[0-9].[0-9]" COMPILER_C_VERSION "${COMPILER_C_VERSION}") + string(REGEX MATCH "^[0-9]" COMPILER_C_MAJOR_VERSION "${COMPILER_C_VERSION}") + string(REGEX MATCH "^[0-9].[0-9]" COMPILER_C_MINOR_VERSION "${COMPILER_C_VERSION}") + string(REGEX REPLACE "^${COMPILER_C_MAJOR_VERSION}." "" COMPILER_C_MINOR_VERSION "${COMPILER_C_MINOR_VERSION}") + if(COMPILER_C_MAJOR_VERSION) + # set(__GNUC__ ${COMPILER_C_MAJOR_VERSION}) + endif(COMPILER_C_MAJOR_VERSION) + if(COMPILER_C_MINOR_VERSION) + # set(__GNUC_MINOR__ ${COMPILER_C_MINOR_VERSION}) + endif(COMPILER_C_MINOR_VERSION) set(MSVC 0) set(BORLAND 0) endif(CMAKE_COMPILER_IS_GNUCC) @@ -76,7 +108,6 @@ if(WIN32) message("Be sure all those variables are correctely set.") message(" -- C_COMPILER $ENV{CC}") message(" -- CXX_COMPILER $ENV{CXX}") - message(" -- RC_COMPILER $ENV{RC}") message(" -- INCLUDE $ENV{INCLUDE}") message(" -- LIB $ENV{LIB}") message(" -- MAKE_PROGRAM ${CMAKE_MAKE_PROGRAM}") @@ -90,7 +121,7 @@ if(WIN32) endif(WIN32) -add_definitions (${INCLUDES}) +include_directories(${INCLUDES}) ### Setup Options include(${PROJECT_DIRECTORY}/buildtools/Cmake/Option.cmake) @@ -103,6 +134,7 @@ include(${PROJECT_DIRECTORY}/buildtools/Cmake/DefinePackages.cmake) ### Build some Maintainer files include(${PROJECT_DIRECTORY}/buildtools/Cmake/MaintainerMode.cmake) +include(${PROJECT_DIRECTORY}/buildtools/Cmake/UnitTesting.cmake) ### Setup gcc flags include(${PROJECT_DIRECTORY}/buildtools/Cmake/Flags.cmake) @@ -136,9 +168,12 @@ endif(HAVE_JAVA) ### Make tests if(NOT WIN32) include(${PROJECT_DIRECTORY}/buildtools/Cmake/AddTests.cmake) -include(${PROJECT_DIRECTORY}/buildtools/Cmake/CTestConfig.cmake) +else(NOT WIN32) +include(${PROJECT_DIRECTORY}/buildtools/Cmake/AddTestsWin.cmake) endif(NOT WIN32) +include(${PROJECT_DIRECTORY}/buildtools/Cmake/CTestConfig.cmake) + ### Setup the distrib include(${PROJECT_DIRECTORY}/buildtools/Cmake/Distrib.cmake) @@ -148,4 +183,4 @@ include(${PROJECT_DIRECTORY}/buildtools/Cmake/Pipol.cmake) ### Print ARGS include(${PROJECT_DIRECTORY}/buildtools/Cmake/PrintArgs.cmake) -INCLUDE(Dart) \ No newline at end of file +INCLUDE(Dart)