X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c10fd9cd99402735e777cc4f6774e5b7265c372f..cc3fbc08e8b448f5b820a2e5719f2029dcb23f89:/CMakeLists.txt diff --git a/CMakeLists.txt b/CMakeLists.txt index 6492dda369..a3e6ed5f13 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,34 +1,48 @@ cmake_minimum_required(VERSION 2.6) -SET(CMAKE_LANGUAGE "Cxx") -SET(PROJECT_NAME "Simgrid") +project(simgrid CXX C) +set(CMAKE_C_FLAGS "" CACHE TYPE INTERNAL FORCE) +set(CMAKE_CXX_FLAGS "" CACHE TYPE INTERNAL FORCE) +set(CMAKE_EXE_LINKER_FLAGS "" CACHE TYPE INTERNAL FORCE) +set(release_version "3.5") +set(libsimgrid_version "${release_version}") +set(libgras_version "${release_version}") +set(libsmpi_version "${release_version}") +exec_program("${CMAKE_COMMAND} -E remove -f ${simgrid_BINARY_DIR}/CTestTestfile.cmake" OUTPUT_VARIABLE rmok) + +if(WIN32) + message("C_COMPILER $ENV{CC}") + message("CXX_COMPILER $ENV{CXX}") + message("MAKE_PROGRAM ${CMAKE_MAKE_PROGRAM}") + message("RC_COMPILER $ENV{RC}") + message("INCLUDE $ENV{INCLUDE}") + message("LIB $ENV{LIB}") +endif(WIN32) ### Find programs and paths -find_program(SH_EXE NAMES sh) -find_program(SED_EXE NAMES sed) -find_program(PWD_EXE NAMES pwd) -find_program(UNAME NAMES uname) -find_program(HOSTNAME_CMD NAMES hostname) -find_program(CAT NAMES cat) -find_path(GCC_PATH NAMES gcc PATHS NO_DEFAULT_PATHS) find_path(GCOV_PATH NAMES gcov PATHS NO_DEFAULT_PATHS) find_path(VALGRIND_PATH NAMES valgrind PATHS NO_DEFAULT_PATHS) -### AUTO DETECT THE PROJECT_DIRECTORY -exec_program("${PWD_EXE}" ARGS "| ${SED_EXE} 's/\\/Cmake//g'" OUTPUT_VARIABLE PROJECT_DIRECTORY) - ### SET THE PROJECT_DIRECTORY -#SET(PROJECT_DIRECTORY "/home/navarrop/Bureau/simgrid-trunk") +SET(PROJECT_DIRECTORY "${CMAKE_HOME_DIRECTORY}") ### Set some variables for Cmake -SET(PROJECT_SOURCE_DIRECTORY "${PROJECT_DIRECTORY}/src") -set(EXECUTABLE_OUTPUT_PATH "${PROJECT_DIRECTORY}/bin") -set(LIBRARY_OUTPUT_PATH "${PROJECT_DIRECTORY}/src/.libs") -set(INCLUDES "-I${PROJECT_DIRECTORY}/include -I${PROJECT_DIRECTORY}/src/include -I${PROJECT_DIRECTORY}/src -I/usr/include/ -L${gtnets_path}/lib") +#SET(PROJECT_SOURCE_DIRECTORY "${PROJECT_DIRECTORY}/src") #this one is evil since it speaks to CPack instead +SET(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR}/lib) +set(INCLUDES "-I${PROJECT_DIRECTORY}/include -I${PROJECT_DIRECTORY}/src/include -I${PROJECT_DIRECTORY}/src -I${CMAKE_CURRENT_BINARY_DIR}/src/") set(CMAKE_SOURCE_DIR ${PROJECT_SOURCE_DIRECTORY}) -add_definitions (${INCLUDES}) +if(EXISTS /usr/include/) + set(INCLUDES "${INCLUDES} -I/usr/include/") +endif(EXISTS /usr/include/) + +if(WIN32) + set(INCLUDES "${INCLUDES} -I$ENV{INCLUDE}") +endif(WIN32) + if(enable_coverage) -add_definitions (-fprofile-arcs -ftest-coverage) + add_definitions (${INCLUDES} -fprofile-arcs -ftest-coverage) +else(enable_coverage) + add_definitions (${INCLUDES}) endif(enable_coverage) ### Setup Options @@ -40,7 +54,7 @@ include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeCompleteInFiles.txt) ### Define source packages for Libs include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeDefinePackages.txt) -include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeFLEXml.txt) +include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeMaintainerMode.txt) ### Setup gcc flags include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeFlags.txt) @@ -48,6 +62,11 @@ include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeFlags.txt) ### Make Libs and Exes include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeMakeExeLib.txt) +### Make Simgrid.jar and Java examples +if(HAVE_JAVA) + include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeJarAndClass.txt) +endif(HAVE_JAVA) + ### Make tests include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeTest.txt) include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CTestConfig.cmake) @@ -58,9 +77,19 @@ include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeDistrib.txt) ### Print ARGS include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakePrintArgs.txt) -### Make Docs -if(enable_maintainer_mode) - include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeDocs.txt) -endif(enable_maintainer_mode) - INCLUDE(Dart) + +exec_program("ctest -N" OUTPUT_VARIABLE LIST_OF_TEST) +string(REPLACE "\n" ";" LIST_OF_TEST ${LIST_OF_TEST}) +foreach(test ${LIST_OF_TEST}) + string(REGEX REPLACE "^.*Test.*project.*" " " test ${test}) + string(REGEX REPLACE "^.*Total.*Tests:.*" " " test ${test}) + string(REGEX MATCH "^.*Testing.*" test_ok_1 ${test}) #for ctest version 2.6 (xxx/xxx Testing) + string(REGEX MATCH "^.*Test.*\\:+" test_ok_2 ${test}) #for ctest version 2.8 (Test #xxx) + if(test_ok_1 OR test_ok_2) + string(REGEX REPLACE "^.*Testing" " " test ${test}) #for ctest version 2.6 + string(REGEX REPLACE "^.*Test.*\\:+" " " test ${test}) #for ctest version 2.8 + string(STRIP ${test} test) + set_tests_properties(${test} PROPERTIES LABELS "rev${SVN_VERSION}") + endif(test_ok_1 OR test_ok_2) +endforeach(test ${LIST_OF_TEST})