mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-28 18:24:57 +03:00
Merge pull request #2746 from wiredfool/msys2
Changes to cleanly compile on windows/msys2
This commit is contained in:
commit
2479019241
40
appveyor.yml
40
appveyor.yml
|
@ -10,6 +10,8 @@ environment:
|
||||||
EXECUTABLE: python.exe
|
EXECUTABLE: python.exe
|
||||||
PIP_DIR: Scripts
|
PIP_DIR: Scripts
|
||||||
VENV: NO
|
VENV: NO
|
||||||
|
TEST_OPTIONS:
|
||||||
|
DEPLOY: YES
|
||||||
matrix:
|
matrix:
|
||||||
- PYTHON: C:/vp/pypy2
|
- PYTHON: C:/vp/pypy2
|
||||||
EXECUTABLE: bin/pypy.exe
|
EXECUTABLE: bin/pypy.exe
|
||||||
|
@ -21,6 +23,11 @@ environment:
|
||||||
- PYTHON: C:/Python34-x64
|
- PYTHON: C:/Python34-x64
|
||||||
- PYTHON: C:/Python33
|
- PYTHON: C:/Python33
|
||||||
- PYTHON: C:/Python33-x64
|
- PYTHON: C:/Python33-x64
|
||||||
|
- PYTHON: C:/msys64/mingw32
|
||||||
|
EXECUTABLE: bin/python3
|
||||||
|
PIP_DIR: bin
|
||||||
|
TEST_OPTIONS: --processes=0
|
||||||
|
DEPLOY: NO
|
||||||
|
|
||||||
|
|
||||||
install:
|
install:
|
||||||
|
@ -36,19 +43,38 @@ install:
|
||||||
{
|
{
|
||||||
c:\pillow\winbuild\appveyor_install_pypy.cmd
|
c:\pillow\winbuild\appveyor_install_pypy.cmd
|
||||||
}
|
}
|
||||||
- c:\python34\python.exe c:\pillow\winbuild\build_dep.py
|
- ps: |
|
||||||
- c:\pillow\winbuild\build_deps.cmd
|
if ($env:PYTHON -eq "c:/msys64/mingw32")
|
||||||
|
{
|
||||||
|
c:\msys64\usr\bin\bash -l -c c:\\pillow\\winbuild\\appveyor_install_msys2_deps.sh
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
c:\python34\python.exe c:\pillow\winbuild\build_dep.py
|
||||||
|
c:\pillow\winbuild\build_deps.cmd
|
||||||
|
$host.SetShouldExit(0)
|
||||||
|
}
|
||||||
|
|
||||||
build_script:
|
build_script:
|
||||||
- '%PYTHON%\%EXECUTABLE% c:\pillow\winbuild\build.py'
|
- ps: |
|
||||||
|
if ($env:PYTHON -eq "c:/msys64/mingw32")
|
||||||
|
{
|
||||||
|
c:\msys64\usr\bin\bash -l -c c:\\pillow\\winbuild\\appveyor_build_msys2.sh
|
||||||
|
Write-Host "through install"
|
||||||
|
$host.SetShouldExit(0)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
& $env:PYTHON/$env:EXECUTABLE c:\pillow\winbuild\build.py
|
||||||
|
$host.SetShouldExit(0)
|
||||||
|
}
|
||||||
- cd c:\pillow
|
- cd c:\pillow
|
||||||
- dir dist\*.egg
|
|
||||||
- '%PYTHON%\%EXECUTABLE% selftest.py --installed'
|
- '%PYTHON%\%EXECUTABLE% selftest.py --installed'
|
||||||
|
|
||||||
test_script:
|
test_script:
|
||||||
- cd c:\pillow
|
- cd c:\pillow
|
||||||
- '%PYTHON%\%PIP_DIR%\pip.exe install nose'
|
- '%PYTHON%\%PIP_DIR%\pip.exe install nose'
|
||||||
- '%PYTHON%\%EXECUTABLE% test-installed.py -v -s'
|
- '%PYTHON%\%EXECUTABLE% test-installed.py -v -s %TEST_OPTIONS%'
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
fast_finish: true
|
fast_finish: true
|
||||||
|
@ -59,7 +85,7 @@ artifacts:
|
||||||
- path: pillow\dist\*.wheel
|
- path: pillow\dist\*.wheel
|
||||||
name: wheel
|
name: wheel
|
||||||
|
|
||||||
after_test:
|
before_deploy:
|
||||||
- '%PYTHON%\%PIP_DIR%\pip.exe install wheel'
|
- '%PYTHON%\%PIP_DIR%\pip.exe install wheel'
|
||||||
- cd c:\pillow\winbuild\
|
- cd c:\pillow\winbuild\
|
||||||
- '%PYTHON%\%EXECUTABLE% c:\pillow\winbuild\build.py --wheel'
|
- '%PYTHON%\%EXECUTABLE% c:\pillow\winbuild\build.py --wheel'
|
||||||
|
@ -77,6 +103,8 @@ deploy:
|
||||||
artifact: /.*egg|wheel/
|
artifact: /.*egg|wheel/
|
||||||
on:
|
on:
|
||||||
branch: master
|
branch: master
|
||||||
|
deploy: YES
|
||||||
|
|
||||||
|
|
||||||
# Uncomment the following line to get RDP access after the build/test and block for
|
# Uncomment the following line to get RDP access after the build/test and block for
|
||||||
# up to the timeout limit (~1hr)
|
# up to the timeout limit (~1hr)
|
||||||
|
|
9
setup.py
9
setup.py
|
@ -17,7 +17,7 @@ import sys
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
from distutils.command.build_ext import build_ext
|
from distutils.command.build_ext import build_ext
|
||||||
from distutils import sysconfig
|
from distutils import sysconfig, ccompiler
|
||||||
from setuptools import Extension, setup, find_packages
|
from setuptools import Extension, setup, find_packages
|
||||||
|
|
||||||
# monkey patch import hook. Even though flake8 says it's not used, it is.
|
# monkey patch import hook. Even though flake8 says it's not used, it is.
|
||||||
|
@ -44,6 +44,9 @@ DEBUG = False
|
||||||
class DependencyException(Exception): pass
|
class DependencyException(Exception): pass
|
||||||
class RequiredDependencyException(Exception): pass
|
class RequiredDependencyException(Exception): pass
|
||||||
|
|
||||||
|
PLATFORM_MINGW = 'mingw' in ccompiler.get_default_compiler()
|
||||||
|
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:
|
||||||
|
@ -607,7 +610,7 @@ class pil_build_ext(build_ext):
|
||||||
if struct.unpack("h", "\0\1".encode('ascii'))[0] == 1:
|
if struct.unpack("h", "\0\1".encode('ascii'))[0] == 1:
|
||||||
defs.append(("WORDS_BIGENDIAN", None))
|
defs.append(("WORDS_BIGENDIAN", None))
|
||||||
|
|
||||||
if sys.platform == "win32" and not hasattr(sys, 'pypy_version_info'):
|
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))
|
||||||
|
@ -781,7 +784,7 @@ try:
|
||||||
test_suite='nose.collector',
|
test_suite='nose.collector',
|
||||||
keywords=["Imaging", ],
|
keywords=["Imaging", ],
|
||||||
license='Standard PIL License',
|
license='Standard PIL License',
|
||||||
zip_safe=not debug_build(), )
|
zip_safe=not (debug_build() or PLATFORM_MINGW), )
|
||||||
except RequiredDependencyException as err:
|
except RequiredDependencyException as err:
|
||||||
msg = """
|
msg = """
|
||||||
|
|
||||||
|
|
3
winbuild/appveyor_build_msys2.sh
Normal file
3
winbuild/appveyor_build_msys2.sh
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
cd /c/pillow && /mingw32/$EXECUTABLE setup.py install
|
11
winbuild/appveyor_install_msys2_deps.sh
Normal file
11
winbuild/appveyor_install_msys2_deps.sh
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
pacman -S --noconfirm mingw32/mingw-w64-i686-python3 \
|
||||||
|
mingw32/mingw-w64-i686-python3-pip \
|
||||||
|
mingw32/mingw-w64-i686-python3-setuptools \
|
||||||
|
mingw32/mingw-w64-i686-python2-pip \
|
||||||
|
mingw32/mingw-w64-i686-python2-setuptools \
|
||||||
|
mingw-w64-i686-libjpeg-turbo
|
||||||
|
|
||||||
|
/mingw32/bin/pip install nose olefile
|
||||||
|
/mingw32/bin/pip3 install nose olefile
|
Loading…
Reference in New Issue
Block a user