forked from tkLayout/tkLayout
-
Notifications
You must be signed in to change notification settings - Fork 5
/
GetGitVersion.cmake
69 lines (57 loc) · 2.91 KB
/
GetGitVersion.cmake
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#############################################################################
#
# CMAKE module to find Git version
#
# Author: Z. Drasal, CERN
#
#############################################################################
FIND_PACKAGE(Git)
IF(GIT_FOUND)
# Get Git branch
EXECUTE_PROCESS(COMMAND ${GIT_EXECUTABLE} rev-parse --abbrev-ref HEAD RESULT_VARIABLE res_var_branch OUTPUT_VARIABLE GIT_BRANCH )
IF( NOT ${res_var_branch} EQUAL 0 )
SET( GIT_BRANCH "Git_Command_Failed")
MESSAGE( WARNING "Git branch failed (not a repo, or no tags). Build will not contain git revision info." )
ENDIF()
# Get Git version
IF(CMAKE_HOST_UNIX)
# Unix like system
# EXECUTE_PROCESS(COMMAND ${GIT_EXECUTABLE} rev-list HEAD | wc -l RESULT_VARIABLE res_var OUTPUT_VARIABLE GIT_VERSION )
EXECUTE_PROCESS(COMMAND bash -c "git rev-list HEAD | wc -l" RESULT_VARIABLE res_var_version OUTPUT_VARIABLE GIT_VERSION )
ELSE()
# Non-unix system
EXECUTE_PROCESS(COMMAND ${GIT_EXECUTABLE} rev-parse HEAD RESULT_VARIABLE res_var_version OUTPUT_VARIABLE GIT_VERSION )
ENDIF()
IF( NOT ${res_var_version} EQUAL 0 )
SET( GIT_VERSION "Git_Command_Failed")
MESSAGE( WARNING "Git version failed (not shell, not a repo, or no tags). Build will not contain git revision info." )
ENDIF()
# Get Git author
EXECUTE_PROCESS(COMMAND ${GIT_EXECUTABLE} config --get remote.origin.url RESULT_VARIABLE res_var_author OUTPUT_VARIABLE GIT_AUTHOR )
IF( NOT ${res_var_author} EQUAL 0 )
SET( GIT_AUTHOR "Git_Command_Failed")
MESSAGE( WARNING "Git config url failed (not a repo, or no tags). Build will not contain git revision info." )
ENDIF()
STRING( REPLACE "\n" "" GIT_BRANCH ${GIT_BRANCH} )
STRING( REPLACE "\n" "" GIT_VERSION ${GIT_VERSION} )
STRING( REPLACE "\n" "" GIT_AUTHOR ${GIT_AUTHOR} )
# All information found
IF ( (${res_var_branch} EQUAL 0) AND (${res_var_version} EQUAL 0) AND (${res_var_author} EQUAL 0) )
#STRING( CONCAT GIT_REVISION ${GIT_BRANCH} "-" ${GIT_VERSION} " on " ${GIT_AUTHOR} )
SET( GIT_REVISION "${GIT_BRANCH}-${GIT_VERSION} on ${GIT_AUTHOR}" )
MESSAGE( STATUS "")
MESSAGE( STATUS "Git Revision: ${GIT_REVISION} " )
MESSAGE( STATUS "" )
# Unix like system
IF(CMAKE_HOST_UNIX)
# Create new GitRevision.cc
SET( vstring "#include <GitRevision.h>\n\n"
"//GitRevision.cc - written by cmake. changes will be lost!\n"
"const std::string GitRevision::revisionNumber = \"${GIT_REVISION}\"\;\n")
FILE(WRITE GitRevision.cc.txt ${vstring} )
EXECUTE_PROCESS(COMMAND bash -c "if [ ! -e GitRevision.orig.cc ]; then cp -p ${CMAKE_CURRENT_SOURCE_DIR}/../source/Tools/src/GitRevision.cc GitRevision.orig.cc; fi" )
EXECUTE_PROCESS(COMMAND ${CMAKE_COMMAND} -E copy_if_different
GitRevision.cc.txt ${CMAKE_CURRENT_SOURCE_DIR}/../source/Tools/src/GitRevision.cc)
ENDIF()
ENDIF()
ENDIF()