123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280 |
- cmake_minimum_required (VERSION 2.8.12)
-
- # Mac OSX RPATH is weird
- # enable @rpath in the install name for any shared library being built
- # note: it is planned that a future version of CMake will enable this by default
- if(POLICY CMP0015)
- cmake_policy(SET CMP0015 NEW)
- endif()
- set(CMAKE_MACOSX_RPATH 1)
-
- project (Lemma CXX)
-
- # required external programs (for runtime of nix, not buildtime)
- FIND_PROGRAM(HAVEGIT git
- PATHS /usr/bin/ /bin ENV PATH NO_DEFAULT_PATH
- )
- if(NOT HAVEGIT)
- message(FATAL_ERROR "Lemma requires that git is installed and in the path of your machine")
- endif(NOT HAVEGIT)
-
- option(BUILD_SHARED_LIBS OFF)
- if(BUILD_SHARED_LIBS)
- set(LABEL_SUFFIX "shared")
- else()
- set(LABEL_SUFFIX "static")
- endif()
-
- if(NOT CMAKE_BUILD_TYPE)
- set(CMAKE_BUILD_TYPE "Release" CACHE STRING
- "Choose the type of build, options are: Debug Release
- RelWithDebInfo MinSizeRel."
- FORCE)
- endif(NOT CMAKE_BUILD_TYPE)
-
- ###################
- # External Projects
- ###################
- include(ExternalProject)
- ##########################################################################################
- # Eigen, this header-library is used extensively for linear algebra, matrices, and arrays
- # Mercurial (hg) repo pull, Would it be better to just download latest stable?
- FIND_PROGRAM( HAVEHG hg
- PATHS /usr/bin/ /bin ENV PATH NO_DEFAULT_PATH
- )
- if (HAVEHG)
- ExternalProject_Add(EIGEN
- HG_REPOSITORY "https://bitbucket.org/eigen/eigen/"
- UPDATE_COMMAND ""
- HG_TAG "3.3.2" #"default"
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/eigen
- CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX}
- )
- ELSE()
- # Use Stable Eigen instead
- ExternalProject_Add(EIGEN
- #URL "http://bitbucket.org/eigen/eigen/get/default.tar.gz" # tip from repo
- URL "http://bitbucket.org/eigen/eigen/get/3.3.2.tar.gz"
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/eigen
- CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX}
- )
- ENDIF()
- include_directories ("${CMAKE_INSTALL_PREFIX}/include/eigen3")
-
- #############################################################################################
- # Yaml-cpp, this library is used extensively for serialisation of classes (class persistence)
- ExternalProject_Add(YAML-CPP
- GIT_REPOSITORY "https://github.com/jbeder/yaml-cpp.git"
- GIT_TAG "master" #"release-0.5.3" #"master"
- UPDATE_COMMAND ""
- PATCH_COMMAND ""
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/yaml-cpp
- CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX} -DBUILD_SHARED_LIBS=${BUILD_SHARED_LIBS} /
- -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
- )
- add_compile_options(-DHAVE_YAMLCPP)
-
- # CxxTest
- find_package(CxxTest)
- if (CXXTEST_FOUND)
- # Do nothing
- else()
- message( STATUS "CxxTest will be built and installed along with Lemma, override if desired in GUI." )
- ExternalProject_Add(CxxTest
- GIT_REPOSITORY "https://github.com/CxxTest/cxxtest.git"
- GIT_TAG "master"
- UPDATE_COMMAND ""
- PATCH_COMMAND ""
- CONFIGURE_COMMAND ""
- BUILD_COMMAND ""
- INSTALL_COMMAND ""
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/CxxTest
- CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX} -DBUILD_SHARED_LIBS=${BUILD_SHARED_LIBS} /
- -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
- )
- # The values "CACHE PATH "" FORCE" makes the GUI show the values of the local CxxTest, but this can cause issues
- # with users wanting to specify their own path, its not recommended
- set (CXXTEST_INCLUDE_DIR "${CMAKE_CURRENT_BINARY_DIR}/external/CxxTest/src/CxxTest/") # CACHE PATH "" FORCE )
- set (CXXTEST_PYTHON_TESTGEN_EXECUTABLE "${CMAKE_CURRENT_BINARY_DIR}/external/CxxTest/src/CxxTest/bin/cxxtestgen") # CACHE PATH "" FORCE )
- find_package(CxxTest REQUIRED)
- endif()
-
- # tinyxml2, this library is used for XML IO
- option( LEMMA_TINYXML_SUPPORT "MATIO library support for MATLAB .mat files" OFF)
- if ( LEMMA_TINYXML_SUPPORT )
- ExternalProject_Add(TINYXML2
- GIT_REPOSITORY "https://github.com/leethomason/tinyxml2.git"
- GIT_TAG "master"
- UPDATE_COMMAND ""
- PATCH_COMMAND ""
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/tinyxml2
- CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${CMAKE_INSTALL_PREFIX} -DBUILD_SHARED_LIBS=${BUILD_SHARED_LIBS} /
- -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
- )
- add_compile_options(-DTINYXMLSUPPORT)
- endif()
-
- option( LEMMA_MATIO_SUPPORT "MATIO library support for MATLAB .mat files" OFF)
- if ( LEMMA_MATIO_SUPPORT )
- add_compile_options(-DHAVE_MATIO)
- # matio, this library is used for MATLAB file IO
- ExternalProject_ADD(MATIO
- GIT_REPOSITORY "git://git.code.sf.net/p/matio/matio"
- GIT_TAG "master"
- UPDATE_COMMAND ""
- PATCH_COMMAND ""
- PREFIX ${CMAKE_CURRENT_BINARY_DIR}/external/matio
- #CONFIGURE_COMMAND ${CMAKE_CURRENT_BINARY_DIR}/external/matio/src/MATIO/autogen.sh && configure
- CONFIGURE_COMMAND ./autogen.sh && ./configure --prefix=${CMAKE_INSTALL_PREFIX}
- BUILD_IN_SOURCE 1
- BUILD_COMMAND ${MAKE}
- )
- endif()
-
- # We don't build VTK, it is too heavy.
- option (LEMMA_VTK6_SUPPORT "VTK library for visualisation and grids" OFF)
- if ( LEMMA_VTK6_SUPPORT )
- #find_package(VTK 6 REQUIRED NO_MODULE)
- find_package(VTK 6.0 COMPONENTS vtkCommonCore vtkRenderingCore vtkFiltersCore vtkFiltersSources
- vtkCommonDataModel vtkFiltersHyperTree vtkIOXML vtkIOImage vtkIOLegacy vtkInteractionStyle
- vtkRenderingAnnotation vtkFiltersHybrid vtkFiltersModeling vtkRenderingVolumeOpenGL NO_MODULE)
- set(volumeRenderer volumerenderer.cxx)
- include(${VTK_USE_FILE})
- add_compile_options(-DLEMMAUSEVTK)
- # Compile Matplot_vtk if VTK is present
- #add_subdirectory(Matplot_vtk)
- #include_directories ("${PROJECT_SOURCE_DIR}/Matplot_vtk")
- endif()
-
- option (LEMMA_VTK7_SUPPORT "VTK library for visualisation and grids" OFF)
- if ( LEMMA_VTK7_SUPPORT )
- #find_package(VTK 7 REQUIRED NO_MODULE)
- find_package(VTK 7.0 COMPONENTS vtkCommonCore vtkRenderingCore vtkFiltersCore vtkFiltersSources
- vtkCommonDataModel vtkFiltersHyperTree vtkIOXML vtkIOImage vtkIOLegacy vtkInteractionStyle
- vtkRenderingAnnotation vtkFiltersHybrid vtkFiltersModeling vtkRenderingVolumeOpenGL2 NO_MODULE)
- set(volumeRenderer volumerenderer.cxx)
- include(${VTK_USE_FILE})
- add_compile_options(-DLEMMAUSEVTK)
- # Compile Matplot_vtk if VTK is present
- #add_subdirectory(Matplot_vtk)
- #include_directories ("${PROJECT_SOURCE_DIR}/Matplot_vtk")
- endif()
-
- #####################
- # Lemma Configuration
- #####################
-
- #####################
- # Look for Ki Ha Lee
- #####################
- FIND_LIBRARY( KIHA_EM1D kihaem1d ) # PATHS ${/home/tirons/local/lib} )
- if ( KIHA_EM1D )
- add_compile_options(-DKIHALEE_EM1D)
- endif()
-
- ####################
- # Look for Boost
- ####################
- option (LEMMA_USE_BOOST "Boost is required by gaussian quadrature classes" OFF)
- if (LEMMA_USE_BOOST)
- find_package(Boost
- 1.58.0 # Minimum or EXACT version e.g. 1.36.0
- # COMPONENTS math # Boost libraries by their canonical name
- )
- if(Boost_FOUND)
- include_directories(${Boost_INCLUDE_DIRS})
- endif()
- find_path( HAVE_BOOST_SPECIAL_FUNCTIONS "boost/math/special_functions.hpp" )
- if(HAVE_BOOST_SPECIAL_FUNCTIONS)
- add_compile_options(-DHAVE_BOOST_SPECIAL_FUNCTIONS)
- endif()
- endif()
-
- ####################
- # Magic rpath flag
- ####################
- SET(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
-
- ####################
- # Add the c++11 flag
- # TODO add compiler specific instructions
- include(CheckCXXCompilerFlag)
- CHECK_CXX_COMPILER_FLAG(-std=c++14 COMPILER_SUPPORTS_CXX14)
- CHECK_CXX_COMPILER_FLAG(-std=c++11 COMPILER_SUPPORTS_CXX11)
- CHECK_CXX_COMPILER_FLAG(-std=c++0x COMPILER_SUPPORTS_CXX0X)
-
- if(COMPILER_SUPPORTS_CXX14)
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++14")
- elseif(COMPILER_SUPPORTS_CXX11)
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
- elseif(COMPILER_SUPPORTS_CXX0X)
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x")
- else()
- message(FATAL_ERROR "The compiler ${CMAKE_CXX_COMPILER} has no C++11 or C++14 support. Please use a different C++ compiler.")
- endif()
-
- option( LEMMA_BUILD_EXAMPLES "Compile example Lemma applications" OFF )
-
- option( LEMMA_USE_OPENMP "Use OpenMP in Lemma" OFF)
- CHECK_CXX_COMPILER_FLAG(-fopenmp COMPILER_SUPPORTS_OPENMP)
- if(COMPILER_SUPPORTS_OPENMP AND LEMMA_USE_OPENMP )
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fopenmp -DLEMMAUSEOMP")
- endif()
-
- set(LEMMA_VERSION_MAJOR "0")
- set(LEMMA_VERSION_MINOR "2")
- set(LEMMA_VERSION_PATCH "0")
- set(LEMMA_VERSION "\"${LEMMA_VERSION_MAJOR}.${LEMMA_VERSION_MINOR}.${LEMMA_VERSION_PATCH}\"")
- set(LEMMA_VERSION_NOQUOTES "${LEMMA_VERSION_MAJOR}.${LEMMA_VERSION_MINOR}.${LEMMA_VERSION_PATCH}")
-
- configure_file (
- "${PROJECT_SOURCE_DIR}/config/LemmaConfig.h.in"
- "${PROJECT_BINARY_DIR}/include/LemmaConfig.h"
- )
- install ( FILES ${PROJECT_BINARY_DIR}/include/LemmaConfig.h DESTINATION ${CMAKE_INSTALL_PREFIX}/include/Lemma/ )
-
- include_directories("${PROJECT_BINARY_DIR}/include")
- include_directories ("${CMAKE_INSTALL_PREFIX}/include/")
- link_directories ("${CMAKE_INSTALL_PREFIX}/lib/")
-
- #######################################################################
- # CXXTEST Framework
- if(CXXTEST_FOUND)
- option (LEMMA_ENABLE_TESTING "Turn on unit testing" ON)
- if (LEMMA_ENABLE_TESTING)
- #include_directories(${CXXTEST_INCLUDE_DIR}) # Add this in testing CMakeLists.txt instead, cleaner
- enable_testing()
- endif()
- endif()
-
- ########################################################################
- # Build Modules
- add_subdirectory (Modules)
-
- ########################################################################
- # add a target to generate API documentation with Doxyfile.in
- # ALL make documentation build by default if possible
- find_package(Doxygen)
- if(DOXYGEN_FOUND)
- option( LEMMA_BUILD_DOCUMENTATION "Build Doxygen man pages" OFF )
- if (LEMMA_BUILD_DOCUMENTATION)
-
- # Custom header and footer option, enable in Doxygen
- # file(COPY ${CMAKE_CURRENT_SOURCE_DIR}/Documentation/header.html
- # DESTINATION ${CMAKE_CURRENT_BINARY_DIR}/Documentation/header.html
- # )
- # file(COPY ${CMAKE_CURRENT_SOURCE_DIR}/Documentation/footer.html
- # DESTINATION ${CMAKE_CURRENT_BINARY_DIR}/Documentation/footer.html
- # )
-
- configure_file(${CMAKE_CURRENT_SOURCE_DIR}/Documentation/Doxyfile.in ${CMAKE_CURRENT_BINARY_DIR}/Documentation/Doxyfile @ONLY)
- add_custom_target(doc
- ALL
- ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/Documentation/Doxyfile
- WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
- COMMENT "Generating API documentation with Doxygen" VERBATIM
- )
-
- endif (LEMMA_BUILD_DOCUMENTATION)
- endif(DOXYGEN_FOUND)
|