3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-05 19:08:45 +01:00

Adding cmake config files to install targets, Major cleaning

This commit is contained in:
Nils Wentzell 2018-03-23 16:59:38 +01:00
parent 2b76c51f12
commit 6bf4afd316
16 changed files with 113 additions and 101 deletions

View File

@ -1,5 +1,5 @@
# Version number # Version number
set (APP4TRIQS_VERSION "1.5") set(APP4TRIQS_VERSION "1.5")
# Start configuration # Start configuration
cmake_minimum_required(VERSION 2.8) cmake_minimum_required(VERSION 2.8)
@ -9,31 +9,28 @@ project(app4triqs CXX)
if(NOT CMAKE_BUILD_TYPE) if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE Release CACHE STRING "Type of build" FORCE) set(CMAKE_BUILD_TYPE Release CACHE STRING "Type of build" FORCE)
endif() endif()
message( STATUS "-------- BUILD-TYPE: ${CMAKE_BUILD_TYPE} -------------") message( STATUS "-------- BUILD-TYPE: ${CMAKE_BUILD_TYPE} --------")
# Use shared libraries # Use shared libraries
set(BUILD_SHARED_LIBS ON) set(BUILD_SHARED_LIBS ON)
# Load TRIQS and Cpp2Py # Load TRIQS and Cpp2Py
find_package(TRIQS 1.5 EXACT REQUIRED) find_package(TRIQS ${APP4TRIQS_VERSION} EXACT REQUIRED)
find_package(Cpp2Py 1.5 EXACT REQUIRED) find_package(Cpp2Py ${APP4TRIQS_VERSION} EXACT REQUIRED)
# We will need the FindNNFT of triqs, so we adjust CMake Module Path to find it # We will need the FindNNFT of triqs, so we adjust CMake Module Path to find it
list(APPEND CMAKE_MODULE_PATH ${TRIQS_ROOT}/share/cmake) list(APPEND CMAKE_MODULE_PATH ${TRIQS_ROOT}/share/cmake)
# Default Install directory to TRIQS_ROOT if not given. Checks an absolute name is given. # Default Install directory to TRIQS_ROOT if not given. Checks an absolute name is given.
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT OR (NOT IS_ABSOLUTE ${CMAKE_INSTALL_PREFIX})) if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT OR (NOT IS_ABSOLUTE ${CMAKE_INSTALL_PREFIX}))
message(STATUS " No install prefix given (or invalid). Defaulting to TRIQS_ROOT") message(STATUS "No install prefix given (or invalid). Defaulting to TRIQS_ROOT")
set(CMAKE_INSTALL_PREFIX ${TRIQS_ROOT} CACHE PATH "default install path" FORCE) set(CMAKE_INSTALL_PREFIX ${TRIQS_ROOT} CACHE PATH "default install path" FORCE)
endif() endif()
message(STATUS "-------- CMAKE_INSTALL_PREFIX: ${CMAKE_INSTALL_PREFIX} -------------") message(STATUS "-------- INSTALL_PREFIX: ${CMAKE_INSTALL_PREFIX} --------")
# Macro defined in TRIQS which picks the hash of repo. # Fetch the git hash of app4triqs
triqs_get_git_hash_of_source_dir(APP4TRIQS_GIT_HASH) triqs_get_git_hash_of_source_dir(APP4TRIQS_GIT_HASH)
message(STATUS "Git hash: ${APP4TRIQS_GIT_HASH}") message(STATUS "app4triqs git hash: ${APP4TRIQS_GIT_HASH}")
# Common to all targets (c++, python, tests).
include_directories(c++)
# Set up the rpath for compiled executable # Set up the rpath for compiled executable
triqs_set_rpath_for_all_targets() triqs_set_rpath_for_all_targets()

View File

