2012-06-08 00:08:47 +08:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2012-04-30 02:44:32 +08:00
|
|
|
import datetime
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
|
2014-08-23 21:26:59 +08:00
|
|
|
from django.utils.lru_cache import lru_cache
|
|
|
|
|
2013-11-03 04:12:09 +08:00
|
|
|
|
2012-04-30 02:44:32 +08:00
|
|
|
def get_version(version=None):
|
2016-01-12 22:19:07 +08:00
|
|
|
"Returns a PEP 440-compliant version number from VERSION."
|
2014-06-06 19:10:20 +08:00
|
|
|
version = get_complete_version(version)
|
2012-04-30 02:44:32 +08:00
|
|
|
|
|
|
|
# Now build the two parts of the version number:
|
2015-04-03 00:40:22 +08:00
|
|
|
# main = X.Y[.Z]
|
2012-04-30 02:44:32 +08:00
|
|
|
# sub = .devN - for pre-alpha releases
|
2015-11-18 00:51:26 +08:00
|
|
|
# | {a|b|rc}N - for alpha, beta, and rc releases
|
2012-04-30 02:44:32 +08:00
|
|
|
|
2015-04-03 00:40:22 +08:00
|
|
|
main = get_main_version(version)
|
2012-04-30 02:44:32 +08:00
|
|
|
|
|
|
|
sub = ''
|
|
|
|
if version[3] == 'alpha' and version[4] == 0:
|
|
|
|
git_changeset = get_git_changeset()
|
|
|
|
if git_changeset:
|
|
|
|
sub = '.dev%s' % git_changeset
|
|
|
|
|
|
|
|
elif version[3] != 'final':
|
2015-11-18 00:51:26 +08:00
|
|
|
mapping = {'alpha': 'a', 'beta': 'b', 'rc': 'rc'}
|
2012-04-30 02:44:32 +08:00
|
|
|
sub = mapping[version[3]] + str(version[4])
|
|
|
|
|
2015-04-03 00:40:22 +08:00
|
|
|
return str(main + sub)
|
2014-06-06 19:10:20 +08:00
|
|
|
|
|
|
|
|
2015-04-03 00:40:22 +08:00
|
|
|
def get_main_version(version=None):
|
|
|
|
"Returns main version (X.Y[.Z]) from VERSION."
|
2014-06-06 19:10:20 +08:00
|
|
|
version = get_complete_version(version)
|
|
|
|
parts = 2 if version[2] == 0 else 3
|
2015-04-03 00:40:22 +08:00
|
|
|
return '.'.join(str(x) for x in version[:parts])
|
2014-06-06 19:10:20 +08:00
|
|
|
|
|
|
|
|
|
|
|
def get_complete_version(version=None):
|
2014-08-04 21:55:16 +08:00
|
|
|
"""Returns a tuple of the django version. If version argument is non-empty,
|
2014-06-06 19:10:20 +08:00
|
|
|
then checks for correctness of the tuple provided.
|
|
|
|
"""
|
|
|
|
if version is None:
|
|
|
|
from django import VERSION as version
|
|
|
|
else:
|
|
|
|
assert len(version) == 5
|
|
|
|
assert version[3] in ('alpha', 'beta', 'rc', 'final')
|
|
|
|
|
|
|
|
return version
|
2012-04-30 02:44:32 +08:00
|
|
|
|
2013-11-03 04:12:09 +08:00
|
|
|
|
2014-12-25 20:30:37 +08:00
|
|
|
def get_docs_version(version=None):
|
|
|
|
version = get_complete_version(version)
|
|
|
|
if version[3] != 'final':
|
|
|
|
return 'dev'
|
|
|
|
else:
|
|
|
|
return '%d.%d' % version[:2]
|
|
|
|
|
|
|
|
|
2014-08-23 21:26:59 +08:00
|
|
|
@lru_cache()
|
2012-04-30 02:44:32 +08:00
|
|
|
def get_git_changeset():
|
|
|
|
"""Returns a numeric identifier of the latest git changeset.
|
|
|
|
|
|
|
|
The result is the UTC timestamp of the changeset in YYYYMMDDHHMMSS format.
|
|
|
|
This value isn't guaranteed to be unique, but collisions are very unlikely,
|
|
|
|
so it's sufficient for generating the development version numbers.
|
|
|
|
"""
|
|
|
|
repo_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
2016-03-29 06:33:29 +08:00
|
|
|
git_log = subprocess.Popen(
|
|
|
|
'git log --pretty=format:%ct --quiet -1 HEAD',
|
|
|
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE,
|
|
|
|
shell=True, cwd=repo_dir, universal_newlines=True,
|
|
|
|
)
|
2012-06-09 03:52:16 +08:00
|
|
|
timestamp = git_log.communicate()[0]
|
2012-04-30 02:44:32 +08:00
|
|
|
try:
|
|
|
|
timestamp = datetime.datetime.utcfromtimestamp(int(timestamp))
|
|
|
|
except ValueError:
|
2014-08-23 21:26:59 +08:00
|
|
|
return None
|
|
|
|
return timestamp.strftime('%Y%m%d%H%M%S')
|