commit:     142845b4fcc54cb8b6d58872761cadf976d12f2b
Author:     Cristian Othón Martínez Vera <cfuga <AT> cfuga <DOT> mx>
AuthorDate: Fri Jan 16 21:31:23 2026 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan 25 06:45:02 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=142845b4

x11-misc/xscreensaver: add 6.14

* drop `x11-libs/libXxf86vm` dependency
* drop `--with-xf86gamma-ext` and `--with-xf86vmode-ext` configure options
* drop `--with-proc-interrupts` configure option
* update ffmpeg configure patch
* update OCRA.ttf font licensing

Signed-off-by: Cristian Othón Martínez Vera <cfuga <AT> cfuga.mx>
Part-of: https://github.com/gentoo/gentoo/pull/45407
Closes: https://github.com/gentoo/gentoo/pull/45407
Signed-off-by: Sam James <sam <AT> gentoo.org>

 x11-misc/xscreensaver/Manifest                     |   1 +
 .../files/xscreensaver-6.14-ffmpeg.patch           |  91 ++++++
 x11-misc/xscreensaver/xscreensaver-6.14.ebuild     | 343 +++++++++++++++++++++
 3 files changed, 435 insertions(+)

diff --git a/x11-misc/xscreensaver/Manifest b/x11-misc/xscreensaver/Manifest
index d041c6bf73e5..83a105319552 100644
--- a/x11-misc/xscreensaver/Manifest
+++ b/x11-misc/xscreensaver/Manifest
@@ -4,3 +4,4 @@ DIST xscreensaver-6.10.1.tar.gz 25081752 BLAKE2B 
6bfeed1acbe0aee07ed64c31f8e503a
 DIST xscreensaver-6.12-logind-idle-hint.patch 4056 BLAKE2B 
30861195aeef16f8252d2324e61674a8d77cd1c0fb62aa5128c8d1e7289edfc2ee7bc4d39e50e1dcbcfe5601b95c14868320bf257bb1c9fe96c9542bde86240a
 SHA512 
3ebb0398266b659545831a772417772f0ba99dd8125cc1ae497eb8dfa4d98dd368a119763283464ea72cab410573b7adc32176e80d243652820b4649b1e4551d
 DIST xscreensaver-6.12.tar.gz 25177935 BLAKE2B 
0e102abd2c28574110b6e1d2b8d59619430869d04c151f379654e1ee8350a93208f198f739f63507e781efd93808fbe17df0f11e5196dde6de010272272eb9fb
 SHA512 
df98e07fe66fd6ad1fd680c6790d66a160f146ff721f90a76c46142888a0d17f82f068343b1ac82aa4562385460da393dc4733abdb26f0cda0f2a8944a614497
 DIST xscreensaver-6.13.tar.gz 25233110 BLAKE2B 
a165a9bf9fa2f1d3db6e660ccb03fe5474bf2338e4d1d606d76b5552ae08d4d9ca97ff5a4b4a0778c741f391a9d654b0422c4b0e9b4a0a5a0c7b535c346d3e69
 SHA512 
1ab42c0d0bf31b6d25e543d44c2ff41f48ef229ffce3a02f82495c1ef9c9452eddec4abe1cd7705220c6491562361f8cd0cca8bce9875ff80a765816574bf8ac
+DIST xscreensaver-6.14.tar.gz 25206667 BLAKE2B 
2137d12232f97cf68daaa9d44bfc0a566a56afefe29cd348b72f8335a92dc391ff0d69fb50c0aa283548c64d746d49c27df20f64d7ab768ada76088240fff08b
 SHA512 
2ef426f7ae862e7b4665014843451410e30dce8dcc16b98e94c58c0a904bba8ab9eb0f561599ea57eb68df49265171507074026784fdbff23fafeb87175e47df

