mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-13 18:56:17 +03:00
Merge pull request #4829 from radarhere/build_ext
Replaced distutils build_ext with setuptools
This commit is contained in:
commit
0ccb28088f
85
setup.py
85
setup.py
|
@ -14,9 +14,9 @@ import struct
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import warnings
|
import warnings
|
||||||
from distutils.command.build_ext import build_ext
|
|
||||||
|
|
||||||
from setuptools import Extension, setup
|
from setuptools import Extension, setup
|
||||||
|
from setuptools.command.build_ext import build_ext
|
||||||
|
|
||||||
|
|
||||||
def get_version():
|
def get_version():
|
||||||
|
@ -351,6 +351,22 @@ class pil_build_ext(build_ext):
|
||||||
_dbg("Requiring %s", x)
|
_dbg("Requiring %s", x)
|
||||||
self.feature.required.add(x)
|
self.feature.required.add(x)
|
||||||
|
|
||||||
|
def _update_extension(self, name, libraries, define_macros=None, include_dirs=None):
|
||||||
|
for extension in self.extensions:
|
||||||
|
if extension.name == name:
|
||||||
|
extension.libraries += libraries
|
||||||
|
if define_macros is not None:
|
||||||
|
extension.define_macros += define_macros
|
||||||
|
if include_dirs is not None:
|
||||||
|
extension.include_dirs += include_dirs
|
||||||
|
break
|
||||||
|
|
||||||
|
def _remove_extension(self, name):
|
||||||
|
for extension in self.extensions:
|
||||||
|
if extension.name == name:
|
||||||
|
self.extensions.remove(extension)
|
||||||
|
break
|
||||||
|
|
||||||
def build_extensions(self):
|
def build_extensions(self):
|
||||||
|
|
||||||
library_dirs = []
|
library_dirs = []
|
||||||
|
@ -694,12 +710,6 @@ class pil_build_ext(build_ext):
|
||||||
#
|
#
|
||||||
# core library
|
# core library
|
||||||
|
|
||||||
files = ["src/_imaging.c"]
|
|
||||||
for src_file in _IMAGING:
|
|
||||||
files.append("src/" + src_file + ".c")
|
|
||||||
for src_file in _LIB_IMAGING:
|
|
||||||
files.append(os.path.join("src/libImaging", src_file + ".c"))
|
|
||||||
|
|
||||||
libs = self.add_imaging_libs.split()
|
libs = self.add_imaging_libs.split()
|
||||||
defs = []
|
defs = []
|
||||||
if feature.jpeg:
|
if feature.jpeg:
|
||||||
|
@ -736,7 +746,7 @@ class pil_build_ext(build_ext):
|
||||||
else:
|
else:
|
||||||
defs.append(("PILLOW_VERSION", '"%s"' % PILLOW_VERSION))
|
defs.append(("PILLOW_VERSION", '"%s"' % PILLOW_VERSION))
|
||||||
|
|
||||||
exts = [(Extension("PIL._imaging", files, libraries=libs, define_macros=defs))]
|
self._update_extension("PIL._imaging", libs, defs)
|
||||||
|
|
||||||
#
|
#
|
||||||
# additional libraries
|
# additional libraries
|
||||||
|
@ -744,26 +754,17 @@ class pil_build_ext(build_ext):
|
||||||
if feature.freetype:
|
if feature.freetype:
|
||||||
libs = ["freetype"]
|
libs = ["freetype"]
|
||||||
defs = []
|
defs = []
|
||||||
exts.append(
|
self._update_extension("PIL._imagingft", libs, defs)
|
||||||
Extension(
|
else:
|
||||||
"PIL._imagingft",
|
self._remove_extension("PIL._imagingft")
|
||||||
["src/_imagingft.c"],
|
|
||||||
libraries=libs,
|
|
||||||
define_macros=defs,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
if feature.lcms:
|
if feature.lcms:
|
||||||
extra = []
|
extra = []
|
||||||
if sys.platform == "win32":
|
if sys.platform == "win32":
|
||||||
extra.extend(["user32", "gdi32"])
|
extra.extend(["user32", "gdi32"])
|
||||||
exts.append(
|
self._update_extension("PIL._imagingcms", [feature.lcms] + extra)
|
||||||
Extension(
|
else:
|
||||||
"PIL._imagingcms",
|
self._remove_extension("PIL._imagingcms")
|
||||||
["src/_imagingcms.c"],
|
|
||||||
libraries=[feature.lcms] + extra,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
if feature.webp:
|
if feature.webp:
|
||||||
libs = [feature.webp]
|
libs = [feature.webp]
|
||||||
|
@ -774,26 +775,12 @@ class pil_build_ext(build_ext):
|
||||||
libs.append(feature.webpmux)
|
libs.append(feature.webpmux)
|
||||||
libs.append(feature.webpmux.replace("pmux", "pdemux"))
|
libs.append(feature.webpmux.replace("pmux", "pdemux"))
|
||||||
|
|
||||||
exts.append(
|
self._update_extension("PIL._webp", libs, defs)
|
||||||
Extension(
|
else:
|
||||||
"PIL._webp", ["src/_webp.c"], libraries=libs, define_macros=defs
|
self._remove_extension("PIL._webp")
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
tk_libs = ["psapi"] if sys.platform == "win32" else []
|
tk_libs = ["psapi"] if sys.platform == "win32" else []
|
||||||
exts.append(
|
self._update_extension("PIL._imagingtk", tk_libs, include_dirs=["src/Tk"])
|
||||||
Extension(
|
|
||||||
"PIL._imagingtk",
|
|
||||||
["src/_imagingtk.c", "src/Tk/tkImaging.c"],
|
|
||||||
include_dirs=["src/Tk"],
|
|
||||||
libraries=tk_libs,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
exts.append(Extension("PIL._imagingmath", ["src/_imagingmath.c"]))
|
|
||||||
exts.append(Extension("PIL._imagingmorph", ["src/_imagingmorph.c"]))
|
|
||||||
|
|
||||||
self.extensions[:] = exts
|
|
||||||
|
|
||||||
build_ext.build_extensions(self)
|
build_ext.build_extensions(self)
|
||||||
|
|
||||||
|
@ -857,6 +844,20 @@ def debug_build():
|
||||||
return hasattr(sys, "gettotalrefcount")
|
return hasattr(sys, "gettotalrefcount")
|
||||||
|
|
||||||
|
|
||||||
|
files = ["src/_imaging.c"]
|
||||||
|
for src_file in _IMAGING:
|
||||||
|
files.append("src/" + src_file + ".c")
|
||||||
|
for src_file in _LIB_IMAGING:
|
||||||
|
files.append(os.path.join("src/libImaging", src_file + ".c"))
|
||||||
|
ext_modules = [
|
||||||
|
Extension("PIL._imaging", files),
|
||||||
|
Extension("PIL._imagingft", ["src/_imagingft.c"]),
|
||||||
|
Extension("PIL._imagingcms", ["src/_imagingcms.c"]),
|
||||||
|
Extension("PIL._webp", ["src/_webp.c"]),
|
||||||
|
Extension("PIL._imagingtk", ["src/_imagingtk.c", "src/Tk/tkImaging.c"]),
|
||||||
|
Extension("PIL._imagingmath", ["src/_imagingmath.c"]),
|
||||||
|
Extension("PIL._imagingmorph", ["src/_imagingmorph.c"]),
|
||||||
|
]
|
||||||
try:
|
try:
|
||||||
setup(
|
setup(
|
||||||
name=NAME,
|
name=NAME,
|
||||||
|
@ -891,7 +892,7 @@ try:
|
||||||
],
|
],
|
||||||
python_requires=">=3.6",
|
python_requires=">=3.6",
|
||||||
cmdclass={"build_ext": pil_build_ext},
|
cmdclass={"build_ext": pil_build_ext},
|
||||||
ext_modules=[Extension("PIL._imaging", ["_imaging.c"])],
|
ext_modules=ext_modules,
|
||||||
include_package_data=True,
|
include_package_data=True,
|
||||||
packages=["PIL"],
|
packages=["PIL"],
|
||||||
package_dir={"": "src"},
|
package_dir={"": "src"},
|
||||||
|
|
Loading…
Reference in New Issue
Block a user