Change version string to contain git hash instead of svn revision

This commit is contained in:
Nick Hall 2013-11-08 19:44:15 +00:00
parent 63578d95a0
commit 57daf4f269
3 changed files with 8 additions and 21 deletions

View File

@ -43,7 +43,7 @@ import uuid
# Gramps modules # Gramps modules
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
from .svn_revision import get_svn_revision from .git_revision import get_git_revision
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -145,7 +145,7 @@ if sys.version_info[0] < 3:
ROOT_DIR = os.path.abspath(os.path.join(os.path.dirname( ROOT_DIR = os.path.abspath(os.path.join(os.path.dirname(
unicode(__file__, sys.getfilesystemencoding())), os.pardir)) unicode(__file__, sys.getfilesystemencoding())), os.pardir))
VERSION += get_svn_revision(ROOT_DIR) VERSION += get_git_revision(ROOT_DIR)
# #
# Glade files # Glade files

View File

@ -25,7 +25,6 @@ from __future__ import unicode_literals
import sys import sys
import subprocess import subprocess
import re
if sys.version_info[0] < 3: if sys.version_info[0] < 3:
cuni = unicode cuni = unicode
@ -34,8 +33,9 @@ else:
return s.decode("utf-8", errors = 'replace') return s.decode("utf-8", errors = 'replace')
cuni = to_utf8 cuni = to_utf8
def _get_svn_revision(path, command, stdout_to_rev): def get_git_revision(path=""):
stdout = "" stdout = ""
command = "git log -1 --format=%h"
try: try:
p = subprocess.Popen( p = subprocess.Popen(
"{} \"{}\"".format(command, path), "{} \"{}\"".format(command, path),
@ -50,19 +50,6 @@ def _get_svn_revision(path, command, stdout_to_rev):
stdout = cuni(stdout) # get a proper string stdout = cuni(stdout) # get a proper string
except UnicodeDecodeError: except UnicodeDecodeError:
pass pass
rev = stdout_to_rev(stdout) return "-" + stdout if stdout else ""
return "-r" + rev if rev else "" else: # no output from git log
else: # no output from svnversion
return "" return ""
def get_svn_revision(path=""):
return _get_svn_revision(path, "svnversion -n",
lambda stdout: stdout if stdout[0].isdigit() else ""
) or get_git_svn_revision(path)
def get_git_svn_revision(path=""):
def stdout_to_rev(stdout):
m = re.search("Revision:\s+(\d+)", stdout, re.MULTILINE)
return m.group(1) if m else ""
return _get_svn_revision(path, "git svn info", stdout_to_rev)

View File

@ -15,6 +15,7 @@ gramps/cli/__init__.py
gramps/gen/constfunc.py gramps/gen/constfunc.py
gramps/gen/dbstate.py gramps/gen/dbstate.py
gramps/gen/errors.py gramps/gen/errors.py
gramps/gen/git_revision.py
gramps/gen/__init__.py gramps/gen/__init__.py
gramps/gen/recentfiles.py gramps/gen/recentfiles.py
gramps/gen/sort.py gramps/gen/sort.py
@ -253,7 +254,6 @@ gramps/gen/utils/file.py
gramps/gen/utils/id.py gramps/gen/utils/id.py
gramps/gen/utils/libformatting.py gramps/gen/utils/libformatting.py
gramps/gen/utils/mactrans.py gramps/gen/utils/mactrans.py
gramps/gen/utils/svn.py
gramps/gen/utils/test/callback_test.py gramps/gen/utils/test/callback_test.py
# #
# gen.utils.docgen # gen.utils.docgen