diff --git a/x11-misc/xscreensaver/files/xscreensaver-6.14-ffmpeg.patch 
b/x11-misc/xscreensaver/files/xscreensaver-6.14-ffmpeg.patch
new file mode 100644
index 000000000000..d355adca31f4
--- /dev/null
+++ b/x11-misc/xscreensaver/files/xscreensaver-6.14-ffmpeg.patch
@@ -0,0 +1,91 @@
+Since version 6.07, xscreensaver could save videos, using ffmpeg,
+but the configure flag --with-record-animation doesn't work to
+deactivate this feature.
+
+Signed-off-by: Cristian Othón Martínez Vera <[email protected]>
+
+--- a/configure.ac
++++ b/configure.ac
+@@ -3801,6 +3801,28 @@
+   XFT_OBJS='$(UTILS_BIN)/xft.o'
+ fi
+ 
++###############################################################################
++#
++#       Check for --with-record-animation
++#
++###############################################################################
++
++record_anim_default=no
++record_anim="$record_anim_default"
++AC_ARG_WITH(record-animation,
++[  --with-record-animation Include code for generating MP4 videos.],
++  [record_anim="$withval"], [record_anim="$record_anim_default"])
++
++HANDLE_X_PATH_ARG(record_anim, --with-record-animation, record animation)
++
++if test "$record_anim" = yes; then
++  true
++elif test "$record_anim" != no; then
++  echo "error: must be yes or no: --with-record-animation=$record_anim"
++  exit 1
++fi
++
++if test "$record_anim" = yes; then
+ 
+ 
###############################################################################
+ #
+@@ -3958,6 +3980,15 @@
+   FFMPEG_LIBS="$FFMPEG_LIBS $extra_ffmpeg_bs"
+ fi
+ 
++  if test "$have_ffmpeg" != yes; then
++    AC_MSG_WARN(--with-record-animation requires the ffmpeg libraries)
++  else
++    AC_MSG_RESULT(enabling --record-animation)
++    AC_DEFINE(HAVE_RECORD_ANIM)
++    ANIM_OBJS='$(ANIM_OBJS)'
++    ANIM_LIBS='$(ANIM_LIBS)'
++  fi
++fi
+ 
+ 
###############################################################################
+ #
+@@ -4050,37 +4081,7 @@
+ fi
+ 
+ 
+-###############################################################################
+-#
+-#       Check for --with-record-animation
+-#
+-###############################################################################
+-
+-record_anim_default=no
+-record_anim="$record_anim_default"
+-AC_ARG_WITH(record-animation,
+-[  --with-record-animation Include code for generating MP4 videos.],
+-  [record_anim="$withval"], [record_anim="$record_anim_default"])
+-
+-HANDLE_X_PATH_ARG(record_anim, --with-record-animation, record animation)
+-
+-if test "$record_anim" = yes; then
+-  true
+-elif test "$record_anim" != no; then
+-  echo "error: must be yes or no: --with-record-animation=$record_anim"
+-  exit 1
+-fi
+ 
+-if test "$record_anim" = yes; then
+-  if test "$have_ffmpeg" != yes; then
+-    AC_MSG_WARN(--with-record-animation requires the ffmpeg libraries)
+-  else
+-    AC_MSG_RESULT(enabling --record-animation)
+-    AC_DEFINE(HAVE_RECORD_ANIM)
+-    ANIM_OBJS='$(ANIM_OBJS)'
+-    ANIM_LIBS='$(ANIM_LIBS)'
+-  fi
+-fi
+ 
+ 
+ 
###############################################################################

