[Buildroot] [PATCH 2/2] package/python-pymupdf: new package.

Arnout Vandecappelle arnout at mind.be
Wed May 26 20:10:42 UTC 2021


 Applied to next, again with changes.

On 07/02/2020 10:37, Raphaël Mélotte wrote:
> Python bindings for the PDF rendering library MuPDF.
> 
> Signed-off-by: Raphaël Mélotte <raphael.melotte at mind.be>
> Signed-off-by: Raphaël Mélotte <raphael.melotte at essensium.com>
> ---
>  DEVELOPERS                                 |  1 +
>  package/Config.in                          |  1 +
>  package/python-pymupdf/Config.in           | 12 +++++++++++
>  package/python-pymupdf/python-pymupdf.hash |  3 +++
>  package/python-pymupdf/python-pymupdf.mk   | 25 ++++++++++++++++++++++
>  5 files changed, 42 insertions(+)
>  create mode 100644 package/python-pymupdf/Config.in
>  create mode 100644 package/python-pymupdf/python-pymupdf.hash
>  create mode 100644 package/python-pymupdf/python-pymupdf.mk
> 
> diff --git a/DEVELOPERS b/DEVELOPERS
> index 9c527c3625..0c67165f4a 100644
> --- a/DEVELOPERS
> +++ b/DEVELOPERS
> @@ -1931,6 +1931,7 @@ F:	package/paho-mqtt-cpp/
>  N:	Raphaël Mélotte <raphael.melotte at essensium.com>
>  F:	package/jbig2dec/
>  F:	package/mupdf/
> +F:  package/python-pymupdf/

 This should have been a tab.


>  N:	Rémi Rérolle <remi.rerolle at gmail.com>
>  F:	package/libfreeimage/
> diff --git a/package/Config.in b/package/Config.in
> index df29673221..ffe1013e82 100644
> --- a/package/Config.in
> +++ b/package/Config.in
> @@ -1013,6 +1013,7 @@ menu "External python modules"
>  	source "package/python-pylibftdi/Config.in"
>  	source "package/python-pylru/Config.in"
>  	source "package/python-pymodbus/Config.in"
> +	source "package/python-pymupdf/Config.in"
>  	source "package/python-pymysql/Config.in"
>  	source "package/python-pynacl/Config.in"
>  	source "package/python-pyopenssl/Config.in"
> diff --git a/package/python-pymupdf/Config.in b/package/python-pymupdf/Config.in
> new file mode 100644
> index 0000000000..2d95423e95
> --- /dev/null
> +++ b/package/python-pymupdf/Config.in
> @@ -0,0 +1,12 @@
> +config BR2_PACKAGE_PYTHON_PYMUPDF
> +	bool "python-pymupdf"
> +	depends on BR2_PACKAGE_XORG7

 Again, harfbuzz dependencies need to be propagated.

> +	select BR2_PACKAGE_MUPDF
> +	select BR2_PACKAGE_ZLIB
> +	help
> +	  Python bindings for the PDF rendering library MuPDF.
> +
> +	  https://github.com/pymupdf/PyMuPDF
> +
> +comment "python-pymupdf needs Xorg"
> +	depends on !BR2_PACKAGE_XORG7
> diff --git a/package/python-pymupdf/python-pymupdf.hash b/package/python-pymupdf/python-pymupdf.hash
> new file mode 100644
> index 0000000000..6729c6b91b
> --- /dev/null
> +++ b/package/python-pymupdf/python-pymupdf.hash
> @@ -0,0 +1,3 @@
> +# md5, sha256 from https://pypi.org/pypi/pymupdf/json
> +md5	0e924bbb7364ba63df65d33fee9656f0  PyMuPDF-1.16.0.tar.gz
> +sha256	1a6cc5b8b0fb9aa16bfa453fdfed445398f00d2556e78d90ba54cdce8d900857  python-pymupdf-1.16.0.tar.gz
> diff --git a/package/python-pymupdf/python-pymupdf.mk b/package/python-pymupdf/python-pymupdf.mk
> new file mode 100644
> index 0000000000..e0f03dc2cf
> --- /dev/null
> +++ b/package/python-pymupdf/python-pymupdf.mk
> @@ -0,0 +1,25 @@
> +################################################################################
> +#
> +# python-pymupdf
> +#
> +################################################################################
> +
> +PYTHON_PYMUPDF_VERSION = 1.16.0
> +# python-pymupdf's version must match exactly mupdf's version

 I've added a similar comment to mupdf itself.

> +PYTHON_PYMUPDF_SOURCE = PyMuPDF-$(PYTHON_PYMUPDF_VERSION).tar.gz
> +PYTHON_PYMUPDF_SITE = https://files.pythonhosted.org/packages/d2/da/692102b6e6868a57d1dc7f98d07413116a02493b3b49a798dcd6f676d368
> +PYTHON_PYMUPDF_SETUP_TYPE = distutils
> +PYTHON_PYMUPDF_LICENSE = GPL-3.0

 Actually, it's also AGPL-3.0+, because the swig-generated files are under the
mupdf license as well. This is explained in the README on github.

 I also added a comment about the lack of license files.

> +PYTHON_PYMUPDF_DEPENDENCIES = mupdf zlib
> +
> +PYTHON_PYMUPDF_ENV = CFLAGS="-I$(STAGING_DIR)/usr/include/mupdf"
> +
> +# We need to remove the original paths as we provide them in the CFLAGS:
> +define PYTHON_PYMUPDF_REMOVE_PATHS
> +	sed -i "s:\/usr\/include\/mupdf::g" $(@D)/setup.py
> +	sed -i "s:\/usr\/local\/include\/mupdf::g" $(@D)/setup.py
> +endef
> +
> +PYTHON_PYMUPDF_POST_PATCH_HOOKS = PYTHON_PYMUPDF_REMOVE_PATHS

 See, you *knew* that it had to be post-patch :-)

 Regards,
 Arnout

> +
> +$(eval $(python-package))
> 


More information about the buildroot mailing list