commit:     9b334524e2dcb30d4067f9adfcd0a627d616ead9
Author:     Philipp Rösner <rndxelement <AT> protonmail <DOT> com>
AuthorDate: Sun Mar 23 13:50:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 22 22:31:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b334524

app-text/mupdf: add 1.25.6

- adjust homepage to upstream change.

Closes: https://bugs.gentoo.org/950160
Signed-off-by: Philipp Rösner <rndxelement <AT> protonmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/41239
Signed-off-by: Sam James <sam <AT> gentoo.org>

 app-text/mupdf/Manifest            |   1 +
 app-text/mupdf/mupdf-1.25.6.ebuild | 167 +++++++++++++++++++++++++++++++++++++
 2 files changed, 168 insertions(+)

diff --git a/app-text/mupdf/Manifest b/app-text/mupdf/Manifest
index a72a7385383b..08593134335e 100644
--- a/app-text/mupdf/Manifest
+++ b/app-text/mupdf/Manifest
@@ -1,2 +1,3 @@
 DIST mupdf-1.24.8-source.tar.gz 54039703 BLAKE2B 
0fe25d9f0f01a1e387da590c28abac66309247c46c05c7c9b36c4bc911fc16adab681243c2c1d2c50ec91bb76b737022bd3faf06b0b3a803e9120829d9cae5b4
 SHA512 
17d8fd9fd0e176c8abd1ebc594259a0f7cf822338085ea4574451ba8ec1ac72ba8bd2d5388a1421bbfd4e91257a48d0e0766213ace0933c39d3cb8d774a3860e
 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

diff --git a/app-text/mupdf/mupdf-1.25.6.ebuild 
b/app-text/mupdf/mupdf-1.25.6.ebuild
new file mode 100644
index 000000000000..b1061e1a9618
--- /dev/null
+++ b/app-text/mupdf/mupdf-1.25.6.ebuild
@@ -0,0 +1,167 @@
+# 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 +javascript 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 )
+       dev-libs/gumbo:=
+       media-libs/freetype:2
+       media-libs/harfbuzz:=[truetype]
+       media-libs/jbig2dec:=
+       media-libs/libpng:0=
+       >=media-libs/openjpeg-2.1:2=
+       >=media-libs/libjpeg-turbo-1.5.3-r2:0=
+       net-misc/curl
+       javascript? ( >=dev-lang/mujs-1.2.0:= )
+       opengl? ( >=media-libs/freeglut-3.0.0 )
+       ssl? ( >=dev-libs/openssl-1.1:0= )
+       sys-libs/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}"/${PN}-1.19.0-Makefile.patch
+       "${FILESDIR}"/${PN}-1.24.8-add-desktop-pc-files.patch
+       "${FILESDIR}"/${PN}-1.24.1-cross-fixes.patch
+       "${FILESDIR}"/${PN}-1.24.1-darwin.patch
+       # See bugs #662352
+       "${FILESDIR}"/${PN}-1.24.1-openssl-x11.patch
+       # General cross fixes from Debian (refreshed)
+       "${FILESDIR}"/${PN}-1.21.1-fix-aliasing-violation.patch
+       "${FILESDIR}"/${PN}-1.24.8-c23.patch
+)
+
+src_prepare() {
+       default
+
+       use hppa && append-cflags -ffunction-sections
+
+       append-cflags "-DFZ_ENABLE_JS=$(usex javascript 1 0)"
+
+       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" \
+               -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)
+               USE_SYSTEM_LIBS=yes
+               USE_SYSTEM_MUJS=$(usex javascript)
+               USE_SYSTEM_GLUT=no
+               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
+}

Reply via email to