Building Pillow on Windows ========================== .. note:: For most people, the `installation instructions <../docs/installation.rst#windows-installation>`_ should be sufficient. This page will describe a build setup to build Pillow against the supported Python versions in 32 and 64-bit modes, using freely available Microsoft compilers. This has been developed and tested against 64-bit Windows 7 Professional and Windows Server 2012 64-bit version on Amazon EC2. Prerequisites ------------- Extra Build Helpers ^^^^^^^^^^^^^^^^^^^ * Powershell (available by default on Windows Server) * GitHub client (provides git+bash shell) Optional: * GPG (for checking signatures) (UNDONE -- Python signature checking) Pythons ^^^^^^^ The build routines expect Python to be installed at C:\PythonXX for 32-bit versions or C:\PythonXXx64 for the 64-bit versions. Download Python 3.4, install it, and add it to the path. This is the Python that we will use to bootstrap the build process. (The download routines are using 3 features, and installing 3.4 gives us pip and virtualenv as well, reducing the number of packages that we need to install.) Download the rest of the Pythons by opening a command window, changing to the ``winbuild`` directory, and running ``python get_pythons.py``. UNDONE -- gpg verify the signatures (note that we can download from https) Run each installer and set the proper path to the installation. Don't set any of them as the default Python, or add them to the path. Compilers ^^^^^^^^^ Download and install: * `Microsoft Windows SDK for Windows 7 and .NET Framework 4 <https://www.microsoft.com/en-us/download/details.aspx?id=8279>`_ * `CMake-2.8.10.2-win32-x86.exe <https://cmake.org/files/v2.8/cmake-2.8.10.2-win32-x86.exe>`_ The samples and the .NET SDK portions aren't required, just the compilers and other tools. UNDONE -- check exact wording. Dependencies ------------ The script 'build_dep.py' downloads and builds the dependencies. Open a command window, change directory into ``winbuild`` and run ``python build_dep.py``. This will download libjpeg, libtiff, libz, and freetype. It will then compile 32 and 64-bit versions of the libraries, with both versions of the compilers. UNDONE -- lcms fails. UNDONE -- webp, jpeg2k not recognized Building Pillow --------------- Once the dependencies are built, run ``python build.py --clean`` to build and install Pillow in virtualenvs for each Python build. ``build.py --wheel`` will build wheels instead of installing into virtualenvs. UNDONE -- suppressed output, what about failures. Testing Pillow -------------- Build and install Pillow, then run ``python test.py`` from the ``winbuild`` directory.