summaryrefslogtreecommitdiff
path: root/build/get-version.sh
diff options
context:
space:
mode:
authorGraham Leggett <minfrin@apache.org>2003-04-12 17:28:55 +0000
committerGraham Leggett <minfrin@apache.org>2003-04-12 17:28:55 +0000
commitf54208ac441ce3abce08a0344f11ea3c4b34a195 (patch)
treec82d83a46d56b67ac46b0cc4766a8c051d6e8da5 /build/get-version.sh
parenta9cddb794f61b06cc78fd5451d4fd91a61142354 (diff)
downloadhttpd-f54208ac441ce3abce08a0344f11ea3c4b34a195.tar.gz
Add code to buildconf that produces an httpd.spec file from
httpd.spec.in, using build/get-version.sh from APR. PR: Obtained from: Submitted by: Reviewed by: git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@99346 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'build/get-version.sh')
-rwxr-xr-xbuild/get-version.sh41
1 files changed, 41 insertions, 0 deletions
diff --git a/build/get-version.sh b/build/get-version.sh
new file mode 100755
index 0000000000..c6e6890d20
--- /dev/null
+++ b/build/get-version.sh
@@ -0,0 +1,41 @@
+#!/bin/sh
+#
+# extract version numbers from a header file
+#
+# USAGE: get-version.sh CMD VERSION_HEADER PREFIX
+# where CMD is one of: all, major, libtool
+# where PREFIX is the prefix to {MAJOR|MINOR|PATCH}_VERSION defines
+#
+# get-version.sh all returns a dotted version number
+# get-version.sh major returns just the major version number
+# get-version.sh libtool returns a version "libtool -version-info" format
+#
+
+if test $# != 3; then
+ echo "USAGE: $0 CMD INCLUDEDIR PREFIX"
+ echo " where CMD is one of: all, major"
+ exit 1
+fi
+
+major_sed="/#define.*$3_MAJORVERSION/s/^.*\([0-9][0-9]*\).*$/\1/p"
+minor_sed="/#define.*$3_MINORVERSION/s/^.*\([0-9][0-9]*\).*$/\1/p"
+patch_sed="/#define.*$3_PATCHLEVEL/s/^[^0-9]*\([0-9][0-9a-z-]*\).*$/\1/p"
+mmn_sed="/#define.*$3_MAJOR/s/^[^0-9]*\([0-9][0-9]*\).*$/\1/p"
+major="`sed -n $major_sed $2`"
+minor="`sed -n $minor_sed $2`"
+patch="`sed -n $patch_sed $2`"
+mmn="`sed -n $mmn_sed $2`"
+
+if test "$1" = "all"; then
+ echo ${major}.${minor}.${patch}
+elif test "$1" = "major"; then
+ echo ${major}
+elif test "$1" = "mmn"; then
+ echo ${mmn}
+elif test "$1" = "libtool"; then
+ # Yes, ${minor}:${patch}:${minor} is correct due to libtool idiocy.
+ echo ${minor}:${patch}:${minor}
+else
+ echo "ERROR: unknown version CMD ($1)"
+ exit 1
+fi