Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add optional dependency on pyvips-binary #507

Merged
merged 2 commits into from
Oct 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
name: CI

on: [ push, pull_request ]
on: [push, pull_request]

jobs:
CI:
Expand Down
79 changes: 46 additions & 33 deletions README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -19,19 +19,19 @@ https://libvips.github.io/pyvips/

This module wraps the libvips image processing library:

https://libvips.github.io/libvips/
https://www.libvips.org/

The libvips docs are also very useful:

https://libvips.github.io/libvips/API/current/
https://www.libvips.org/API/current/

If you have the development headers for libvips installed and have a working C
compiler, this module will use cffi API mode to try to build a libvips
binary extension for your Python.
compiler, this module will use cffi API mode to try to build a libvips
binary extension for your Python.

If it is unable to build a binary extension, it will use cffi ABI mode
instead and only needs the libvips shared library. This takes longer to
start up and is typically ~20% slower in execution. You can find out if
start up and is typically ~20% slower in execution. You can find out if
API mode is being used with:

.. code-block:: python
Expand All @@ -41,7 +41,7 @@ API mode is being used with:
print(pyvips.API_mode)

This binding passes the vips test suite cleanly and with no leaks under
python3 and pypy3 on Windows, macOS and Linux.
python3 and pypy3 on Windows, macOS and Linux.

How it works
------------
Expand All @@ -53,31 +53,45 @@ pipeline executes at once, streaming the image in parallel from source to
destination a section at a time.

Because ``pyvips`` is parallel, it's quick, and because it doesn't need to
keep entire images in memory, it's light. For example, the libvips
keep entire images in memory, it's light. For example, the libvips
speed and memory use benchmark:

https://github.com/libvips/libvips/wiki/Speed-and-memory-use

Loads a large tiff image, shrinks by 10%, sharpens, and saves again. On this
test ``pyvips`` is typically 3x faster than ImageMagick and needs 5x less
memory.
memory.

There's a handy chapter in the docs explaining how libvips opens files,
which gives some more background.

http://libvips.github.io/libvips/API/current/How-it-opens-files.md.html
https://www.libvips.org/API/current/How-it-opens-files.html

Install
-------
Binary installation
-------------------

The quickest way to start with pyvips is by installing the binary package
with:

.. code-block:: shell

You need the libvips shared library on your library search path,
version 8.2 or later, though at least version 8.9 is required for all features
to work. See:
$ pip install "pyvips[binary]"

https://libvips.github.io/libvips/install.html
This installs a self-contained package with the most commonly needed
libraries. If your platform is unsupported or the pre-built binary is
unsuitable, you can install libvips globally instead.

Linux install
-------------
Local installation
------------------

You need the libvips shared library on your library search path, version 8.2
or later, though at least version 8.9 is required for all features to work.
See:

https://www.libvips.org/install.html

Linux
^^^^^

Perhaps:

Expand All @@ -94,22 +108,22 @@ With python 3.11 and later, you will need to create a venv first and add
$ python3 -m venv ~/.local
$ pip install pyvips

macOS install
-------------
macOS
^^^^^

With homebrew:
With Homebrew:

.. code-block:: shell

$ brew install vips python pkg-config
$ pip3 install pyvips

Windows install
---------------
Windows
^^^^^^^

on Windows you can download a pre-compiled binary from the libvips website.
On Windows, you can download a pre-compiled binary from the libvips website.

https://libvips.github.io/libvips/install.html
https://www.libvips.org/install.html

You'll need a 64-bit Python. The official one works well.

Expand All @@ -123,15 +137,15 @@ start of your program:
.. code-block:: python

import os
vipsbin = r'c:\vips-dev-8.13\bin'
vipsbin = r'c:\vips-dev-8.16\bin'
os.environ['PATH'] = vipsbin + ';' + os.environ['PATH']

For Python 3.8 and later, you need:

.. code-block:: python

import os
vipsbin = r'c:\vips-dev-8.13\bin'
vipsbin = r'c:\vips-dev-8.16\bin'
add_dll_dir = getattr(os, 'add_dll_directory', None)
if callable(add_dll_dir):
add_dll_dir(vipsbin)
Expand All @@ -140,10 +154,10 @@ For Python 3.8 and later, you need:

Now when you import pyvips, it should be able to find the DLLs.

conda install
-------------
Conda
^^^^^

The conda package includes a matching libvips binary, so just enter:
The Conda package includes a matching libvips binary, so just enter:

.. code-block:: shell

Expand Down Expand Up @@ -184,7 +198,7 @@ Run all tests:

.. code-block:: shell

$ tox
$ tox

Run test suite:

Expand Down Expand Up @@ -237,9 +251,9 @@ then
.. code-block:: shell

$ cd doc; \
python3 -c "import pyvips; pyvips.Operation.generate_sphinx_all()" > x
python3 -c "import pyvips; pyvips.Operation.generate_sphinx_all()" > x

And copy-paste ``x`` into the obvious place in ``doc/vimage.rst``.
And copy-paste ``x`` into the obvious place in ``doc/vimage.rst``.

Update version number:

Expand All @@ -256,4 +270,3 @@ Update pypi package:
$ twine upload --repository pyvips dist/*
$ git tag -a v2.2.0 -m "as uploaded to pypi"
$ git push origin v2.2.0

1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ exclude = [
]

[project.optional-dependencies]
binary = ["pyvips-binary"]
# All the following are used for our own testing
tox = ["tox"]
test = [
Expand Down