# HG changeset patch
# User Akos Ladanyi <ladanyi@tmit.bme.hu>
# 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