From 727ee3aa980d505b0381ab3a0e574ca5d7094451 Mon Sep 17 00:00:00 2001 From: Cristian Ionescu-Idbohrn Date: Sat, 16 Feb 2013 23:54:17 +0100 Subject: Unified handling of version extraction. Removed oddly named and ridiculously outdated documentation text (scripts). Created new directory 'scripts'. Added unified version extraction script (scripts/get-version). Yes, it's more shell script code but faster and more maintainable than the sed commands and the swearwords/regexps repeated over and over again. Makefile and packaging/macosx/make-package.sh modified accordingly. I don't do windos neither macos but, AFAICS my tests show, it should be safe. Signed-off-by: Cristian Ionescu-Idbohrn Signed-off-by: Dirk Hohndel --- Makefile | 11 +++++--- packaging/macosx/make-package.sh | 2 +- scripts | 13 ---------- scripts/get-version | 56 ++++++++++++++++++++++++++++++++++++++++ 4 files changed, 64 insertions(+), 18 deletions(-) delete mode 100644 scripts create mode 100755 scripts/get-version diff --git a/Makefile b/Makefile index 43ab19a29..63528a93c 100644 --- a/Makefile +++ b/Makefile @@ -26,11 +26,14 @@ MANFILES = $(NAME).1 XSLTFILES = xslt/*.xslt UNAME := $(shell $(CC) -dumpmachine 2>&1 | grep -E -o "linux|darwin|win") -VERSION_STRING := $(shell git describe --tags --abbrev=12 || echo "v$(VERSION)") -# Windows .nsi style with four numbers 1.2.3.4 -PRODVERSION_STRING := $(shell git describe --tags --abbrev=12 | sed 's/v\([0-9]*\)\.\([0-9]*\)-\([0-9]*\)-.*/\1.\2.\3.0/ ; s/v\([0-9]\)\.\([0-9]*\)/\1.\2.0.0/' || echo "$(VERSION).0.0") +GET_VERSION = ./scripts/get-version +VERSION_STRING := $(shell $(GET_VERSION) linux || echo "v$(VERSION)") # Mac Info.plist style with three numbers 1.2.3 -CFBUNDLEVERSION_STRING := $(shell git describe --tags --abbrev=12 | sed 's/v\([0-9]*\)\.\([0-9]*\)-\([0-9]*\)-.*/\1.\2.\3/ ; s/v\([0-9]\)\.\([0-9]*\)/\1.\2.0/' || echo "$(VERSION).0") +CFBUNDLEVERSION_STRING := $(shell $(GET_VERSION) darwin $(VERSION_STRING) || \ + echo "$(VERSION).0") +# Windows .nsi style with four numbers 1.2.3.4 +PRODVERSION_STRING := $(shell $(GET_VERSION) win $(VERSION_STRING) || \ + echo "$(VERSION).0.0") # find libdivecomputer # First deal with the cross compile environment and with Mac. diff --git a/packaging/macosx/make-package.sh b/packaging/macosx/make-package.sh index 0556ecb84..c9558b36f 100755 --- a/packaging/macosx/make-package.sh +++ b/packaging/macosx/make-package.sh @@ -24,7 +24,7 @@ PREFIX="/Applications/Subsurface.app/Contents/Resources" INFOPLIST=./packaging/macosx/Info.plist # same git version magic as in the Makefile -VERSION=`git describe --tags --abbrev=12 | sed 's/v\([0-9]*\)\.\([0-9]*\)-\([0-9]*\)-.*/\1.\2.\3/ ; s/v\([0-9]\)\.\([0-9]*\)/\1.\2.0/' || echo "git.missing.please.hardcode.version"` +VERSION=$(./scripts/get-version darwin) # gtk-mac-bundler allegedly supports signing by setting this environment # variable, but this fails as we change the shared objects below and all diff --git a/scripts b/scripts deleted file mode 100644 index 5afc688b1..000000000 --- a/scripts +++ /dev/null @@ -1,13 +0,0 @@ -Downloading with 'libdivecomputer': - - - result: one XML file for all dives in the computer - - [torvalds@i5 examples]$ ./universal -b vyper2 /dev/ttyUSB0 - [torvalds@i5 examples]$ mv output.xml 2011-08-28.xml - -Unpacking Suunto SDE files: - - - result: one XML file per dive: - - mv LinusDivelogs.SDE LinusDivelogs.zip - unzip LinusDivelogs.zip diff --git a/scripts/get-version b/scripts/get-version new file mode 100755 index 000000000..c59e2000b --- /dev/null +++ b/scripts/get-version @@ -0,0 +1,56 @@ +#!/bin/sh + +# $1 - os name {linux|darwin|win} +# $2 - [optional] raw version string "vX.Y-patchN-sha1". as from `git describe' +# (see below) + +set -eu +#set -x + +croak() { + echo "$0: $*" >&2 + exit 1 +} + +[ $# -ge 1 ] || croak "missing OS argument" +os=$1 + +if [ $# -eq 2 ] && [ "$2" ]; then + v0=$2 +else + cmd="git describe --tags --abbrev=12" + v0=$($cmd) || croak "odd; command '$cmd' failed" +fi + +# strip off the 'v' prefix, if any +v0=${v0#v} + +case $os in + linux) + v=$v0 + ;; + darwin|win) + # split version string using a '-' separator + IFS='-' + set -- $v0 + v1=$1 + if [ $# -gt 1 ]; then + v1=$v1.$2 + else + v1=$v1.0 + fi + case $os in + darwin) + v=$v1 + ;; + win) + # always add '0' as the 4:th digit + v=$v1.0 + ;; + esac + ;; + *) + v='git.missing.please.hardcode.version' + ;; +esac +printf '%s' $v -- cgit v1.2.3-70-g09d2