mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-26 01:04:29 +03:00
Only search for Ghostscript Windows binary when needed
This commit is contained in:
parent
e1889544cd
commit
f225130ee5
|
@ -38,7 +38,14 @@ split = re.compile(r"^%%([^:]*):[ \t]*(.*)[ \t]*$")
|
|||
field = re.compile(r"^%[%!\w]([^:]*)[ \t]*$")
|
||||
|
||||
gs_windows_binary = None
|
||||
if sys.platform.startswith("win"):
|
||||
|
||||
|
||||
def _get_windows_binary():
|
||||
global gs_windows_binary
|
||||
if gs_windows_binary is not None:
|
||||
return gs_windows_binary
|
||||
if not sys.platform.startswith("win"):
|
||||
return
|
||||
import shutil
|
||||
|
||||
for binary in ("gswin32c", "gswin64c", "gs"):
|
||||
|
@ -47,18 +54,18 @@ if sys.platform.startswith("win"):
|
|||
break
|
||||
else:
|
||||
gs_windows_binary = False
|
||||
return gs_windows_binary
|
||||
|
||||
|
||||
def has_ghostscript():
|
||||
if gs_windows_binary:
|
||||
return True
|
||||
if not sys.platform.startswith("win"):
|
||||
gs_windows_binary = _get_windows_binary()
|
||||
if gs_windows_binary is not None:
|
||||
return gs_windows_binary is not False
|
||||
try:
|
||||
subprocess.check_call(["gs", "--version"], stdout=subprocess.DEVNULL)
|
||||
return True
|
||||
except OSError:
|
||||
# No Ghostscript
|
||||
pass
|
||||
return False
|
||||
|
||||
|
||||
|
@ -132,8 +139,8 @@ def Ghostscript(tile, size, fp, scale=1, transparency=False):
|
|||
"showpage",
|
||||
]
|
||||
|
||||
if gs_windows_binary is not None:
|
||||
if not gs_windows_binary:
|
||||
gs_windows_binary = _get_windows_binary()
|
||||
if gs_windows_binary is False:
|
||||
try:
|
||||
os.unlink(outfile)
|
||||
if infile_temp:
|
||||
|
@ -143,6 +150,7 @@ def Ghostscript(tile, size, fp, scale=1, transparency=False):
|
|||
|
||||
msg = "Unable to locate Ghostscript on paths"
|
||||
raise OSError(msg)
|
||||
elif gs_windows_binary is not None:
|
||||
command[0] = gs_windows_binary
|
||||
|
||||
# push data through Ghostscript
|
||||
|
|
Loading…
Reference in New Issue
Block a user