Fixed #5215 -- Added Subversion revision number to Django version string. Thanks for the patch, Deryck Hodge

git-svn-id: http://code.djangoproject.com/svn/django/trunk@5990 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Adrian Holovaty 2007-08-21 03:08:02 +00:00
parent a3a07af910
commit a1e26b0105
3 changed files with 36 additions and 1 deletions

View File

@ -136,6 +136,7 @@ answer newbie questions, and generally made Django that much better:
Joe Heck <http://www.rhonabwy.com/wp/> Joe Heck <http://www.rhonabwy.com/wp/>
Joel Heenan <joelh-django@planetjoel.com> Joel Heenan <joelh-django@planetjoel.com>
hipertracker@gmail.com hipertracker@gmail.com
Deryck Hodge <http://www.devurandom.org/>
Brett Hoerner <bretthoerner@bretthoerner.com> Brett Hoerner <bretthoerner@bretthoerner.com>
Ian Holsman <http://feh.holsman.net/> Ian Holsman <http://feh.holsman.net/>
Kieran Holland <http://www.kieranholland.com> Kieran Holland <http://www.kieranholland.com>

View File

@ -4,5 +4,6 @@ def get_version():
"Returns the version as a human-format string." "Returns the version as a human-format string."
v = '.'.join([str(i) for i in VERSION[:-1]]) v = '.'.join([str(i) for i in VERSION[:-1]])
if VERSION[-1]: if VERSION[-1]:
v += '-' + VERSION[-1] from django.utils.version import get_svn_revision
v = '%s-%s-%s' % (v, VERSION[-1], get_svn_revision())
return v return v

33
django/utils/version.py Normal file
View File

@ -0,0 +1,33 @@
import django
import os.path
import re
def get_svn_revision():
"""
Returns the SVN revision in the form SVN-XXXX,
where XXXX is the revision number.
Returns SVN-unknown if anything goes wrong, such as an unexpected
format of internal SVN files.
"""
rev = None
entries_path = '%s/.svn/entries' % django.__path__[0]
if os.path.exists(entries_path):
entries = open(entries_path, 'r').read()
# Versions >= 7 of the entries file are flat text. The first line is
# the version number. The next set of digits after 'dir' is the revision.
if re.match('(\d+)', entries):
rev_match = re.search('\d+\s+dir\s+(\d+)', entries)
if rev_match:
rev = rev_match.groups()[0]
# Older XML versions of the file specify revision as an attribute of
# the first entries node.
else:
from xml.dom import minidom
dom = minidom.parse(entries_path)
rev = dom.getElementsByTagName('entry')[0].getAttribute('revision')
if rev:
return u'SVN-%s' % rev
return u'SVN-unknown'