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:
parent
a3a07af910
commit
a1e26b0105
1
AUTHORS
1
AUTHORS
|
@ -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>
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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'
|
Loading…
Reference in New Issue