@ -3,17 +3,18 @@ add_library(app4triqs_c ${sources})
target_link_libraries(app4triqs_c PUBLIC triqs) target_link_libraries(app4triqs_c PUBLIC triqs)
target_compile_options(app4triqs_c PUBLIC -std=c++17) target_compile_options(app4triqs_c PUBLIC -std=c++17)
target_include_directories(app4triqs_c PUBLIC $<BUILD_INTERFACE:${CMAKE_SOURCE_DIR}/c++>)
target_compile_definitions(app4triqs_c PUBLIC target_compile_definitions(app4triqs_c PRIVATE
APP4TRIQS_GIT_HASH=${APP4TRIQS_GIT_HASH} APP4TRIQS_GIT_HASH=${APP4TRIQS_GIT_HASH}
TRIQS_GIT_HASH=${TRIQS_GIT_HASH} TRIQS_GIT_HASH=${TRIQS_GIT_HASH}
$<$<CONFIG:Debug>:DEBUG_APP4TRIQS> $<$<CONFIG:Debug>:DEBUG_APP4TRIQS>
$<$<CONFIG:Debug>:TRIQS_ARRAYS_ENFORCE_BOUNDCHECK> $<$<CONFIG:Debug>:TRIQS_ARRAYS_ENFORCE_BOUNDCHECK>
#$<$<BOOL:${MyOption}>:MYOPTION> # Add compile definintions for option #$<$<BOOL:${MyOption}>:MYOPTION> # Add compile definintions for option
) )
# Install # Install
install(TARGETS app4triqs_c DESTINATION lib) install(TARGETS app4triqs_c EXPORT app4triqs-targets DESTINATION lib)
# If other applications need our headers, we can install them as well # If other applications need our headers, we can install them as well
# install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} DESTINATION include FILES_MATCHING PATTERN "*.hpp" PATTERN "*.h") install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} DESTINATION include FILES_MATCHING PATTERN "*.hpp" PATTERN "*.h")

View File

