2021-11-13 19:01:21 +01:00
|
|
|
cmake_minimum_required(VERSION 3.16)
|
|
|
|
|
2021-11-13 19:49:02 +01:00
|
|
|
# =========== SETUP THE PROJECT =============
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# Initialize the CMake project.
|
2021-11-13 19:01:21 +01:00
|
|
|
project(Trexio
|
|
|
|
VERSION 2.0.0
|
|
|
|
DESCRIPTION "TREX I/O library"
|
|
|
|
LANGUAGES C Fortran
|
|
|
|
)
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# Request the C99 standard.
|
2021-11-13 19:01:21 +01:00
|
|
|
set(CMAKE_C_STANDARD 99)
|
|
|
|
set(CMAKE_C_STANDARD_REQUIRED ON)
|
|
|
|
|
2021-11-16 17:52:05 +01:00
|
|
|
# Optional configure for developer mode to generate source code from org-mode files.
|
|
|
|
option(TREXIO_DEVEL "TREXIO developer mode (for code generation)." OFF)
|
|
|
|
|
|
|
|
if(EXISTS ".git/config")
|
|
|
|
set(TREXIO_DEVEL ON)
|
2021-11-17 10:07:19 +01:00
|
|
|
find_package(Python3 REQUIRED)
|
2021-11-16 17:52:05 +01:00
|
|
|
if(Python3_FOUND)
|
2021-11-17 10:07:19 +01:00
|
|
|
if(Python3_VERSION_MINOR LESS 6)
|
|
|
|
message(FATAL_ERROR "Required Python3 version :: >= 3.6; Found :: ${Python3_VERSION}")
|
|
|
|
else()
|
|
|
|
message(STATUS "Python3 version :: ${Python3_VERSION}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
find_program(EMACS NAMES emacs REQUIRED)
|
|
|
|
if(NOT EMACS-NOTFOUND)
|
|
|
|
message(STATUS "EMACS detected :: ${EMACS}")
|
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "EMACS not found. It is required to produce TREXIO source code from org-mode files.")
|
2021-11-16 17:52:05 +01:00
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# By default, the shared TREXIO library is built (even without -DBUILD_SHARED_LIBS=ON).
|
|
|
|
# To change this behaviour, append -DBUILD_STATIC_LIBS=ON to the cmake call.
|
|
|
|
option(BUILD_SHARED_LIBS "Build the shared library" ON)
|
|
|
|
option(BUILD_STATIC_LIBS "Build the static library" OFF)
|
|
|
|
|
|
|
|
if(BUILD_SHARED_LIBS AND BUILD_STATIC_LIBS)
|
|
|
|
set(BUILD_SHARED_LIBS OFF)
|
|
|
|
endif()
|
|
|
|
|
2021-11-13 19:49:02 +01:00
|
|
|
# ========= DEFINE TREXIO C LIBRARY =========
|
|
|
|
|
2021-11-17 10:57:03 +01:00
|
|
|
# Set a list of TREXIO source and header files that are always compiled.
|
2021-11-15 11:16:28 +01:00
|
|
|
set(TREXIO_SOURCES
|
2021-11-16 17:52:05 +01:00
|
|
|
${CMAKE_SOURCE_DIR}/src/trexio.c
|
|
|
|
${CMAKE_SOURCE_DIR}/src/trexio_text.c
|
2021-11-13 19:01:21 +01:00
|
|
|
)
|
2021-11-17 10:57:03 +01:00
|
|
|
set(TREXIO_PUBLIC_HEADERS ${CMAKE_SOURCE_DIR}/include/trexio.h)
|
|
|
|
set(TREXIO_PRIVATE_HEADERS
|
|
|
|
${CMAKE_SOURCE_DIR}/src/trexio_s.h
|
|
|
|
${CMAKE_SOURCE_DIR}/src/trexio_private.h
|
|
|
|
${CMAKE_SOURCE_DIR}/src/trexio_text.h
|
|
|
|
)
|
2021-11-13 19:01:21 +01:00
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# Conditional SHARED/STATIC build for TREXIO library.
|
|
|
|
if(BUILD_SHARED_LIBS AND NOT BUILD_STATIC_LIBS)
|
|
|
|
|
|
|
|
message(STATUS "TREXIO :: shared C library will be built")
|
2021-11-16 17:52:05 +01:00
|
|
|
add_library(trexio SHARED)
|
2021-11-15 11:16:28 +01:00
|
|
|
|
|
|
|
elseif(NOT BUILD_SHARED_LIBS AND BUILD_STATIC_LIBS)
|
|
|
|
|
|
|
|
message(STATUS "TREXIO :: static C library will be built")
|
2021-11-16 17:52:05 +01:00
|
|
|
add_library(trexio STATIC)
|
2021-11-13 19:01:21 +01:00
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Building both static and shared TREXIO simultaneously is not supported.")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Set TREXIO version and include files.
|
2021-11-13 19:01:21 +01:00
|
|
|
set_target_properties(trexio PROPERTIES
|
|
|
|
VERSION ${PROJECT_VERSION}
|
2021-11-17 10:57:03 +01:00
|
|
|
PUBLIC_HEADER ${TREXIO_PUBLIC_HEADERS}
|
2021-11-13 19:01:21 +01:00
|
|
|
)
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# Set directories to be included at build time.
|
2021-11-13 19:49:02 +01:00
|
|
|
include_directories(include)
|
2021-11-13 19:01:21 +01:00
|
|
|
|
2021-11-15 10:29:50 +01:00
|
|
|
# ============= CONFIGURE HDF5 ==============
|
|
|
|
|
2021-11-15 12:58:30 +01:00
|
|
|
# By defaulti, TREXIO is configured with the HDF5 support.
|
|
|
|
# To change this, append -DENABLE_HDF5=OFF to the cmake call.
|
2021-11-15 10:29:50 +01:00
|
|
|
option(ENABLE_HDF5 "Enable HDF5 support" ON)
|
|
|
|
|
2021-11-13 19:01:21 +01:00
|
|
|
if(ENABLE_HDF5)
|
2021-11-15 11:16:28 +01:00
|
|
|
# Try to detect HDF5 installation using built-in FindHDF5.cmake macro.
|
2021-11-15 10:29:50 +01:00
|
|
|
find_package(HDF5 REQUIRED COMPONENTS C HL)
|
|
|
|
|
|
|
|
if(HDF5_FOUND)
|
|
|
|
message(STATUS "HDF5 version :: ${HDF5_VERSION}")
|
|
|
|
message(STATUS "HDF5 include dir :: ${HDF5_INCLUDE_DIRS}")
|
|
|
|
else()
|
|
|
|
# Download and install HDF5 library using FetchContent
|
|
|
|
# ...
|
2021-11-15 11:16:28 +01:00
|
|
|
# For now - raise a FATAL_ERROR
|
|
|
|
message(FATAL_ERROR "HDF5 is enabled but not found.")
|
2021-11-15 10:29:50 +01:00
|
|
|
endif()
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# If HDF5 found:
|
2021-11-16 17:52:05 +01:00
|
|
|
# - append the trexio_hdf5.c source file with the HDF5 back end to the list TREXIO_SOURCES
|
2021-11-17 10:57:03 +01:00
|
|
|
list(APPEND TREXIO_SOURCES ${CMAKE_SOURCE_DIR}/src/trexio_hdf5.c)
|
|
|
|
list(APPEND TREXIO_PRIVATE_HEADERS ${CMAKE_SOURCE_DIR}/src/trexio_hdf5.h)
|
2021-11-15 12:58:30 +01:00
|
|
|
# - define symbol HAVE_HDF5=1 (used to activate HDF5 back end in the preprocessor conditionals)
|
2021-11-16 17:52:05 +01:00
|
|
|
target_compile_definitions(trexio PUBLIC "HAVE_HDF5")
|
2021-11-15 12:58:30 +01:00
|
|
|
# - include directories with HDF5 header files
|
2021-11-15 10:29:50 +01:00
|
|
|
target_include_directories(trexio PRIVATE ${HDF5_C_INCLUDE_DIRS})
|
2021-11-15 11:16:28 +01:00
|
|
|
# - link to HDF5 C libraries
|
2021-11-15 10:29:50 +01:00
|
|
|
target_link_libraries(trexio PRIVATE
|
|
|
|
${HDF5_C_HL_LIBRARIES}
|
|
|
|
${HDF5_C_LIBRARIES})
|
2021-11-13 19:01:21 +01:00
|
|
|
endif()
|
|
|
|
|
2021-11-17 10:57:03 +01:00
|
|
|
# Private headers have to be listed as sources, otherwise they are installed
|
|
|
|
# with public headers upon make install (when using PRIVATE_HEADER property).
|
|
|
|
target_sources(trexio PRIVATE ${TREXIO_SOURCES} ${TREXIO_PRIVATE_HEADERS})
|
2021-11-16 17:52:05 +01:00
|
|
|
|
2021-11-13 19:49:02 +01:00
|
|
|
# ================= TESTING =================
|
|
|
|
|
|
|
|
enable_testing()
|
|
|
|
|
2021-11-15 11:16:28 +01:00
|
|
|
# Create a list of tests for TEXT back end.
|
2021-11-15 10:29:50 +01:00
|
|
|
set(Tests_text
|
|
|
|
open_text
|
|
|
|
io_dset_float_text
|
|
|
|
io_dset_str_text
|
|
|
|
io_safe_dset_float_text
|
|
|
|
io_dset_int_text
|
|
|
|
io_num_text
|
|
|
|
io_str_text
|
|
|
|
overwrite_all_text
|
|
|
|
)
|
|
|
|
|
|
|
|
if(ENABLE_HDF5)
|
2021-11-15 11:16:28 +01:00
|
|
|
# Create a list of tests for HDF5 back end.
|
2021-11-15 10:29:50 +01:00
|
|
|
set(Tests_hdf5
|
|
|
|
open_hdf5
|
|
|
|
io_dset_float_hdf5
|
|
|
|
io_dset_str_hdf5
|
|
|
|
io_safe_dset_float_hdf5
|
|
|
|
io_dset_int_hdf5
|
|
|
|
io_num_hdf5
|
|
|
|
io_str_hdf5
|
|
|
|
overwrite_all_hdf5
|
|
|
|
)
|
2021-11-15 11:16:28 +01:00
|
|
|
|
|
|
|
# Set ${Tests} variable to the complete list of tests.
|
2021-11-15 10:29:50 +01:00
|
|
|
set(Tests io_all ${Tests_text} ${Tests_hdf5})
|
|
|
|
else()
|
|
|
|
set(Tests ${Tests_text})
|
|
|
|
endif()
|
|
|
|
|
2021-11-15 12:58:30 +01:00
|
|
|
# Compile each TREXIO test as an executable and add them to CTest using add_test.
|
2021-11-15 10:29:50 +01:00
|
|
|
foreach(test ${Tests})
|
|
|
|
add_executable(${test} tests/${test}.c)
|
|
|
|
target_link_libraries(${test} PRIVATE trexio)
|
|
|
|
add_test(NAME ${test} COMMAND $<TARGET_FILE:${test}>)
|
|
|
|
endforeach ()
|
2021-11-13 19:49:02 +01:00
|
|
|
|
2021-11-15 12:58:30 +01:00
|
|
|
# ============= FORTRAN SUPPORT ==============
|
|
|
|
|
|
|
|
include(FortranCInterface)
|
|
|
|
# Check that C and Fortran compilers can talk to each other.
|
|
|
|
FortranCInterface_VERIFY()
|
|
|
|
|
|
|
|
set(TREXIO_MOD_FILE ${CMAKE_SOURCE_DIR}/include/trexio_f.f90)
|
|
|
|
|
|
|
|
# Add TREXIO Fortran module as a library.
|
|
|
|
add_library(trexio_f SHARED)
|
|
|
|
target_sources(trexio_f PUBLIC ${TREXIO_MOD_FILE})
|
|
|
|
target_link_libraries(trexio_f PUBLIC trexio)
|
|
|
|
|
|
|
|
# Add Fortran test and link it with the aforementioned library.
|
|
|
|
add_executable(test_f tests/test_f.f90)
|
|
|
|
target_link_libraries(test_f PRIVATE trexio_f)
|
|
|
|
add_test(NAME test_f COMMAND $<TARGET_FILE:test_f>)
|
|
|
|
|
2021-11-16 17:52:05 +01:00
|
|
|
# ====== CODE GENERATION FOR DEVEL MODE =====
|
|
|
|
|
|
|
|
if(TREXIO_DEVEL)
|
|
|
|
set(ORG_FILES
|
|
|
|
src/templates_front/templator_front.org
|
|
|
|
src/templates_text/templator_text.org
|
|
|
|
trex.org
|
|
|
|
)
|
|
|
|
if(ENABLE_HDF5)
|
|
|
|
list(APPEND ORG_FILES src/templates_hdf5/templator_hdf5.org)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
add_custom_command(OUTPUT ${TREXIO_SOURCES}
|
2021-11-17 10:57:03 +01:00
|
|
|
${TREXIO_PUBLIC_HEADERS}
|
|
|
|
${TREXIO_PRIVATE_HEADERS}
|
2021-11-16 17:52:05 +01:00
|
|
|
${TREXIO_MOD_FILE}
|
|
|
|
COMMAND ./build_trexio.sh
|
|
|
|
DEPENDS ${ORG_FILES}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/tools
|
|
|
|
COMMENT "Generating TREXIO source code from org-mode files."
|
|
|
|
VERBATIM)
|
|
|
|
endif()
|
|
|
|
|
2021-11-13 19:49:02 +01:00
|
|
|
# ============= INSTALL TREXIO ==============
|
2021-11-13 19:01:21 +01:00
|
|
|
|
|
|
|
include(GNUInstallDirs)
|
2021-11-15 11:16:28 +01:00
|
|
|
# Use standard GNU directories for installation of TREXIO (e.g. /usr/local/lib|include).
|
|
|
|
# The installation prefix can be modified using -DCMAKE_INSTALL_PREFIX=<custom/path> option of cmake.
|
2021-11-13 19:01:21 +01:00
|
|
|
install(TARGETS trexio
|
2021-11-17 10:57:03 +01:00
|
|
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
|
|
|
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
|
|
|
|
)
|
2021-11-15 12:58:30 +01:00
|
|
|
# Also install trexio_f.f90 file with TREXIO Fortran module.
|
|
|
|
install(FILES ${TREXIO_MOD_FILE} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
2021-11-13 19:01:21 +01:00
|
|
|
|
2021-11-16 18:10:36 +01:00
|
|
|
# Uninstall target, copied from CMake FAQ:
|
|
|
|
# https://gitlab.kitware.com/cmake/community/wikis/FAQ#can-i-do-make-uninstall-with-cmake
|
|
|
|
if(NOT TARGET uninstall)
|
|
|
|
configure_file(
|
2021-11-17 11:02:35 +01:00
|
|
|
"${CMAKE_CURRENT_SOURCE_DIR}/cmake/cmake_uninstall.cmake.in"
|
2021-11-16 18:10:36 +01:00
|
|
|
"${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
|
|
|
|
IMMEDIATE @ONLY)
|
|
|
|
|
|
|
|
add_custom_target(uninstall
|
|
|
|
COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake)
|
|
|
|
endif()
|
|
|
|
|
2021-11-13 19:49:02 +01:00
|
|
|
# ===========================================
|
2021-11-13 19:01:21 +01:00
|
|
|
|