From 3066c08a0db54729af639e128b4e9fe4fdc8c008 Mon Sep 17 00:00:00 2001 From: Hector Martin Date: Sun, 11 Apr 2010 17:11:08 +0200 Subject: Add automatic git versioning and tag for archives --- Modules/VersionTag.cmake | 13 +++++++++++++ Modules/describe.sh | 17 +++++++++++++++++ 2 files changed, 30 insertions(+) create mode 100644 Modules/VersionTag.cmake create mode 100755 Modules/describe.sh (limited to 'Modules') diff --git a/Modules/VersionTag.cmake b/Modules/VersionTag.cmake new file mode 100644 index 0000000..682ab3e --- /dev/null +++ b/Modules/VersionTag.cmake @@ -0,0 +1,13 @@ +execute_process( + COMMAND "sh" "${CMAKE_SOURCE_DIR}/Modules/describe.sh" + WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}" + OUTPUT_VARIABLE DESCRIBE + OUTPUT_STRIP_TRAILING_WHITESPACE +) + +if(DESCRIBE STREQUAL "") + set (VERSION_TAG "UNKNOWN") +else() + string(REGEX REPLACE "^v" "" VERSION_TAG "${DESCRIBE}") +endif() + diff --git a/Modules/describe.sh b/Modules/describe.sh new file mode 100755 index 0000000..91730b8 --- /dev/null +++ b/Modules/describe.sh @@ -0,0 +1,17 @@ +#!/bin/bash + +# Check for git and a git repo. +if head=`git rev-parse --verify HEAD 2>/dev/null`; then + echo -n `git describe` + + # Are there uncommitted changes? + git update-index --refresh --unmerged > /dev/null + git diff-index --quiet HEAD || echo -n -dirty +else +# Check for version tag + if [ -e version.tag ]; then + echo -n `cat version.tag` + fi +fi + +echo -- cgit v1.1-32-gdbae