mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-28 10:14:30 +03:00
Merge pull request #2877 from hugovk/python_requires
Specify compatible Python versions for pip
This commit is contained in:
commit
cb216fad68
62
setup.py
62
setup.py
|
@ -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,
|
||||||
|
|
Loading…
Reference in New Issue
Block a user