@ -30,16 +30,25 @@ execute_process(COMMAND cp_rs ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY
add_custom_target(docs_cpp2rst) add_custom_target(docs_cpp2rst)
get_property(TRIQS_INCLUDE_DIRS TARGET triqs PROPERTY INTERFACE_INCLUDE_DIRECTORIES)
get_property(APP4TRIQS_INCLUDE_DIRS TARGET app4triqs_c PROPERTY INTERFACE_INCLUDE_DIRECTORIES)
set(CPP2RST_INCLUDE_DIRS ${TRIQS_INCLUDE_DIRS} ${APP4TRIQS_INCLUDE_DIRS})
foreach(I ${CPP2RST_INCLUDE_DIRS})
set (CPP2RST_INCLUDE_COMMAND ${CPP2RST_INCLUDE_COMMAND} --includes ${I})
endforeach()
macro(generate_docs header_file) macro(generate_docs header_file)
add_custom_command (TARGET docs_cpp2rst add_custom_command (TARGET docs_cpp2rst
COMMAND c++2rst COMMAND c++2rst
${header_file} ${header_file}
-N app4triqs -N app4triqs
--output_directory ${CMAKE_CURRENT_BINARY_DIR}/cpp2rst_generated --output_directory ${CMAKE_CURRENT_BINARY_DIR}/cpp2rst_generated
--cxxflags="-std=c++17" ${CPP2RST_INCLUDE_COMMAND}
-I ${CMAKE_SOURCE_DIR}/c++ --cxxflags="-std=c++17"
-I ${TRIQS_ROOT}/include -I ${CMAKE_SOURCE_DIR}/c++
2>&1 >> cpp2rst.log -I ${TRIQS_ROOT}/include
2>&1 >> cpp2rst.log
) )
endmacro(generate_docs) endmacro(generate_docs)

View File

@ -1,3 +1,6 @@
.. _about: .. _about:
About app4triqs
===============
An example application using cpp2py and triqs. An example application using cpp2py and triqs.

View File

@ -29,4 +29,4 @@ html_sidebars = {'index': ['sideb.html', 'searchbox.html']}
htmlhelp_basename = 'TRIQSIntdoc' htmlhelp_basename = 'TRIQSIntdoc'
intersphinx_mapping = {'python': ('http://docs.python.org/2.7', None), 'triqslibs': ('http://ipht.cea.fr/triqs', None)} intersphinx_mapping = {'python': ('http://docs.python.org/2.7', None), 'triqslibs': ('https://triqs.ipht.cnrs.fr/unstable', None)}

View File

@ -1,12 +1,24 @@
.. _contents:
Table of contents Documentation
================= =============
Contents
--------
.. toctree:: .. toctree::
:maxdepth: 5 :maxdepth: 5
index index
documentation
install install
issues issues
about about
Reference manual
----------------
.. toctree::
:maxdepth: 5
cpp2rst_generated/app4triqs/toto
cpp2rst_generated/app4triqs/chain

View File

@ -1,12 +0,0 @@
.. _documentation:
Documentation
=============
Reference manual
----------------
.. toctree::
:maxdepth: 1
cpp2rst_generated/app4triqs/compute_Sigma_Hedin

View File

@ -1,11 +1,11 @@
.. _welcome: .. _welcome:
App4Triqs app4triqs
========= =========
An example application using cpp2py and triqs. An example application using cpp2py and triqs.
This documentation is generated based on the doc/\*.rst files and This documentation is generated based on `rst <https://de.wikipedia.org/wiki/ReStructuredText>`_ files
the comments in the sources and headers. and the comments in the sources and headers.
Lets have a look at the :ref:`documentation`. Lets have a look at the :ref:`documentation <contents>`.

View File

@ -43,8 +43,8 @@ Version compatibility
Be careful that the version of the TRIQS library and of the solver must be Be careful that the version of the TRIQS library and of the solver must be
compatible (more information on the :ref:`TRIQS website <triqslibs:versions>`). compatible (more information on the :ref:`TRIQS website <triqslibs:versions>`).
As the TRILEX project is currently still in alpha phase (unstable), it can As app4triqs is still in alpha phase (unstable), it can only be compiled against the
only be compiled against the unstable branch of triqs. unstable branch of triqs.
Custom CMake options Custom CMake options
-------------------- --------------------

View File

@ -1,25 +1,3 @@
################################################################################
#
# App4Triqs: Test application for Triqs
#
# Copyright (C) 2018 by The Simons Foundation
# Author: H. U.R. Strand
#
# App4Triqs is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# App4Triqs is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License along with
# App4Triqs. If not, see <http://www.gnu.org/licenses/>.
#
################################################################################
r""" r"""
DOC DOC

View File

@ -1,25 +1,3 @@
################################################################################
#
# App4Triqs: Test application for Triqs
#
# Copyright (C) 2018 by The Simons Foundation
# Author: H. U.R. Strand
#
# App4Triqs is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# App4Triqs is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License along with
# App4Triqs. If not, see <http://www.gnu.org/licenses/>.
#
################################################################################
version = "@APP4TRIQS_VERSION@" version = "@APP4TRIQS_VERSION@"
triqs_hash = "@TRIQS_GIT_HASH@" triqs_hash = "@TRIQS_GIT_HASH@"
app4triqs_hash = "@APP4TRIQS_GIT_HASH@" app4triqs_hash = "@APP4TRIQS_GIT_HASH@"

View File

@ -1,10 +1,16 @@
add_subdirectory(cmake)
if(NOT CMAKE_INSTALL_PREFIX STREQUAL TRIQS_ROOT) if(NOT CMAKE_INSTALL_PREFIX STREQUAL TRIQS_ROOT)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/app4triqs.modulefile.in ${CMAKE_CURRENT_BINARY_DIR}/app4triqs.modulefile @ONLY) configure_file(app4triqs.modulefile.in app4triqs.modulefile @ONLY)
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/app4triqs.modulefile DESTINATION ${CMAKE_INSTALL_PREFIX}/share) configure_file(app4triqsvars.sh.in app4triqsvars.sh @ONLY)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/app4triqsvars.sh.in ${CMAKE_CURRENT_BINARY_DIR}/app4triqsvars.sh @ONLY) install(
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/app4triqsvars.sh DESTINATION ${CMAKE_INSTALL_PREFIX}/share) FILES
${CMAKE_CURRENT_BINARY_DIR}/app4triqs.modulefile
${CMAKE_CURRENT_BINARY_DIR}/app4triqsvars.sh
DESTINATION share
)
message(STATUS "***************************************************************") message(STATUS "***************************************************************")
message(STATUS "* Custom install Location. Use: ") message(STATUS "* Custom install Location. Use: ")

