Akin to config.h, we write project-version.h whenever the VCS sha hash of the project changes. This file can then be included to embed this into the project. Since this changes more frequently, we choose another file than config.h. Care is also taken to not rewrite the header if the information doesn't change, but the project is rebuilt.
64 lines
1.8 KiB
CMake
64 lines
1.8 KiB
CMake
# - This script must be passed the following information
|
|
#
|
|
# GIT_EXECUTABLE Path to the Git executable
|
|
# PROJECT_SOURCE_DIR Path to the source directory
|
|
# PROJECT_BINARY_DIR Path to the build directory
|
|
# PROJECT_LABEL String that identifies the minor
|
|
# version of the project, e.g. "2013.03"
|
|
#
|
|
|
|
# get hash code
|
|
exec_program (
|
|
${GIT_EXECUTABLE} ${PROJECT_SOURCE_DIR}
|
|
ARGS rev-parse --short --verify HEAD
|
|
OUTPUT_VARIABLE sha1
|
|
RETURN_VALUE has_sha
|
|
)
|
|
|
|
# exec_program unfortunately mashes together both output
|
|
# and error streams, so we must use the return code to make
|
|
# sure that we only get the output
|
|
if (NOT ${has_sha} EQUAL 0)
|
|
set (sha1 "")
|
|
endif ()
|
|
|
|
# check for local changes
|
|
if (sha1)
|
|
# unstaged
|
|
exec_program (
|
|
${GIT_EXECUTABLE} ${PROJECT_SOURCE_DIR}
|
|
ARGS diff --no-ext-diff --quiet --exit-code
|
|
RETURN_VALUE dirty
|
|
OUTPUT_VARIABLE _dummy
|
|
)
|
|
|
|
# staged
|
|
exec_program (
|
|
${GIT_EXECUTABLE} ${PROJECT_SOURCE_DIR}
|
|
ARGS diff-index --no-ext-diff --cached --quiet --exit-code HEAD --
|
|
RETURN_VALUE staged
|
|
OUTPUT_VARIABLE _dummy
|
|
)
|
|
|
|
# if we found any changes, then append an asterisk to
|
|
# the SHA1 so we know that it cannot be trusted
|
|
if (dirty OR staged)
|
|
set (sha1 "${sha1}*")
|
|
endif ()
|
|
|
|
# make a formatted version that can be appended to the label
|
|
set (sha1 " (${sha1})")
|
|
endif ()
|
|
|
|
# write the content to a temporary file in a C compatible format
|
|
file (WRITE "${PROJECT_BINARY_DIR}/project-version.tmp"
|
|
"#define PROJECT_VERSION \"${PROJECT_LABEL}${sha1}\"\n"
|
|
)
|
|
|
|
# only commit this to source code if it actually changed. here
|
|
# we use execute_process instead of exec_program to avoid having
|
|
# it printed on the console every time
|
|
execute_process (COMMAND
|
|
${CMAKE_COMMAND} -E copy_if_different "${PROJECT_BINARY_DIR}/project-version.tmp" "${PROJECT_BINARY_DIR}/project-version.h"
|
|
)
|