diff options
| author | Jason R. Coombs <jaraco@jaraco.com> | 2014-09-27 15:43:10 -0400 |
|---|---|---|
| committer | Jason R. Coombs <jaraco@jaraco.com> | 2014-09-27 15:43:10 -0400 |
| commit | c5d53df96d27f54f40ae4df974a74e1536f45ae1 (patch) | |
| tree | f47e9efbfef91e8d91f8b8fc6bfd9f6f474577a3 /setuptools/dist.py | |
| parent | 2b5d7f1333ff860bc9210ab3ad9ab2791db12bc2 (diff) | |
| parent | 9382fa0c05e533400613e1c7c0a777cabb463390 (diff) | |
| download | python-setuptools-git-c5d53df96d27f54f40ae4df974a74e1536f45ae1.tar.gz | |
Merge github pull request #13 (dstufft/setuptools:use-packaging).
Diffstat (limited to 'setuptools/dist.py')
| -rw-r--r-- | setuptools/dist.py | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/setuptools/dist.py b/setuptools/dist.py index 8b36f67c..ae4ff554 100644 --- a/setuptools/dist.py +++ b/setuptools/dist.py @@ -15,6 +15,7 @@ from distutils.errors import (DistutilsOptionError, DistutilsPlatformError, from setuptools.depends import Require from setuptools.compat import basestring, PY2 +from setuptools._vendor.packaging.version import Version, InvalidVersion import pkg_resources def _get_unpatched(cls): @@ -268,6 +269,26 @@ class Distribution(_Distribution): # Some people apparently take "version number" too literally :) self.metadata.version = str(self.metadata.version) + if self.metadata.version is not None: + try: + normalized_version = str(Version(self.metadata.version)) + if self.metadata.version != normalized_version: + warnings.warn( + "The version specified requires normalization, " + "consider using '%s' instead of '%s'." % ( + normalized_version, + self.metadata.version, + ) + ) + self.metadata.version = normalized_version + except (InvalidVersion, TypeError): + warnings.warn( + "The version specified (%r) is an invalid version, this " + "may not work as expected with newer versions of " + "setuptools, pip, and PyPI. Please see PEP 440 for more " + "details." % self.metadata.version + ) + def parse_command_line(self): """Process features after parsing command line options""" result = _Distribution.parse_command_line(self) |
