diff options
author | Tomaz Canabrava <tomaz.canabrava@intel.com> | 2015-11-17 18:33:33 -0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-12-16 07:59:37 -0800 |
commit | 268fbf3fb152bba485b4924d2b686889d8b10532 (patch) | |
tree | 21df7f1f7f7c92804ef82e4614891d44e7c277b5 /CMakeLists.txt | |
parent | f60e86b19c6d785a91bc126ac587bf9f3ee87369 (diff) | |
download | subsurface-268fbf3fb152bba485b4924d2b686889d8b10532.tar.gz |
Handle VersionGeneration outside of the main CMakeFile
This is actually a good change: we used to write a new
CMake file in configure time just to move it outside of the
source to the build dir at compile time. Now this file is
pre-created and it's only moved.
Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com>
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r-- | CMakeLists.txt | 56 |
1 files changed, 1 insertions, 55 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index e4f7b8581..2a3bf27f1 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -91,6 +91,7 @@ include(cmake/Modules/HandleFindLibDiveComputer.cmake) include(cmake/Modules/HandleFindMarble.cmake) include(cmake/Modules/HandleFindGrantlee.cmake) include(cmake/Modules/HandleFtdiSupport.cmake) +include(cmake/Modules/HandleVersionGeneration.cmake) pkg_config_library(LIBXML libxml-2.0 REQUIRED) pkg_config_library(LIBSQLITE3 sqlite3 REQUIRED) @@ -146,61 +147,6 @@ if(BTSUPPORT) add_definitions(-DBT_SUPPORT) endif() -# Generate the ssrf-config.h every 'make' -file(WRITE ${CMAKE_BINARY_DIR}/version.h.in -"#define VERSION_STRING \"@VERSION_STRING@\" -#define GIT_VERSION_STRING \"@GIT_VERSION_STRING@\" -#define CANONICAL_VERSION_STRING \"@CANONICAL_VERSION_STRING@\" -") - -file(WRITE ${CMAKE_BINARY_DIR}/version.cmake " - if(\${APPLE}) - set(VER_OS darwin) - elseif(\${WIN32}) - set(VER_OS win) - else() - set(VER_OS linux) - endif() - if(CMAKE_SYSTEM_NAME STREQUAL \"Windows\") - set(VER_OS win) - endif() - execute_process( - COMMAND sh scripts/get-version \${VER_OS} - WORKING_DIRECTORY ${CMAKE_SOURCE_DIR} - OUTPUT_VARIABLE VERSION_STRING - OUTPUT_STRIP_TRAILING_WHITESPACE - ) - execute_process( - COMMAND sh scripts/get-version linux - WORKING_DIRECTORY ${CMAKE_SOURCE_DIR} - OUTPUT_VARIABLE GIT_VERSION_STRING - OUTPUT_STRIP_TRAILING_WHITESPACE - ) - execute_process( - COMMAND sh scripts/get-version full - WORKING_DIRECTORY ${CMAKE_SOURCE_DIR} - OUTPUT_VARIABLE CANONICAL_VERSION_STRING - OUTPUT_STRIP_TRAILING_WHITESPACE - ) - configure_file(\${SRC} \${DST} @ONLY) - if(CMAKE_SYSTEM_NAME STREQUAL \"Windows\") - execute_process( - COMMAND cat ${CMAKE_SOURCE_DIR}/packaging/windows/subsurface.nsi.in - COMMAND sed -e \"s/VERSIONTOKEN/\${GIT_VERSION_STRING}/\" - COMMAND sed -e \"s/PRODVTOKEN/\${CANONICAL_VERSION_STRING}/\" - OUTPUT_FILE ${CMAKE_BINARY_DIR}/staging/subsurface.nsi - ) - endif() -") - -add_custom_target( - version ALL COMMAND ${CMAKE_COMMAND} ${CMAKE_COMMAND} - -D SRC=${CMAKE_BINARY_DIR}/version.h.in - -D DST=${CMAKE_BINARY_DIR}/ssrf-version.h - -D CMAKE_SYSTEM_NAME=${CMAKE_SYSTEM_NAME} - -P ${CMAKE_BINARY_DIR}/version.cmake -) - # set up the different target platforms if(CMAKE_SYSTEM_NAME STREQUAL "Linux") set(SUBSURFACE_TARGET subsurface) |