summaryrefslogtreecommitdiff
path: root/django/utils/version.py
diff options
context:
space:
mode:
Diffstat (limited to 'django/utils/version.py')
-rw-r--r--django/utils/version.py34
1 files changed, 25 insertions, 9 deletions
diff --git a/django/utils/version.py b/django/utils/version.py
index 6798749d43..c680dbdc4a 100644
--- a/django/utils/version.py
+++ b/django/utils/version.py
@@ -7,19 +7,14 @@ import subprocess
def get_version(version=None):
"Returns a PEP 386-compliant version number from VERSION."
- if version is None:
- from django import VERSION as version
- else:
- assert len(version) == 5
- assert version[3] in ('alpha', 'beta', 'rc', 'final')
+ version = get_complete_version(version)
# Now build the two parts of the version number:
- # main = X.Y[.Z]
+ # major = X.Y[.Z]
# sub = .devN - for pre-alpha releases
# | {a|b|c}N - for alpha, beta and rc releases
- parts = 2 if version[2] == 0 else 3
- main = '.'.join(str(x) for x in version[:parts])
+ major = get_major_version(version)
sub = ''
if version[3] == 'alpha' and version[4] == 0:
@@ -31,7 +26,28 @@ def get_version(version=None):
mapping = {'alpha': 'a', 'beta': 'b', 'rc': 'c'}
sub = mapping[version[3]] + str(version[4])
- return str(main + sub)
+ return str(major + sub)
+
+
+def get_major_version(version=None):
+ "Returns major version from VERSION."
+ version = get_complete_version(version)
+ parts = 2 if version[2] == 0 else 3
+ major = '.'.join(str(x) for x in version[:parts])
+ return major
+
+
+def get_complete_version(version=None):
+ """Returns a tuple of the django version. If version argument is non-empy,
+ 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
def get_git_changeset():