commit: fb56f481312f68d350b560c7e01b7150b66b3dba Author: Philipp Rösner <rndxelement <AT> protonmail <DOT> com> AuthorDate: Sun Jan 11 14:14:46 2026 +0000 Commit: Sam James <sam <AT> gentoo <DOT> org> CommitDate: Sat Feb 28 14:21:16 2026 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fb56f481
app-text/mupdf: add 1.27.2 - Remove thirdparty patch because it is fixed upstream - Update patches (and improve descriptions) - Tested building all possible use combinations via pkg-testing-tool - Runtime tested with a sample PDF file - Build and runtime tested reverse dependency app-text/zathura-pdf-mupdf-0.4.4 Signed-off-by: Philipp Rösner <rndxelement <AT> protonmail.com> Part-of: https://github.com/gentoo/gentoo/pull/45334 Signed-off-by: Sam James <sam <AT> gentoo.org> app-text/mupdf/Manifest | 1 + app-text/mupdf/files/mupdf-1.27.2-Makefile.patch | 32 ++++ .../mupdf/files/mupdf-1.27.2-cross-fixes.patch | 182 ++++++++++++++++++++ app-text/mupdf/files/mupdf-1.27.2-jpx.patch | 30 ++++ .../mupdf/files/mupdf-1.27.2-openssl-x11.patch | 24 +++ app-text/mupdf/mupdf-1.27.2.ebuild | 184 +++++++++++++++++++++ 6 files changed, 453 insertions(+) diff --git a/app-text/mupdf/Manifest b/app-text/mupdf/Manifest index b174b8ce496d..507899636942 100644 --- a/app-text/mupdf/Manifest +++ b/app-text/mupdf/Manifest @@ -1,3 +1,4 @@ DIST mupdf-1.25.2-source.tar.gz 54635699 BLAKE2B 08e4c1bd4d8f9a731b10e1368c3f4a62a9b949c4a1842f2ce297ef3a595107f63e184230c31149a6a5db9038838d891fdeb0330323afcdc0b6966bee06046288 SHA512 089bcf228a28e5f47e793d66f6355b22b531c031a6d1feb0dd07a5fee55780fda92d6cde646336ca0200869c32d523be23a8fe2232fad010b38673419c7859f2 DIST mupdf-1.25.6-source.tar.gz 54637444 BLAKE2B f9fb771e96938c2862e10aa7482f52218cf5d159e77300016b64f2f10424d72e6ea13566abf8180eb2a31644d711755f93edc69189230d50a543408105881b55 SHA512 74aa127f7d7e91c8a51c04e130d113e0fcf444a09a8e96420bd66847b20a4fb92fad9e95376f3a7d9a91b3391ef4b44e5fb6a0bee38476d4ecf9e5ae34d9ed74 DIST mupdf-1.26.3-source.tar.gz 64525703 BLAKE2B 81272e198394e48872d31d982f9a89c0fe2ab065343569e18a696c06c660e8f7b113acca96cd34894a0d601761bf426af7b57ff45dc029167d6483eda88af885 SHA512 242b02e90e1e758cf8d6ffc34f6799011a1d599689cc2ae9330c14968769347e1e4201775258248e5cbb80fb7cffd690e938f73f202713752b5320ef8186c176 +DIST mupdf-1.27.2-source.tar.gz 66968384 BLAKE2B 93c49059ee1ba9e4f3f3548178ea5d997f9b2ce82b801870e15defe42ee4a7c448edf69fedac3d8ced4833a07f7cd8b7fe5858165690a99126b8612a9d1e7844 SHA512 68c92007aac775d22dca151a7ae2d4e77755dbc0c8a6faeec8048aa3537de4e1b5a98d999e090460298f294d7aed62e3aa144817d78655435d9498b159ccd0dc diff --git a/app-text/mupdf/files/mupdf-1.27.2-Makefile.patch b/app-text/mupdf/files/mupdf-1.27.2-Makefile.patch new file mode 100644 index 000000000000..d56ec3e0b25c --- /dev/null +++ b/app-text/mupdf/files/mupdf-1.27.2-Makefile.patch @@ -0,0 +1,32 @@ +diff --git a/Makefile b/Makefile +index 811ade9..d57a631 100644 +--- a/Makefile ++++ b/Makefile +@@ -342,13 +342,12 @@ ifeq ($(shared),yes) + endif + endif + else +- MUPDF_LIB = $(OUT)/libmupdf.a +- ifneq ($(THIRD_OBJ),) +- # omit libmupdf-third if there is nothing in it +- THIRD_LIB = $(OUT)/libmupdf-third.a +- endif +- $(MUPDF_LIB) : $(MUPDF_OBJ) +- $(THIRD_LIB) : $(THIRD_OBJ) ++ MUPDF_LIB = libmupdf.so.$(GENTOO_PV) ++ THIRD_LIB = ++ MUPDF_STATIC = $(OUT)/libmupdf.a ++ $(MUPDF_LIB) : $(MUPDF_OBJ) $(THIRD_OBJ) ++ $(QUIET_LINK) $(CC) $(LDFLAGS) --shared -Wl,-soname -Wl,$(MUPDF_LIB) -o $@ $^ $(THIRD_LIBS) $(LIBS) ++ $(MUPDF_STATIC): $(MUPDF_OBJ) $(THIRD_OBJ) + endif + + ifneq ($(USE_SYSTEM_GLUT),yes) +@@ -496,7 +495,6 @@ ifeq ($(shared),yes) + endif + else + install -m 644 $(MUPDF_LIB) $(DESTDIR)$(libdir) +- install -m 644 $(THIRD_LIB) $(DESTDIR)$(libdir) + endif + + install-tools: tools diff --git a/app-text/mupdf/files/mupdf-1.27.2-cross-fixes.patch b/app-text/mupdf/files/mupdf-1.27.2-cross-fixes.patch new file mode 100644 index 000000000000..a24f198863d1 --- /dev/null +++ b/app-text/mupdf/files/mupdf-1.27.2-cross-fixes.patch @@ -0,0 +1,182 @@ +diff --git a/Makerules b/Makerules +index 985b096..9fe5bca 100644 +--- a/Makerules ++++ b/Makerules +@@ -14,6 +14,8 @@ ifeq ($(OS),) + OS := $(shell uname) + endif + ++PKG_CONFIG ?= $(PKG_CONFIG) ++CC_FOR_BUILD ?= $(CC) + WARNING_CFLAGS := -Wall -Wsign-compare + + # Feature configuration options +@@ -231,13 +233,13 @@ ifeq ($(OS),Darwin) + ifneq ($(ARCHFLAGS),) + $(warning "MacOS with ARCHFLAGS set. Assuming we are building for arm64, and setting HAVE_LIBCRYPTO to no.") + HAVE_LIBCRYPTO := no +- else ifeq (, $(shell command -v pkg-config)) +- $(warning "No pkg-config found, install it for proper integration of libcrypto") ++ else ifeq (, $(shell command -v $(PKG_CONFIG))) ++ $(warning "No $(PKG_CONFIG) found, install it for proper integration of libcrypto") + else +- HAVE_LIBCRYPTO := $(shell pkg-config --exists 'libcrypto >= 1.1.0' && echo yes) ++ HAVE_LIBCRYPTO := $(shell $(PKG_CONFIG) --exists 'libcrypto >= 1.1.0' && echo yes) + ifeq ($(HAVE_LIBCRYPTO),yes) +- LIBCRYPTO_CFLAGS := $(shell pkg-config --cflags libcrypto) -DHAVE_LIBCRYPTO +- LIBCRYPTO_LIBS := $(shell pkg-config --libs libcrypto) ++ LIBCRYPTO_CFLAGS := $(shell $(PKG_CONFIG) --cflags libcrypto) -DHAVE_LIBCRYPTO ++ LIBCRYPTO_LIBS := $(shell $(PKG_CONFIG) --libs libcrypto) + endif + endif + +@@ -251,78 +253,78 @@ else + LDFLAGS += -pthread + endif + +- ifeq ($(shell pkg-config --exists 'freetype2 >= 18.3.12' && echo yes),yes) +- SYS_FREETYPE_CFLAGS := $(shell pkg-config --cflags freetype2) +- SYS_FREETYPE_LIBS := $(shell pkg-config --libs freetype2) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'freetype2 >= 18.3.12' && echo yes),yes) ++ SYS_FREETYPE_CFLAGS := $(shell $(PKG_CONFIG) --cflags freetype2) ++ SYS_FREETYPE_LIBS := $(shell $(PKG_CONFIG) --libs freetype2) + endif +- ifeq ($(shell pkg-config --exists 'gumbo >= 0.10.0' && echo yes),yes) +- SYS_GUMBO_CFLAGS := $(shell pkg-config --cflags gumbo) +- SYS_GUMBO_LIBS := $(shell pkg-config --libs gumbo) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'gumbo >= 0.10.0' && echo yes),yes) ++ SYS_GUMBO_CFLAGS := $(shell $(PKG_CONFIG) --cflags gumbo) ++ SYS_GUMBO_LIBS := $(shell $(PKG_CONFIG) --libs gumbo) + endif +- ifeq ($(shell pkg-config --exists 'harfbuzz >= 2.0.0' && echo yes),yes) +- SYS_HARFBUZZ_CFLAGS := $(shell pkg-config --cflags harfbuzz) +- SYS_HARFBUZZ_LIBS := $(shell pkg-config --libs harfbuzz) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'harfbuzz >= 2.0.0' && echo yes),yes) ++ SYS_HARFBUZZ_CFLAGS := $(shell $(PKG_CONFIG) --cflags harfbuzz) ++ SYS_HARFBUZZ_LIBS := $(shell $(PKG_CONFIG) --libs harfbuzz) + endif +- ifeq ($(shell pkg-config --exists lcms2 && echo yes),yes) +- SYS_LCMS2_CFLAGS := $(shell pkg-config --cflags lcms2) +- SYS_LCMS2_LIBS := $(shell pkg-config --libs lcms2) ++ ifeq ($(shell $(PKG_CONFIG) --exists lcms2 && echo yes),yes) ++ SYS_LCMS2_CFLAGS := $(shell $(PKG_CONFIG) --cflags lcms2) ++ SYS_LCMS2_LIBS := $(shell $(PKG_CONFIG) --libs lcms2) + endif +- ifeq ($(shell pkg-config --exists libjpeg && echo yes),yes) +- SYS_LIBJPEG_CFLAGS := $(shell pkg-config --cflags libjpeg) +- SYS_LIBJPEG_LIBS := $(shell pkg-config --libs libjpeg) ++ ifeq ($(shell $(PKG_CONFIG) --exists libjpeg && echo yes),yes) ++ SYS_LIBJPEG_CFLAGS := $(shell $(PKG_CONFIG) --cflags libjpeg) ++ SYS_LIBJPEG_LIBS := $(shell $(PKG_CONFIG) --libs libjpeg) + endif +- ifeq ($(shell pkg-config --exists 'libopenjp2 >= 2.1.0' && echo yes),yes) +- SYS_OPENJPEG_CFLAGS := $(shell pkg-config --cflags libopenjp2) +- SYS_OPENJPEG_LIBS := $(shell pkg-config --libs libopenjp2) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'libopenjp2 >= 2.1.0' && echo yes),yes) ++ SYS_OPENJPEG_CFLAGS := $(shell $(PKG_CONFIG) --cflags libopenjp2) ++ SYS_OPENJPEG_LIBS := $(shell $(PKG_CONFIG) --libs libopenjp2) + endif +- ifeq ($(shell pkg-config --exists 'zlib >= 1.2.6' && echo yes),yes) +- SYS_ZLIB_CFLAGS := $(shell pkg-config --cflags zlib) +- SYS_ZLIB_LIBS := $(shell pkg-config --libs zlib) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'zlib >= 1.2.6' && echo yes),yes) ++ SYS_ZLIB_CFLAGS := $(shell $(PKG_CONFIG) --cflags zlib) ++ SYS_ZLIB_LIBS := $(shell $(PKG_CONFIG) --libs zlib) + endif +- ifeq ($(shell pkg-config --exists 'libbrotlidec libbrotlienc >= 0.6.0' && echo yes),yes) +- SYS_BROTLI_CFLAGS := $(shell pkg-config --cflags libbrotlidec libbrotlienc) +- SYS_BROTLI_LIBS := $(shell pkg-config --libs libbrotlidec libbrotlienc) ++ ifeq ($(shell $(PKG_CONFIG) --exists 'libbrotlidec libbrotlienc >= 0.6.0' && echo yes),yes) ++ SYS_BROTLI_CFLAGS := $(shell $(PKG_CONFIG) --cflags libbrotlidec libbrotlienc) ++ SYS_BROTLI_LIBS := $(shell $(PKG_CONFIG) --libs libbrotlidec libbrotlienc) + endif + +- HAVE_SYS_LEPTONICA := $(shell pkg-config --exists 'lept >= 1.7.4' && echo yes) ++ HAVE_SYS_LEPTONICA := $(shell $(PKG_CONFIG) --exists 'lept >= 1.7.4' && echo yes) + ifeq ($(HAVE_SYS_LEPTONICA),yes) +- SYS_LEPTONICA_CFLAGS := $(shell pkg-config --cflags lept) +- SYS_LEPTONICA_LIBS := $(shell pkg-config --libs lept) ++ SYS_LEPTONICA_CFLAGS := $(shell $(PKG_CONFIG) --cflags lept) ++ SYS_LEPTONICA_LIBS := $(shell $(PKG_CONFIG) --libs lept) + endif + +- HAVE_SYS_TESSERACT := $(shell pkg-config --exists 'tesseract >= 4.0.0' && echo yes) ++ HAVE_SYS_TESSERACT := $(shell $(PKG_CONFIG) --exists 'tesseract >= 4.0.0' && echo yes) + ifeq ($(HAVE_SYS_TESSERACT),yes) +- SYS_TESSERACT_CFLAGS := $(shell pkg-config --cflags tesseract) +- SYS_TESSERACT_LIBS := $(shell pkg-config --libs tesseract) ++ SYS_TESSERACT_CFLAGS := $(shell $(PKG_CONFIG) --cflags tesseract) ++ SYS_TESSERACT_LIBS := $(shell $(PKG_CONFIG) --libs tesseract) + endif + +- HAVE_SYS_LIBARCHIVE := $(shell pkg-config --exists 'libarchive' && echo yes) ++ HAVE_SYS_LIBARCHIVE := $(shell $(PKG_CONFIG) --exists 'libarchive' && echo yes) + ifeq ($(HAVE_SYS_LIBARCHIVE),yes) +- SYS_LIBARCHIVE_CFLAGS := $(shell pkg-config --cflags libarchive) +- SYS_LIBARCHIVE_LIBS := $(shell pkg-config --libs libarchive) ++ SYS_LIBARCHIVE_CFLAGS := $(shell $(PKG_CONFIG) --cflags libarchive) ++ SYS_LIBARCHIVE_LIBS := $(shell $(PKG_CONFIG) --libs libarchive) + endif + +- HAVE_SYS_ZXINGCPP := $(shell pkg-config --exists 'zxing >= 2.0.0' && echo yes) ++ HAVE_SYS_ZXINGCPP := $(shell $(PKG_CONFIG) --exists 'zxing >= 2.0.0' && echo yes) + ifeq ($(HAVE_SYS_ZXINGCPP),yes) +- SYS_ZXINGCPP_CFLAGS := $(shell pkg-config --cflags zxing) +- SYS_ZXINGCPP_LIBS := $(shell pkg-config --libs zxing) ++ SYS_ZXINGCPP_CFLAGS := $(shell $(PKG_CONFIG) --cflags zxing) ++ SYS_ZXINGCPP_LIBS := $(shell $(PKG_CONFIG) --libs zxing) + endif + +- HAVE_SYS_CURL := $(shell pkg-config --exists libcurl && echo yes) ++ HAVE_SYS_CURL := $(shell $(PKG_CONFIG) --exists libcurl && echo yes) + ifeq ($(HAVE_SYS_CURL),yes) +- SYS_CURL_CFLAGS := $(shell pkg-config --cflags libcurl) +- SYS_CURL_LIBS := $(shell pkg-config --libs libcurl) ++ SYS_CURL_CFLAGS := $(shell $(PKG_CONFIG) --cflags libcurl) ++ SYS_CURL_LIBS := $(shell $(PKG_CONFIG) --libs libcurl) + endif + + ifeq ($(HAVE_GLUT),) +- HAVE_GLUT := $(shell pkg-config --exists gl x11 xrandr && echo yes) ++ HAVE_GLUT := $(shell $(PKG_CONFIG) --exists gl x11 xrandr && echo yes) + endif + ifeq ($(HAVE_GLUT),yes) +- SYS_GL_CFLAGS := $(shell pkg-config --cflags gl x11 xrandr) +- SYS_GL_LIBS := $(shell pkg-config --libs gl x11 xrandr) +- ifeq ($(shell pkg-config --exists glut && echo yes),yes) +- SYS_GLUT_CFLAGS := $(shell pkg-config --cflags glut) +- SYS_GLUT_LIBS := $(shell pkg-config --libs glut) ++ SYS_GL_CFLAGS := $(shell $(PKG_CONFIG) --cflags gl x11 xrandr) ++ SYS_GL_LIBS := $(shell $(PKG_CONFIG) --libs gl x11 xrandr) ++ ifeq ($(shell $(PKG_CONFIG) --exists glut && echo yes),yes) ++ SYS_GLUT_CFLAGS := $(shell $(PKG_CONFIG) --cflags glut) ++ SYS_GLUT_LIBS := $(shell $(PKG_CONFIG) --libs glut) + else + SYS_GLUT_CFLAGS := + SYS_GLUT_LIBS := -lglut +@@ -330,19 +332,19 @@ else + endif + + ifeq ($(HAVE_X11),) +- HAVE_X11 := $(shell pkg-config --exists x11 xext && echo yes) ++ HAVE_X11 := $(shell $(PKG_CONFIG) --exists x11 xext && echo yes) + endif + ifeq ($(HAVE_X11),yes) +- X11_CFLAGS := $(shell pkg-config --cflags x11 xext) +- X11_LIBS := $(shell pkg-config --libs x11 xext) ++ X11_CFLAGS := $(shell $(PKG_CONFIG) --cflags x11 xext) ++ X11_LIBS := $(shell $(PKG_CONFIG) --libs x11 xext) + endif + + ifeq ($(HAVE_LIBCRYPTO),) +- HAVE_LIBCRYPTO := $(shell pkg-config --exists 'libcrypto >= 1.1.0' && echo yes) ++ HAVE_LIBCRYPTO := $(shell $(PKG_CONFIG) --exists 'libcrypto >= 1.1.0' && echo yes) + endif + ifeq ($(HAVE_LIBCRYPTO),yes) +- LIBCRYPTO_CFLAGS := $(shell pkg-config --cflags libcrypto) -DHAVE_LIBCRYPTO +- LIBCRYPTO_LIBS := $(shell pkg-config --libs libcrypto) ++ LIBCRYPTO_CFLAGS := $(shell $(PKG_CONFIG) --cflags libcrypto) -DHAVE_LIBCRYPTO ++ LIBCRYPTO_LIBS := $(shell $(PKG_CONFIG) --libs libcrypto) + endif + + HAVE_PTHREAD := yes diff --git a/app-text/mupdf/files/mupdf-1.27.2-jpx.patch b/app-text/mupdf/files/mupdf-1.27.2-jpx.patch new file mode 100644 index 000000000000..1b676e9fb35f --- /dev/null +++ b/app-text/mupdf/files/mupdf-1.27.2-jpx.patch @@ -0,0 +1,30 @@ +diff --git a/source/tools/murun.c b/source/tools/murun.c +index 1880fab..471cec0 100644 +--- a/source/tools/murun.c ++++ b/source/tools/murun.c +@@ -5390,6 +5390,7 @@ static void ffi_Pixmap_saveAsPKM(js_State *J) + rethrow(J); + } + ++#if FZ_ENABLE_JPX + static void ffi_Pixmap_saveAsJPX(js_State *J) + { + fz_context *ctx = js_getcontext(J); +@@ -5402,6 +5403,7 @@ static void ffi_Pixmap_saveAsJPX(js_State *J) + fz_catch(ctx) + rethrow(J); + } ++#endif + + static void ffi_Pixmap_convertToColorSpace(js_State *J) + { +@@ -12521,7 +12523,9 @@ int murun_main(int argc, char **argv) + jsB_propfun(J, "Pixmap.saveAsPNM", ffi_Pixmap_saveAsPNM, 1); + jsB_propfun(J, "Pixmap.saveAsPBM", ffi_Pixmap_saveAsPBM, 1); + jsB_propfun(J, "Pixmap.saveAsPKM", ffi_Pixmap_saveAsPKM, 1); ++ #if FZ_ENABLE_JPX + jsB_propfun(J, "Pixmap.saveAsJPX", ffi_Pixmap_saveAsJPX, 2); ++ #endif + } + js_setregistry(J, "fz_pixmap"); + diff --git a/app-text/mupdf/files/mupdf-1.27.2-openssl-x11.patch b/app-text/mupdf/files/mupdf-1.27.2-openssl-x11.patch new file mode 100644 index 000000000000..5a997ce9d54d --- /dev/null +++ b/app-text/mupdf/files/mupdf-1.27.2-openssl-x11.patch @@ -0,0 +1,24 @@ +diff --git a/Makerules b/Makerules +index 9fe5bca..1bc93d8 100644 +--- a/Makerules ++++ b/Makerules +@@ -331,17 +331,13 @@ else + endif + endif + +- ifeq ($(HAVE_X11),) +- HAVE_X11 := $(shell $(PKG_CONFIG) --exists x11 xext && echo yes) +- endif ++ HAVE_X11 := not-unless-portage-tells-me + ifeq ($(HAVE_X11),yes) + X11_CFLAGS := $(shell $(PKG_CONFIG) --cflags x11 xext) + X11_LIBS := $(shell $(PKG_CONFIG) --libs x11 xext) + endif + +- ifeq ($(HAVE_LIBCRYPTO),) +- HAVE_LIBCRYPTO := $(shell $(PKG_CONFIG) --exists 'libcrypto >= 1.1.0' && echo yes) +- endif ++ HAVE_LIBCRYPTO := not-unless-portage-tells-me + ifeq ($(HAVE_LIBCRYPTO),yes) + LIBCRYPTO_CFLAGS := $(shell $(PKG_CONFIG) --cflags libcrypto) -DHAVE_LIBCRYPTO + LIBCRYPTO_LIBS := $(shell $(PKG_CONFIG) --libs libcrypto) diff --git a/app-text/mupdf/mupdf-1.27.2.ebuild b/app-text/mupdf/mupdf-1.27.2.ebuild new file mode 100644 index 000000000000..cd97af746a70 --- /dev/null +++ b/app-text/mupdf/mupdf-1.27.2.ebuild @@ -0,0 +1,184 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +# Please check upstream git regularly for relevant security-related commits +# to backport. + +inherit desktop flag-o-matic toolchain-funcs xdg + +DESCRIPTION="A lightweight PDF viewer and toolkit written in portable C" +HOMEPAGE="https://mupdf.com/ https://cgit.ghostscript.com/mupdf.git/" +SRC_URI="https://mupdf.com/downloads/archive/${P}-source.tar.gz" +S="${WORKDIR}"/${P}-source + +LICENSE="AGPL-3" +SLOT="0/${PV}" +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86" +IUSE="archive barcode brotli +javascript +jpeg2k opengl ssl X" +REQUIRED_USE="opengl? ( javascript )" + +# Although we use the bundled, patched version of freeglut in mupdf (because of +# bug #653298), the best way to ensure that its dependencies are present is to +# install system's freeglut. +RDEPEND=" + archive? ( app-arch/libarchive ) + barcode? ( media-libs/zxing-cpp:= ) + brotli? ( app-arch/brotli:= ) + dev-libs/gumbo:= + media-libs/freetype:2 + media-libs/harfbuzz:=[truetype] + media-libs/jbig2dec:= + media-libs/libpng:0= + >=media-libs/libjpeg-turbo-1.5.3-r2:0= + net-misc/curl + javascript? ( >=dev-lang/mujs-1.3.8:= ) + jpeg2k? ( >=media-libs/openjpeg-2.1:2= ) + opengl? ( >=media-libs/freeglut-3.0.0 ) + ssl? ( >=dev-libs/openssl-1.1:0= ) + virtual/zlib:= + X? ( + media-libs/libglvnd[X] + x11-libs/libX11 + x11-libs/libXext + x11-libs/libXrandr + ) +" +DEPEND="${RDEPEND} + X? ( x11-base/xorg-proto )" +BDEPEND="virtual/pkgconfig" + +PATCHES=( + "${FILESDIR}"/${PN}-1.15-CFLAGS.patch + "${FILESDIR}"/${P}-Makefile.patch + "${FILESDIR}"/${P}-jpx.patch + "${FILESDIR}"/${PN}-1.24.8-add-desktop-pc-files.patch + "${FILESDIR}"/${P}-cross-fixes.patch + "${FILESDIR}"/${PN}-1.24.1-darwin.patch + # See bug #662352 + "${FILESDIR}"/${P}-openssl-x11.patch + # General cross fixes from Debian (refreshed) + "${FILESDIR}"/${PN}-1.21.1-fix-aliasing-violation.patch +) + +src_prepare() { + default + + use hppa && append-cflags -ffunction-sections + + append-cflags "-DFZ_ENABLE_JS=$(usex javascript 1 0)" + + if ! use jpeg2k; then + append-cflags "-DFZ_ENABLE_JPX=0" + sed -i '/_OPENJPEG_/d' Makerules || die + # See https://github.com/ArtifexSoftware/mupdf/pull/60 + sed -i '/openjpeg.h/d' 'source/fitz/encode-jpx.c' || die + fi + + sed -e "1iOS = Linux" \ + -e "1iCC = $(tc-getCC)" \ + -e "1iCXX = $(tc-getCXX)" \ + -e "1iLD = $(tc-getLD)" \ + -e "1iAR = $(tc-getAR)" \ + -e "1iverbose = yes" \ + -e "1ibuild = debug" \ + -e "1ibarcode = $(usex barcode)" \ + -e "1ibrotli = $(usex brotli)" \ + -e "1imujs = $(usex javascript)" \ + -i Makerules || die "Failed adding build variables to Makerules in src_prepare()" + + # Adjust MuPDF version in .pc file created by the + # [...]-add-desktop-pc-files.patch file + sed -e "s/Version: \(.*\)/Version: ${PV}/" \ + -i platform/debian/${PN}.pc || die "Failed substituting version in ${PN}.pc" +} + +_emake() { + # When HAVE_OBJCOPY is yes, we end up with a lot of QA warnings. + # + # Bundled libs + # * General + # Note that USE_SYSTEM_LIBS=yes is a metaoption which will set to upstream's + # recommendations. It does not mean "always use system libs". + # See [0] below for what it means in a specific version. + # + # * freeglut + # We don't use system's freeglut because upstream has a special modified + # version of it that gives mupdf clipboard support. See bug #653298 + # + # * mujs + # As of v1.15.0, mupdf started using symbols in mujs that were not part + # of any release. We then went back to using the bundled version of it. + # But v1.17.0 looks ok, so we'll go unbundled again. Be aware of this risk + # when bumping and check! + # See bug #685244 + # + # * lmms2 + # mupdf uses a bundled version of lcms2 [0] because Artifex have forked it [1]. + # It is therefore not appropriate for us to unbundle it at this time. + # + # [0] https://git.ghostscript.com/?p=mupdf.git;a=blob;f=Makethird;h=c4c540fa4a075df0db85e6fdaab809099881f35a;hb=HEAD#l9 + # [1] https://www.ghostscript.com/doc/lcms2mt/doc/WhyThisFork.txt + local myemakeargs=( + GENTOO_PV=${PV} + HAVE_GLUT=$(usex opengl) + HAVE_LIBCRYPTO=$(usex ssl) + HAVE_X11=$(usex X) + HAVE_ZXINGCPP=$(usex barcode) + HAVE_MUJS=$(usex javascript) + HAVE_SYS_ZXINGCPP=$(usex barcode) + USE_SYSTEM_LIBS=yes + USE_SYSTEM_BROTLI=$(usex brotli) + USE_SYSTEM_GLUT=no + USE_SYSTEM_MUJS=$(usex javascript) + USE_SYSTEM_ZXINGCPP=$(usex barcode) + HAVE_OBJCOPY=no + "$@" + ) + + emake "${myemakeargs[@]}" +} + +src_compile() { + tc-export PKG_CONFIG + + _emake XCFLAGS="-fPIC" +} + +src_install() { + if use opengl || use X ; then + domenu platform/debian/${PN}.desktop + doicon -s scalable docs/logo/${PN}-icon.svg + else + rm docs/man/${PN}.1 || die "Failed to remove man page in src_install()" + fi + + sed -i \ + -e "1iprefix = ${ED}/usr" \ + -e "1ilibdir = ${ED}/usr/$(get_libdir)" \ + -e "1idocdir = ${ED}/usr/share/doc/${PF}" \ + -i Makerules || die "Failed adding liprefix, lilibdir and lidocdir to Makerules in src_install()" + + _emake install + + dosym libmupdf.so.${PV} /usr/$(get_libdir)/lib${PN}.so + + if use opengl ; then + einfo "mupdf symlink points to mupdf-gl (bug 616654)" + dosym ${PN}-gl /usr/bin/${PN} + elif use X ; then + einfo "mupdf symlink points to mupdf-x11 (bug 616654)" + dosym ${PN}-x11 /usr/bin/${PN} + fi + + # Respect libdir and EPREFIX (bugs #734898, #911965) + sed -i -e "s:/lib:/$(get_libdir):" \ + -e "s:/usr:${EPREFIX}/usr:" platform/debian/${PN}.pc \ + || die "Failed to sed pkgconfig file to respect libdir and EPREFIX in src_install()" + + insinto /usr/$(get_libdir)/pkgconfig + doins platform/debian/${PN}.pc + + dodoc README CHANGES CONTRIBUTORS +}
