Merge pull request #2877 from hugovk/python_requires

Specify compatible Python versions for pip
This commit is contained in:
wiredfool 2017-12-09 14:08:31 +00:00 committed by GitHub
commit cb216fad68
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -40,25 +40,33 @@ _IMAGING = ("decode", "encode", "map", "display", "outline", "path")
_LIB_IMAGING = ( _LIB_IMAGING = (
"Access", "AlphaComposite", "Resample", "Bands", "BcnDecode", "BitDecode", "Access", "AlphaComposite", "Resample", "Bands", "BcnDecode", "BitDecode",
"Blend", "Chops", "Convert", "ConvertYCbCr", "Copy", "Crc32", "Crop", "Dib", "Blend", "Chops", "Convert", "ConvertYCbCr", "Copy", "Crc32", "Crop",
"Draw", "Effects", "EpsEncode", "File", "Fill", "Filter", "FliDecode", "Dib", "Draw", "Effects", "EpsEncode", "File", "Fill", "Filter",
"Geometry", "GetBBox", "GifDecode", "GifEncode", "HexDecode", "Histo", "FliDecode", "Geometry", "GetBBox", "GifDecode", "GifEncode", "HexDecode",
"JpegDecode", "JpegEncode", "LzwDecode", "Matrix", "ModeFilter", "Histo", "JpegDecode", "JpegEncode", "LzwDecode", "Matrix", "ModeFilter",
"Negative", "Offset", "Pack", "PackDecode", "Palette", "Paste", "Negative", "Offset", "Pack", "PackDecode", "Palette", "Paste", "Quant",
"Quant", "QuantOctree", "QuantHash", "QuantHeap", "PcdDecode", "PcxDecode", "QuantOctree", "QuantHash", "QuantHeap", "PcdDecode", "PcxDecode",
"PcxEncode", "Point", "RankFilter", "RawDecode", "RawEncode", "Storage", "PcxEncode", "Point", "RankFilter", "RawDecode", "RawEncode", "Storage",
"SgiRleDecode", "SunRleDecode", "TgaRleDecode", "Unpack", "UnpackYCC", "SgiRleDecode", "SunRleDecode", "TgaRleDecode", "Unpack", "UnpackYCC",
"UnsharpMask", "XbmDecode", "XbmEncode", "ZipDecode", "ZipEncode", "TiffDecode", "UnsharpMask", "XbmDecode", "XbmEncode", "ZipDecode", "ZipEncode",
"Jpeg2KDecode", "Jpeg2KEncode", "BoxBlur", "QuantPngQuant", "codec_fd") "TiffDecode", "Jpeg2KDecode", "Jpeg2KEncode", "BoxBlur", "QuantPngQuant",
"codec_fd")
DEBUG = False DEBUG = False
class DependencyException(Exception): pass
class RequiredDependencyException(Exception): pass class DependencyException(Exception):
pass
class RequiredDependencyException(Exception):
pass
PLATFORM_MINGW = 'mingw' in ccompiler.get_default_compiler() PLATFORM_MINGW = 'mingw' in ccompiler.get_default_compiler()
PLATFORM_PYPY = hasattr(sys, 'pypy_version_info') PLATFORM_PYPY = hasattr(sys, 'pypy_version_info')
def _dbg(s, tp=None): def _dbg(s, tp=None):
if DEBUG: if DEBUG:
if tp: if tp:
@ -108,6 +116,7 @@ def _cmd_exists(cmd):
for path in os.environ["PATH"].split(os.pathsep) for path in os.environ["PATH"].split(os.pathsep)
) )
def _read(file): def _read(file):
with open(file, 'rb') as fp: with open(file, 'rb') as fp:
return fp.read() return fp.read()
@ -119,6 +128,7 @@ def get_version():
exec(compile(f.read(), version_file, 'exec')) exec(compile(f.read(), version_file, 'exec'))
return locals()['__version__'] return locals()['__version__']
try: try:
import _tkinter import _tkinter
except (ImportError, OSError): except (ImportError, OSError):
@ -136,6 +146,7 @@ FREETYPE_ROOT = None
LCMS_ROOT = None LCMS_ROOT = None
RAQM_ROOT = None RAQM_ROOT = None
def _pkg_config(name): def _pkg_config(name):
try: try:
command = [ command = [
@ -147,9 +158,10 @@ def _pkg_config(name):
command.append('--silence-errors') command.append('--silence-errors')
libs = subprocess.check_output(command).decode('utf8').split(' ') libs = subprocess.check_output(command).decode('utf8').split(' ')
return libs[1][2:].strip(), libs[0][2:].strip() return libs[1][2:].strip(), libs[0][2:].strip()
except: except Exception:
pass pass
class pil_build_ext(build_ext): class pil_build_ext(build_ext):
class feature: class feature:
features = ['zlib', 'jpeg', 'tiff', 'freetype', 'raqm', 'lcms', 'webp', features = ['zlib', 'jpeg', 'tiff', 'freetype', 'raqm', 'lcms', 'webp',
@ -178,7 +190,8 @@ class pil_build_ext(build_ext):
] + [ ] + [
('enable-%s' % x, None, 'Enable support for %s' % x) for x in feature ('enable-%s' % x, None, 'Enable support for %s' % x) for x in feature
] + [ ] + [
('disable-platform-guessing', None, 'Disable platform guessing on Linux'), ('disable-platform-guessing', None,
'Disable platform guessing on Linux'),
('debug', None, 'Debug logging') ('debug', None, 'Debug logging')
] ]
@ -299,7 +312,7 @@ class pil_build_ext(build_ext):
try: try:
prefix = subprocess.check_output(['brew', '--prefix']).strip( prefix = subprocess.check_output(['brew', '--prefix']).strip(
).decode('latin1') ).decode('latin1')
except: except Exception:
# Homebrew not installed # Homebrew not installed
prefix = None prefix = None
@ -337,8 +350,10 @@ class pil_build_ext(build_ext):
_add_directory(library_dirs, "/usr/lib/i386-linux-gnu") _add_directory(library_dirs, "/usr/lib/i386-linux-gnu")
else: else:
libdirs = { libdirs = {
'x86_64': ["/lib64", "/usr/lib64", "/usr/lib/x86_64-linux-gnu"], 'x86_64': ["/lib64", "/usr/lib64",
'64bit': ["/lib64", "/usr/lib64", "/usr/lib/x86_64-linux-gnu"], "/usr/lib/x86_64-linux-gnu"],
'64bit': ["/lib64", "/usr/lib64",
"/usr/lib/x86_64-linux-gnu"],
'i386': ["/usr/lib/i386-linux-gnu"], 'i386': ["/usr/lib/i386-linux-gnu"],
'i686': ["/usr/lib/i386-linux-gnu"], 'i686': ["/usr/lib/i386-linux-gnu"],
'32bit': ["/usr/lib/i386-linux-gnu"], '32bit': ["/usr/lib/i386-linux-gnu"],
@ -371,7 +386,8 @@ class pil_build_ext(build_ext):
# user libs are at $PREFIX/lib # user libs are at $PREFIX/lib
if os.environ.get('ANDROID_ROOT', None): if os.environ.get('ANDROID_ROOT', None):
_add_directory(library_dirs, _add_directory(library_dirs,
os.path.join(os.environ['ANDROID_ROOT'],'lib')) os.path.join(os.environ['ANDROID_ROOT'],
'lib'))
elif sys.platform.startswith("gnu"): elif sys.platform.startswith("gnu"):
self.add_multiarch_paths() self.add_multiarch_paths()
@ -608,9 +624,9 @@ class pil_build_ext(build_ext):
defs.append(("WORDS_BIGENDIAN", None)) defs.append(("WORDS_BIGENDIAN", None))
if sys.platform == "win32" and not (PLATFORM_PYPY or PLATFORM_MINGW): if sys.platform == "win32" and not (PLATFORM_PYPY or PLATFORM_MINGW):
defs.append(("PILLOW_VERSION", '"\\"%s\\""'%PILLOW_VERSION)) defs.append(("PILLOW_VERSION", '"\\"%s\\""' % PILLOW_VERSION))
else: else:
defs.append(("PILLOW_VERSION", '"%s"'%PILLOW_VERSION)) defs.append(("PILLOW_VERSION", '"%s"' % PILLOW_VERSION))
exts = [(Extension("PIL._imaging", exts = [(Extension("PIL._imaging",
files, files,
@ -712,7 +728,8 @@ class pil_build_ext(build_ext):
if not all: if not all:
print("To add a missing option, make sure you have the required") print("To add a missing option, make sure you have the required")
print("library and headers.") print("library and headers.")
print("See https://pillow.readthedocs.io/en/latest/installation.html#building-from-source") print("See https://pillow.readthedocs.io/en/latest/installation."
"html#building-from-source")
print("") print("")
print("To check the build, run the selftest.py script.") print("To check the build, run the selftest.py script.")
@ -730,7 +747,7 @@ class pil_build_ext(build_ext):
try: try:
ret = subprocess.call(['dpkg-architecture', ret = subprocess.call(['dpkg-architecture',
'-qDEB_HOST_MULTIARCH'], stdout=fp) '-qDEB_HOST_MULTIARCH'], stdout=fp)
except: except Exception:
return return
try: try:
if ret >> 8 == 0: if ret >> 8 == 0:
@ -771,9 +788,10 @@ try:
"Programming Language :: Python :: 3.4", "Programming Language :: Python :: 3.4",
"Programming Language :: Python :: 3.5", "Programming Language :: Python :: 3.5",
"Programming Language :: Python :: 3.6", "Programming Language :: Python :: 3.6",
'Programming Language :: Python :: Implementation :: CPython', "Programming Language :: Python :: Implementation :: CPython",
'Programming Language :: Python :: Implementation :: PyPy', "Programming Language :: Python :: Implementation :: PyPy",
], ],
python_requires=">=2.7, !=3.0.*, !=3.1.*, !=3.2.*",
cmdclass={"build_ext": pil_build_ext}, cmdclass={"build_ext": pil_build_ext},
ext_modules=[Extension("PIL._imaging", ["_imaging.c"])], ext_modules=[Extension("PIL._imaging", ["_imaging.c"])],
include_package_data=True, include_package_data=True,