# HG changeset patch # User Akos Ladanyi # Date 1243593653 -3600 # Node ID d1e1cd94bf49d75657dde71a3557a267acbf0644 # Parent a0265f621d393d765cb5a476a729f77d1388cc15 Put the version string into config.h Also make it possible to set the version using the LEMON_VERSION environment variable, and use the hg revision as version string in case this variable is unset. diff -r a0265f621d39 -r d1e1cd94bf49 CMakeLists.txt --- a/CMakeLists.txt Fri May 29 10:35:05 2009 +0100 +++ b/CMakeLists.txt Fri May 29 11:40:53 2009 +0100 @@ -1,13 +1,24 @@ CMAKE_MINIMUM_REQUIRED(VERSION 2.6) -IF(EXISTS ${CMAKE_SOURCE_DIR}/cmake/version.cmake) - INCLUDE(${CMAKE_SOURCE_DIR}/cmake/version.cmake) -ELSE(EXISTS ${CMAKE_SOURCE_DIR}/cmake/version.cmake) - SET(PROJECT_NAME "LEMON") - SET(PROJECT_VERSION "hg-tip" CACHE STRING "LEMON version string.") -ENDIF(EXISTS ${CMAKE_SOURCE_DIR}/cmake/version.cmake) +SET(PROJECT_NAME "LEMON") +PROJECT(${PROJECT_NAME}) -PROJECT(${PROJECT_NAME}) +IF(EXISTS ${PROJECT_SOURCE_DIR}/cmake/version.cmake) + INCLUDE(${PROJECT_SOURCE_DIR}/cmake/version.cmake) +ELSEIF(DEFINED ENV{LEMON_VERSION}) + SET(LEMON_VERSION $ENV{LEMON_VERSION} CACHE STRING "LEMON version string.") +ELSE() + EXECUTE_PROCESS( + COMMAND hg id -i + WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} + OUTPUT_VARIABLE HG_REVISION + ERROR_QUIET + OUTPUT_STRIP_TRAILING_WHITESPACE + ) + SET(LEMON_VERSION ${HG_REVISION} CACHE STRING "LEMON version string.") +ENDIF() + +SET(PROJECT_VERSION ${LEMON_VERSION}) SET(CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake) diff -r a0265f621d39 -r d1e1cd94bf49 cmake/version.cmake.in --- a/cmake/version.cmake.in Fri May 29 10:35:05 2009 +0100 +++ b/cmake/version.cmake.in Fri May 29 11:40:53 2009 +0100 @@ -1,2 +1,1 @@ -SET(PROJECT_NAME "@PACKAGE_NAME@") -SET(PROJECT_VERSION "@PACKAGE_VERSION@" CACHE STRING "LEMON version string.") +SET(LEMON_VERSION "@PACKAGE_VERSION@" CACHE STRING "LEMON version string.") diff -r a0265f621d39 -r d1e1cd94bf49 configure.ac --- a/configure.ac Fri May 29 10:35:05 2009 +0100 +++ b/configure.ac Fri May 29 11:40:53 2009 +0100 @@ -19,6 +19,8 @@ AC_CONFIG_SRCDIR([lemon/list_graph.h]) AC_CONFIG_HEADERS([config.h lemon/config.h]) +AC_DEFINE([LEMON_VERSION], [lemon_version()], [The version string]) + dnl Do compilation tests using the C++ compiler. AC_LANG([C++]) diff -r a0265f621d39 -r d1e1cd94bf49 lemon/config.h.cmake --- a/lemon/config.h.cmake Fri May 29 10:35:05 2009 +0100 +++ b/lemon/config.h.cmake Fri May 29 11:40:53 2009 +0100 @@ -1,3 +1,4 @@ +#define LEMON_VERSION "@PROJECT_VERSION@" #cmakedefine LEMON_HAVE_LONG_LONG 1 #cmakedefine LEMON_HAVE_LP 1 #cmakedefine LEMON_HAVE_MIP 1 diff -r a0265f621d39 -r d1e1cd94bf49 lemon/config.h.in --- a/lemon/config.h.in Fri May 29 10:35:05 2009 +0100 +++ b/lemon/config.h.in Fri May 29 11:40:53 2009 +0100 @@ -1,3 +1,6 @@ +/* The version string */ +#undef LEMON_VERSION + /* Define to 1 if you have long long */ #undef LEMON_HAVE_LONG_LONG