diff options
| author | Anubhav Joshi <anubhav9042@gmail.com> | 2014-06-06 16:40:20 +0530 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2014-06-11 10:03:34 -0400 |
| commit | 42736ac8e8c31137131714013951249a09e6e7d4 (patch) | |
| tree | fcd32b692aee3b1a16902e340ab020e8a3b5a445 /django/utils/version.py | |
| parent | e163a3d17b2551001677b615ccdaeadf17705d29 (diff) | |
Fixed #21430 -- Added a RuntimeWarning when unpickling Models and QuerySets from a different Django version.
Thanks FunkyBob for the suggestion, prasoon2211 for the initial patch,
and akaariai, loic, and charettes for helping in shaping the patch.
Diffstat (limited to 'django/utils/version.py')
| -rw-r--r-- | django/utils/version.py | 34 |
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(): |