View File

@ -8,6 +8,3 @@ export LIBRARY_PATH=@CMAKE_INSTALL_PREFIX@/lib:$LIBRARY_PATH
export LD_LIBRARY_PATH=@CMAKE_INSTALL_PREFIX@/lib:$LD_LIBRARY_PATH export LD_LIBRARY_PATH=@CMAKE_INSTALL_PREFIX@/lib:$LD_LIBRARY_PATH
export PYTHONPATH=@CMAKE_INSTALL_PREFIX@/@CPP2PY_PYTHON_LIB_DEST_ROOT@:$PYTHONPATH export PYTHONPATH=@CMAKE_INSTALL_PREFIX@/@CPP2PY_PYTHON_LIB_DEST_ROOT@:$PYTHONPATH
export CMAKE_PREFIX_PATH=@CMAKE_INSTALL_PREFIX@/share/cmake:$CMAKE_PREFIX_PATH export CMAKE_PREFIX_PATH=@CMAKE_INSTALL_PREFIX@/share/cmake:$CMAKE_PREFIX_PATH

View File

@ -0,0 +1,10 @@
configure_file(app4triqs-config.cmake.in app4triqs-config.cmake @ONLY)
configure_file(app4triqs-config-version.cmake.in app4triqs-config-version.cmake @ONLY)
install(
FILES
${CMAKE_CURRENT_BINARY_DIR}/app4triqs-config.cmake
${CMAKE_CURRENT_BINARY_DIR}/app4triqs-config-version.cmake
DESTINATION share/cmake
)
install(EXPORT app4triqs-targets DESTINATION share/cmake)

View File

@ -0,0 +1,13 @@
set(PACKAGE_VERSION @APP4TRIQS_VERSION@)
if (PACKAGE_FIND_VERSION VERSION_EQUAL PACKAGE_VERSION)
set(PACKAGE_VERSION_EXACT TRUE)
endif()
if (PACKAGE_FIND_VERSION VERSION_LESS PACKAGE_VERSION)
set(PACKAGE_VERSION_COMPATIBLE TRUE)
endif()
if (PACKAGE_FIND_VERSION VERSION_GREATER PACKAGE_VERSION)
set(PACKAGE_VERSION_UNSUITABLE TRUE)
endif()

View File

@ -0,0 +1,20 @@
# Multiple inclusion guard
if (NOT APP4TRIQS_FOUND)
set(APP4TRIQS_FOUND True)
# version
set(APP4TRIQS_VERSION @APP4TRIQS_VERSION@)
set(APP4TRIQS_GIT_HASH @APP4TRIQS_GIT_HASH@)
# Root of the installation
set(APP4TRIQS_ROOT @CMAKE_INSTALL_PREFIX@)
# include the exported targets of this project
include(@CMAKE_INSTALL_PREFIX@/share/cmake/app4triqs-targets.cmake)
MESSAGE(STATUS "Found APP4TRIQSConfig.cmake with version ${APP4TRIQS_VERSION}, hash = ${APP4TRIQS_GIT_HASH}")
# Documentation
set(APP4TRIQS_WITH_DOCUMENTATION @Build_Documentation@)
endif (NOT APP4TRIQS_FOUND)