diff --git a/x11-misc/xscreensaver/xscreensaver-6.14.ebuild 
b/x11-misc/xscreensaver/xscreensaver-6.14.ebuild
new file mode 100644
index 000000000000..e72accdbf279
--- /dev/null
+++ b/x11-misc/xscreensaver/xscreensaver-6.14.ebuild
@@ -0,0 +1,343 @@
+# Copyright 1999-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit autotools flag-o-matic font greadme optfeature pam strip-linguas 
systemd xdg-utils
+
+DESCRIPTION="Modular screen saver and locker for the X Window System"
+HOMEPAGE="https://www.jwz.org/xscreensaver/";
+SRC_URI="
+       https://www.jwz.org/xscreensaver/${P}.tar.gz
+       logind-idle-hint? (
+               
https://github.com/Flowdalic/xscreensaver/commit/e79e2f41be3367c196899ef2f38ab97436fa1a65.patch
 ->
+                       ${PN}-6.12-logind-idle-hint.patch
+       )
+       systemd? (
+               
https://github.com/Flowdalic/xscreensaver/commit/376b07ec76cfe1070f498773aaec8fd7030593af.patch
 ->
+                       
${PN}-6.07-xscreensaver.service-start-with-no-splash.patch
+       )
+"
+
+S="${WORKDIR}/${PN}-$(ver_cut 1-2)"
+# Font license mapping for folder ./hacks/fonts/ as following:
+#   clacon.ttf       -- MIT
+#   gallant12x22.ttf -- BSD
+#   luximr.ttf       -- bh-luxi (package media-fonts/font-bh-ttf)
+#   OCRA.ttf         -- freely redistributable
+#   SpecialElite.ttf -- Apache-2.0
+LICENSE="BSD fonts? ( MIT freedist Apache-2.0 ) systemd? ( ISC )"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv 
~sparc ~x86"
+IUSE="elogind ffmpeg fonts +gdk-pixbuf gdm +gtk jpeg +locking logind-idle-hint 
new-login offensive pam +perl +png selinux suid systemd xinerama wayland"
+REQUIRED_USE="
+       ?? ( elogind systemd )
+       pam? ( locking )
+       logind-idle-hint? ( || ( elogind systemd ) )
+"
+
+COMMON_DEPEND="
+       >=dev-libs/libxml2-2.4.6:=
+       x11-apps/appres
+       x11-apps/xwininfo
+       x11-libs/libX11
+       x11-libs/libXext
+       >=x11-libs/libXft-2.1.0
+       x11-libs/libXi
+       x11-libs/libXrandr
+       x11-libs/libXt
+       virtual/glu
+       virtual/opengl
+       elogind? ( sys-auth/elogind )
+       gdk-pixbuf? ( >=x11-libs/gdk-pixbuf-2.42.0:2[jpeg?] )
+       gtk? ( >=x11-libs/gtk+-3.0.0:3[X,wayland?] )
+       ffmpeg? ( >=media-video/ffmpeg-6.1:= )
+       jpeg? ( media-libs/libjpeg-turbo:= )
+       locking? ( virtual/libcrypt:= )
+       new-login? (
+               gdm? ( gnome-base/gdm )
+               !gdm? ( || ( x11-misc/lightdm lxde-base/lxdm ) )
+       )
+       pam? ( sys-libs/pam )
+       png? ( media-libs/libpng:= )
+       systemd? ( >=sys-apps/systemd-221:= )
+       xinerama? ( x11-libs/libXinerama )
+       wayland? ( >=dev-libs/wayland-1.8 )
+"
+# For USE="perl" see output of `qlist xscreensaver | grep '\(bin\|misc\)' | 
xargs grep '::'`
+RDEPEND="
+       ${COMMON_DEPEND}
+       sys-apps/attr
+       x11-misc/xdg-utils
+       perl? (
+               dev-lang/perl
+               dev-perl/HTML-Parser
+               dev-perl/LWP-Protocol-https
+               dev-perl/libwww-perl
+       )
+       selinux? ( sec-policy/selinux-xscreensaver )
+       wayland? ( gui-apps/grim )
+"
+DEPEND="
+       ${COMMON_DEPEND}
+       x11-base/xorg-proto
+"
+BDEPEND="
+       dev-util/intltool
+       app-alternatives/bc
+       sys-devel/gettext
+       virtual/pkgconfig
+"
+PATCHES=(
+       "${FILESDIR}"/${PN}-5.31-pragma.patch
+       "${FILESDIR}"/${PN}-6.01-gentoo.patch
+       "${FILESDIR}"/${PN}-6.07-gcc.patch
+       "${FILESDIR}"/${PN}-6.01-configure.ac-sandbox.patch
+       "${FILESDIR}"/${PN}-6.01-without-gl-makefile.patch
+       "${FILESDIR}"/${PN}-6.01-non-gtk-install.patch
+       "${FILESDIR}"/${PN}-6.01-configure-install_sh.patch
+       "${FILESDIR}"/${PN}-6.03-without-gl-configure.patch
+       "${FILESDIR}"/${PN}-6.05-remove-update-icon-cache.patch
+       "${FILESDIR}"/${PN}-6.05-r2-configure-exit-codes.patch
+       "${FILESDIR}"/${PN}-6.07-allow-no-pam.patch
+       "${FILESDIR}"/${PN}-6.07-fix-desktop-files.patch
+       "${FILESDIR}"/${PN}-6.14-ffmpeg.patch
+)
+
+DOCS=( README{,.hacking} )
+
+# see https://bugs.gentoo.org/898328
+QA_CONFIG_IMPL_DECL_SKIP=( getspnam_shadow )
+
+src_prepare() {
+       default
+
+       # bug #896440
+       mv po/ca.po po/ca.po.old || die
+       iconv -f ISO-8859-15 -t UTF-8 po/ca.po.old >po/ca.po || die
+
+       sed -i configure.ac -e '/^ALL_LINGUAS=/d' || die
+
+       if use systemd; then
+               # Causes "Failed to enable unit: Cannot alias 
xscreensaver.service as org.jwz.xscreensaver."
+               # after "systemctl --user enable xscreensaver".
+               sed -i -e '/^Alias=org.jwz.xscreensaver.service/d' \
+                       driver/xscreensaver.service.in || die
+
+               eapply 
"${DISTDIR}/${PN}-6.07-xscreensaver.service-start-with-no-splash.patch"
+       fi
+
+       strip-linguas -i po/
+       export ALL_LINGUAS="${LINGUAS}"
+
+       if use new-login && ! use gdm; then #392967
+               sed -i \
+                       -e "/default_l.*1/s:gdmflexiserver 
-ls:${EPREFIX}/usr/libexec/lightdm/&:" \
+                       configure{,.ac} || die
+       fi
+
+       # We are patching driver/XScreenSaver.ad.in, so let's delete the
+       # header generated from it so that it gets back in sync during build:
+       rm driver/XScreenSaver_ad.h || die
+
+       if ! use offensive; then
+               sed -i \
+                       -e 
'/boobies/d;/boobs/d;/cock/d;/pussy/d;/viagra/d;/vibrator/d' \
+                       hacks/barcode.c || die
+               sed -i \
+                       -e 's|erect penis|shuffle board|g' \
+                       -e 's|flaccid penis|flaccid anchor|g' \
+                       -e 's|vagina|engagement ring|g' \
+                       -e 's|Penis|Shuttle|g' \
+                       hacks/glx/glsnake.c || die
+               sed -i \
+                       's| Stay.*fucking mask\.$||' \
+                       hacks/glx/covid19.man \
+                       hacks/config/covid19.xml || die
+               sed -i \
+                       -e 's|Ass |Dumb |g' \
+                       -e 's|Buttcorn|Blue Corn|g' \
+                       -e 's| dick||gi' \
+                       -e 's| shit||g' \
+                       hacks/bsod.c || die
+               eapply 
"${FILESDIR}/xscreensaver-6.05-teach-handsy-some-manners.patch"
+       fi
+
+       if use logind-idle-hint; then
+               eapply "${DISTDIR}/${PN}-6.12-logind-idle-hint.patch"
+       fi
+
+       config_rpath_update "${S}"/config.rpath
+
+       # Must be eauto*re*conf, to force the rebuild
+       eautoreconf
+}
+
+src_configure() {
+       if use ppc || use ppc64; then
+               filter-flags -maltivec -mabi=altivec
+               append-flags -U__VEC__
+       fi
+
+       unset BC_ENV_ARGS #24568
+
+       # WARNING: This is NOT a normal autoconf script
+       # Some of the --with options are NOT standard, and expect "--with-X=no" 
rather than "--without-X"
+       ECONF_OPTS=(
+               $(use_enable locking)
+               $(use_with elogind)
+               $(use_with gdk-pixbuf pixbuf)
+               $(use_with gtk)
+               $(use_with new-login login-manager)
+               $(use_with pam)
+               $(use_with suid setuid-hacks)
+               $(use_with systemd)
+               $(use_with xinerama xinerama-ext)
+               $(use_with wayland)
+               --with-jpeg=$(usex jpeg yes no)
+               --with-record-animation=$(usex ffmpeg yes no)
+               --with-png=$(usex png yes no)
+               --with-xft=yes
+               --with-app-defaults="${EPREFIX}"/usr/share/X11/app-defaults
+               --with-configdir="${EPREFIX}"/usr/share/${PN}/config
+               --with-dpms-ext
+               --with-hackdir="${EPREFIX}"/usr/$(get_libdir)/misc/${PN}
+               --with-randr-ext
+               --with-text-file="${EPREFIX}"/etc/gentoo-release
+               --with-xdbe-ext
+               --with-xinput-ext
+               --with-xkb-ext
+               --with-xshm-ext
+               --without-gle
+               --without-gles
+               --without-glx
+               --without-kerberos
+               --without-motif
+               --with-proc-oom
+               --x-includes="${EPREFIX}"/usr/include
+               --x-libraries="${EPREFIX}"/usr/$(get_libdir)
+       )
+       # WARNING: This is NOT a normal autoconf script
+       econf "${ECONF_OPTS[@]}"
+}
+
+src_compile() {
+       # stock target is "default", which is broken in some releases.
+       emake all
+}
+
+src_install() {
+       use pam && dodir /etc/pam.d/
+       emake install_prefix="${D}" DESTDIR="${D}" 
GTK_SHAREDIR="${installprefix}"/usr/share/xscreensaver install
+
+       if use fonts; then
+               # Do not duplicate font Luxi Mono (of package 
media-fonts/font-bh-ttf)
+               rm -v "${ED}${FONTDIR}"/luximr.ttf || die
+
+               font_xfont_config
+       else
+               rm -rfv "${ED}${FONTDIR}" || die #812473
+       fi
+
+       einstalldocs
+
+       if use pam; then
+               fperms 755 /usr/bin/${PN}
+               pamd_mimic_system ${PN} auth
+       fi
+
+       # bugs #809599, #828869
+       if ! use gtk; then
+               rm "${ED}/usr/bin/xscreensaver-demo" || die
+       fi
+
+       if use systemd; then
+               systemd_douserunit "${ED}/usr/share/${PN}/xscreensaver.service"
+       fi
+       # Makefile installs xscreensaver.service regardless of
+       # --without-systemd, and if USE=systemd, we will have installed the
+       # unit file already.
+       rm "${ED}/usr/share/${PN}/xscreensaver.service" || die
+
+       # bug #885989
+       fperms 4755 /usr/$(get_libdir)/misc/xscreensaver/xscreensaver-auth
+
+       if ! { use png || use gdk-pixbuf; }; then
+               greadme_stdin --append <<-EOF
+               Xscreensaver was built without any means to support image 
manipulation
+               (i.e. with neither USE=gtk-pixbuf or USE=png. Several 
screensavers
+               will likely just fail to work without it and several others will
+               have diminished appearance like displaying a checkerboard 
pattern
+               instead of an image. It is strongly recommended to enable at 
least one
+               of those flags.
+
+               EOF
+       elif ! use gdk-pixbuf; then
+               greadme_stdin --append <<-EOF
+               Xscreensaver was built with png support only. This means that 
most of
+               screensavers won't be able to use images in any other formats. 
It is
+               recommended to enable USE=gtk-pixbuf.
+
+               EOF
+       fi
+
+       if ! use jpeg; then
+               greadme_stdin --append <<-EOF
+               Xscreensaver was built without jpeg support. This mean that
+               'webcollage' screensaver will be considerably slower. Enable
+               USE=jpeg if that will become an issue.
+
+               EOF
+       fi
+
+       if use gtk; then
+               greadme_stdin --append <<-EOF
+               You can configure xscreensaver via 'xscreensaver-settings'.
+
+               EOF
+       else
+               greadme_stdin --append <<-EOF
+               Since xscreensaver had been built without USE=gtk
+               'xscreensaver-settings' was not installed. Hence the only
+               way to configure it is via some third-party utilities or
+               directly via configuration file '~/.xscreensaver'.
+
+               EOF
+       fi
+
+       if use wayland; then
+               greadme_stdin --append <<-EOF
+               WARNING: Wayland support is preliminary. It does not lock and 
you need
+               a supported compositor, like:
+
+                *  kde-plasma/kwin
+                *  gui-wm/sway
+                *  gui-wm/hyprland
+                *  gui-wm/wayfire
+                *  gui-wm/labwc
+               EOF
+       fi
+}
+
+pkg_postinst() {
+       use fonts && font_pkg_postinst
+
+       greadme_pkg_postinst
+
+       optfeature_header 'Additional dependencies for specific screensavers'
+       optfeature 'vidwhacker' 'media-libs/netpbm[jpeg,png] 
virtual/imagemagick-tools' \
+                       'media-libs/netpbm[jpeg,png] media-libs/libjpeg-turbo  
media-gfx/fbida'
+       optfeature 'webcollage' 'virtual/imagemagick-tools[jpeg,png] 
x11-apps/xdpyinfo'
+
+       optfeature_header 'Fonts'
+       optfeature 'Bitmap fonts 75dpi' media-fonts/font-adobe-75dpi
+       optfeature 'Bitmap fonts 100dpi' media-fonts/font-adobe-100dpi
+       optfeature 'Truetype font Luxi Mono' media-fonts/font-bh-ttf
+
+       xdg_icon_cache_update
+}
+
+pkg_postrm() {
+       use fonts && font_pkg_postrm
+       xdg_icon_cache_update
+}

Reply via email to