Update the revision checks to work with a pure-git repo

This commit is contained in:
Thomas Goyne 2012-08-19 14:05:38 -07:00
parent fd6652b345
commit 42a016a83b
9 changed files with 99 additions and 79 deletions

1
.gitignore vendored
View file

@ -64,3 +64,4 @@ configure
svn-revision.h svn-revision.h
svn_revision svn_revision
svnmove.txt svnmove.txt
git_version.h

View file

@ -43,7 +43,7 @@ AEGISUB_VERSION_DATA = @AEGISUB_VERSION_DATA@
BUILD_DATE = @BUILD_DATE@ BUILD_DATE = @BUILD_DATE@
PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_TARNAME = @PACKAGE_TARNAME@
PACKAGE_DEBUG = @PACKAGE_DEBUG@ PACKAGE_DEBUG = @PACKAGE_DEBUG@
SVN_REVISION = @SVN_REVISION@ BUILD_VERSION_STRING = @BUILD_GIT_VERSION_STRING@
# OS X # OS X
BUNDLE_STRING = @BUNDLE_STRING@ BUNDLE_STRING = @BUNDLE_STRING@
DARWIN_ARCH = @DARWIN_ARCH@ DARWIN_ARCH = @DARWIN_ARCH@

View file

@ -0,0 +1,9 @@
cd %~dp0..
sh build/version.sh .
if %ERRORLEVEL% NEQ 0 goto :fail
goto :eof
:fail
ECHO Aegisub requires that sh and git be on the windows command line path for version checking.
> build\git_version.h echo #define BUILD_GIT_VERSION_NUMBER 0
>> build\git_version.h echo #define BUILD_GIT_VERSION_STR "unknown"

52
aegisub/build/version.sh Executable file
View file

@ -0,0 +1,52 @@
srcdir="$1"
# If no git repo try to read from the existing git_version.h, for building from tarballs
if ! test -d "${srcdir}/.git"; then
version_h_path="${srcdir}/aegisub/build/git_version.h"
if test -f "${version_h_path}"; then
while read line; do
set -- $line
export $2=$(echo $3 | sed 's/"//g')
done < "${version_h_path}"
if test x$BUILD_GIT_VERSION_NUMBER != x -a x$BUILD_GIT_VERSION_STRING != x; then
export VERSION_SOURCE="from cached git_version.h"
return 0
else
echo "invalid git_version.h"
exit 2
fi
else
echo "git repo not found and no cached git_version.h"
exit 2
fi
fi
last_svn_revision=6962
last_svn_hash="2289c084f28d9923989e1b58b81332347130ea78"
git_branch="$(git symbolic-ref HEAD 2> /dev/null)" || git_branch="(unnamed branch)"
git_branch="${git_branch##refs/heads/}"
git_revision=$(expr $last_svn_revision + $(git log --pretty=oneline $last_svn_hash..HEAD 2>/dev/null | wc -l))
git_hash=$(git rev-parse --short HEAD)
git_version_str="${git_revision}-${git_branch}-${git_hash}"
new_version_h="\
#define BUILD_GIT_VERSION_NUMBER ${git_revision}
#define BUILD_GIT_VERSION_STRING \"${git_version_str}\""
# may not exist yet for out of tree builds
mkdir -p build
version_h_path="build/git_version.h"
# Write it only if it's changed to avoid spurious rebuilds
# This bizzare comparison method is due to that newlines in shell variables are very exciting
case "$(cat ${version_h_path} 2> /dev/null)"
in
"${new_version_h}");;
*) echo "${new_version_h}" > "${version_h_path}"
esac
export BUILD_GIT_VERSION_NUMBER="${git_revision}"
export BUILD_GIT_VERSION_STRING="${git_version_str}"
export VERSION_SOURCE="from git"

View file

@ -40,7 +40,6 @@ AC_CONFIG_HEADER([acconf.h])
AC_GNU_SOURCE AC_GNU_SOURCE
AC_CANONICAL_HOST AC_CANONICAL_HOST
########################### ###########################
# Check host architecture # Check host architecture
########################### ###########################
@ -151,29 +150,9 @@ PKG_PROG_PKG_CONFIG([pkgconfig_required_version])
################# #################
# Developers only # Developers only
################# #################
# XXX: This needs to be fixed to handle mixed revisions properly AC_MSG_CHECKING([for version])
# There is probably a better way to handle it as well... . $srcdir/build/version.sh "$srcdir/.."
AC_MSG_CHECKING([for svn version]) AC_MSG_RESULT([$BUILD_GIT_VERSION_STRING $VERSION_SOURCE])
# Try to get revision from working copy and check if it makes sense
SVN_REVISION=`svnversion $srcdir | sed "s/\(^@<:@0-9@:>@*\).*/\1/"` 2> /dev/null
AS_IF([test -n "$SVN_REVISION" -a -z "`echo $SVN_REVISION | tr -d '0-9'`"], [
`echo $SVN_REVISION > $srcdir/svn_revision`
AC_MSG_RESULT([$SVN_REVISION from "svnversion $srcdir"])
], [test -f "$srcdir/svn_revision"], [
SVN_REVISION=`cat $srcdir/svn_revision`
AC_MSG_RESULT([$SVN_REVISION from "$srcdir/svn_revision"])
], [test -d "$srcdir/../.git"], [
SVN_REVISION=[`git log --format=%b | grep git-svn-id -m 1 | sed -E 's/.*@([0-9]+) .*/\1/'`]
`echo $SVN_REVISION > $srcdir/svn_revision`
AC_MSG_RESULT([$SVN_REVISION from git])
], [
AC_MSG_RESULT([not found])
AC_MSG_FAILURE([unable to get SVN Revision from $srcdir/svn_revision or 'svnversion $srcdir'])
])
# This is required in order for the config file to work correctly.
AC_DEFINE_UNQUOTED([BUILD_SVN_REVISION], [$SVN_REVISION], [SVN Revision number, used for config.dat and version.cpp])
# Release information. # Release information.
AS_IF([test "aegisub_FINAL_RELEASE" = "1"], [ AS_IF([test "aegisub_FINAL_RELEASE" = "1"], [
@ -181,24 +160,23 @@ AS_IF([test "aegisub_FINAL_RELEASE" = "1"], [
BUNDLE_STRING="${PACKAGE_NAME}" BUNDLE_STRING="${PACKAGE_NAME}"
DMG_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}-${arch_bundle}" DMG_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}-${arch_bundle}"
], [ ], [
PACKAGE_STRING="${PACKAGE_STRING}-dev-r${SVN_REVISION}" PACKAGE_STRING="${PACKAGE_STRING}-dev-r${BUILD_GIT_VERSION_NUMBER}"
PACKAGE_VERSION="${PACKAGE_VERSION}-dev-r${SVN_REVISION}" PACKAGE_VERSION="${PACKAGE_VERSION}-dev-r${BUILD_GIT_VERSION_NUMBER}"
VERSION="${VERSION}-dev-r${SVN_REVISION}" VERSION="${VERSION}-dev-r${BUILD_GIT_VERSION_NUMBER}"
BUNDLE_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}" BUNDLE_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}"
DMG_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}-${arch_bundle}" DMG_STRING="${PACKAGE_NAME}-${PACKAGE_VERSION}-${arch_bundle}"
]) ])
PACKAGE_TARNAME="${PACKAGE_TARNAME}-${PACKAGE_VERSION}" PACKAGE_TARNAME="${PACKAGE_TARNAME}-${PACKAGE_VERSION}"
# Used in version.cpp
AC_MSG_CHECKING([for build date]) AC_MSG_CHECKING([for build date])
BUILD_DATE=`date "+%Y-%m-%d %H:%M %Z"` BUILD_DATE=`date "+%Y-%m-%d %H:%M %Z"`
AC_MSG_RESULT($BUILD_DATE) AC_MSG_RESULT($BUILD_DATE)
AC_SUBST(SVN_REVISION)
AC_SUBST(BUILD_DATE)
AC_SUBST(BUNDLE_STRING) AC_SUBST(BUNDLE_STRING)
AC_SUBST(DMG_STRING) AC_SUBST(DMG_STRING)
AC_SUBST([BUILD_GIT_VERSION_STRING])
AC_SUBST([BUILD_DATE])
################################################### ###################################################
# Check for pthreads and setup variables / compiler # Check for pthreads and setup variables / compiler
@ -731,7 +709,7 @@ AS_IF([test x$with_ffms2 != xyes], [AC_MSG_NOTICE([
AC_MSG_RESULT([ AC_MSG_RESULT([
Configure settings Configure settings
Install prefix: $prefix Install prefix: $prefix
SVN Revision: $SVN_REVISION Revision: $BUILD_GIT_VERSION_STRING
Debug $enable_debug Debug $enable_debug
CFLAGS $CFLAGS CFLAGS $CFLAGS
CXXFLAGS $CXXFLAGS CXXFLAGS $CXXFLAGS

View file

@ -31,7 +31,7 @@
<string>@PLIST_VERSION@</string> <string>@PLIST_VERSION@</string>
<key>CFBundleLongVersionString</key> <key>CFBundleLongVersionString</key>
<string>@PLIST_VERSION@ (@PLIST_SVN_REVISION@), Copyright 2005-2012, aegisub http://www.aegisub.org/</string> <string>@PLIST_VERSION@, Copyright 2005-2012, aegisub http://www.aegisub.org/</string>
<!-- Values: i386, ppc, x86_65, ppc64 --> <!-- Values: i386, ppc, x86_65, ppc64 -->
<key>LSArchitecturePriority</key> <key>LSArchitecturePriority</key>
@ -39,7 +39,7 @@
<!-- Displayed in the 'Get Info' context menu dialogue --> <!-- Displayed in the 'Get Info' context menu dialogue -->
<key>CFBundleGetInfoString</key> <key>CFBundleGetInfoString</key>
<string>aegisub version @PLIST_VERSION@ (@PLIST_SVN_REVISION@) built on @PLIST_BUILD_DATE@ http://www.aegisub.org/</string> <string>aegisub version @PLIST_VERSION@ built on @PLIST_BUILD_DATE@ http://www.aegisub.org/</string>
<!-- Whether to allow multiple instances across user logins --> <!-- Whether to allow multiple instances across user logins -->
<key>LSMultipleInstancesProhibited</key> <key>LSMultipleInstancesProhibited</key>

View file

@ -5,7 +5,7 @@ PROGRAM_INSTALL = yes
PRECOMPILED_HEADER_NAME=agi_pre.h PRECOMPILED_HEADER_NAME=agi_pre.h
AEGISUB_CFLAGS = -I. -I.. -Iinclude -I../libaegisub/include -DAEGISUB $(CFLAGS_PTHREAD) $(CFLAGS_FFTW3) $(CFLAGS_PROFILE) AEGISUB_CFLAGS = -I. -I.. -Iinclude -I../libaegisub/include -I../build -DAEGISUB $(CFLAGS_PTHREAD) $(CFLAGS_FFTW3) $(CFLAGS_PROFILE)
CFLAGS += $(AEGISUB_CFLAGS) CFLAGS += $(AEGISUB_CFLAGS)
CXXFLAGS += $(AEGISUB_CFLAGS) -D__STDC_FORMAT_MACROS $(CXXFLAGS_WX) CXXFLAGS += $(AEGISUB_CFLAGS) -D__STDC_FORMAT_MACROS $(CXXFLAGS_WX)

View file

@ -37,60 +37,40 @@
#include "config.h" #include "config.h"
#include "version.h" #include "version.h"
#include "git_version.h"
#ifdef __WINDOWS__
#include "../build/svn-revision.h"
#endif
#define STR_INT2(x) #x
#define STR_INT(x) STR_INT2(x)
#ifdef _DEBUG
#define DEBUG_SUFFIX " [DEBUG VERSION]"
#else
#define DEBUG_SUFFIX ""
#endif
#ifdef BUILD_CREDIT
#define BUILD_CREDIT_SUFFIX ", " BUILD_CREDIT
#else
#define BUILD_CREDIT_SUFFIX ""
#endif
#ifndef BUILD_SVN_DATE
#define BUILD_SVN_DATE __DATE__ " " __TIME__
#endif
#ifndef BUILD_SVN_LOCALMODS
#define BUILD_SVN_LOCALMODS ""
#endif
// Define FINAL_RELEASE to mark a build as a "final" version, ie. not pre-release version // Define FINAL_RELEASE to mark a build as a "final" version, ie. not pre-release version
// In that case it won't include the SVN revision information // In that case it won't include the SVN revision information
#ifdef FINAL_RELEASE #ifdef FINAL_RELEASE
#define VERSION_NUMBER "3.0.0" #define VERSION_NUMBER "3.0.0"
#define BUILD_CREDIT_SUFFIX ""
#define DEBUG_SUFFIX ""
#else #else
#define VERSION_NUMBER "r" STR_INT(BUILD_SVN_REVISION) BUILD_SVN_LOCALMODS #define VERSION_NUMBER BUILD_GIT_VERSION_STRING
#ifdef _DEBUG
#define DEBUG_SUFFIX " [DEBUG VERSION]"
#else
#define DEBUG_SUFFIX ""
#endif
#ifdef BUILD_CREDIT
#define BUILD_CREDIT_SUFFIX ", " BUILD_CREDIT
#else
#define BUILD_CREDIT_SUFFIX ""
#endif
#endif #endif
const char *GetAegisubLongVersionString() { const char *GetAegisubLongVersionString() {
#ifdef FINAL_RELEASE return VERSION_NUMBER BUILD_CREDIT_SUFFIX DEBUG_SUFFIX;
return VERSION_NUMBER DEBUG_SUFFIX;
#else
return VERSION_NUMBER " (development version" BUILD_CREDIT_SUFFIX ")" DEBUG_SUFFIX;
#endif
} }
const char *GetAegisubShortVersionString() { const char *GetAegisubShortVersionString() {
#ifdef FINAL_RELEASE return VERSION_NUMBER DEBUG_SUFFIX;
return VERSION_NUMBER " (built from SVN revision r" #BUILD_SVN_REVISION BUILD_SVN_LOCALMODS ")" DEBUG_SUFFIX;
#else
return VERSION_NUMBER " (development version" BUILD_CREDIT_SUFFIX ")" DEBUG_SUFFIX;
#endif
} }
const char *GetAegisubBuildTime() { const char *GetAegisubBuildTime() {
return BUILD_SVN_DATE; return __DATE__ " " __TIME__;
} }
const char *GetAegisubBuildCredit() { const char *GetAegisubBuildCredit() {
@ -114,9 +94,10 @@ const char *GetVersionNumber() {
} }
int GetSVNRevision() { int GetSVNRevision() {
#ifdef BUILD_SVN_REVISION #ifdef BUILD_GIT_VERSION_NUMBER
return BUILD_SVN_REVISION; return BUILD_GIT_VERSION_NUMBER;
#else #else
return 0; return 0;
#endif #endif
} }

View file

@ -1,5 +1,4 @@
s/@PLIST_VERSION@/@VERSION@/g s/@PLIST_VERSION@/@BUILD_VERSION_STRING@/g
s/@PLIST_SVN_REVISION@/@SVN_REVISION@/g
s/@PLIST_BUILD_DATE@/@BUILD_DATE@/g s/@PLIST_BUILD_DATE@/@BUILD_DATE@/g
s/@PKG_DMG_STRING@/@DMG_STRING@/ s/@PKG_DMG_STRING@/@DMG_STRING@/
s/@PKG_BUNDLE_STRING@/@BUNDLE_STRING@/ s/@PKG_BUNDLE_STRING@/@BUNDLE_STRING@/