commit:     79d3bbef1b508c36bf1f88481a9d791098b438cd
Author:     Pascal Jäger <pascal.jaeger <AT> leimstift <DOT> de>
AuthorDate: Sun Oct 16 17:14:35 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 30 09:37:56 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=79d3bbef

x11-misc/xscreensaver: version bump to 6.05

* New patch for handsys manners
* Building with USE="-opengl" is not supported anymore
* Also added a patch for -gtk builds, set GTK_SHAREDIR because when build
  with USE="-gtk" it is not set and then installs .service file into /
* Building with USE="-xft" is not supported anymore
* Delete .service file when USE="-systemd"

Closes: https://bugs.gentoo.org/869218
Closes: https://bugs.gentoo.org/851057
Closes: https://bugs.gentoo.org/834593
Closes: https://bugs.gentoo.org/851834
Closes: https://bugs.gentoo.org/830777
Signed-off-by: Pascal Jäger <pascal.jaeger <AT> leimstift.de>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 x11-misc/xscreensaver/Manifest                     |   1 +
 .../xscreensaver-6.05-configure-exit-codes.patch   |  29 +++
 ...screensaver-6.05-remove-update-icon-cache.patch |  13 ++
 ...creensaver-6.05-teach-handsy-some-manners.patch |  42 ++++
 x11-misc/xscreensaver/metadata.xml                 |   9 +-
 x11-misc/xscreensaver/xscreensaver-6.05.ebuild     | 243 +++++++++++++++++++++
 6 files changed, 336 insertions(+), 1 deletion(-)

diff --git a/x11-misc/xscreensaver/Manifest b/x11-misc/xscreensaver/Manifest
index cb133020e650..fd4388280ff6 100644
--- a/x11-misc/xscreensaver/Manifest
+++ b/x11-misc/xscreensaver/Manifest
@@ -2,3 +2,4 @@ DIST xscreensaver-6.01.tar.gz 27820165 BLAKE2B 
b2c90b47fb65db79d2473c1e396717156
 DIST xscreensaver-6.02.tar.gz 22672643 BLAKE2B 
2d931fe93230e8c7344abd9180e26ab8775f82604e6f4804c82821c486203be567708cf50f7a11276a6b39df493fe5652b4198765ecb3bc5afc8cbc5a01d4801
 SHA512 
2291ec6ca2d2a24dae975f7f3a8e1733c06f289eb74955db5b3344c7ddcc1d72f82d380df984ef9199f2ed7ab8a7bc920da57d98f589ae5fd1cee082755ba1ff
 DIST xscreensaver-6.03.tar.gz 25703584 BLAKE2B 
1276e469e8f4116fac5d434aeacbc16ff8243b56095d39ff4fcbb390abad935e70d308d2a3ecfebaa453f2dd19944ecc2edb18a229248c02f2e3997f30436bce
 SHA512 
4aa30824c972a73dc09aeba478cad074f273839a4c7641cddd292da38fc75db10a3f6243cbe8619c5e39cad54c27d33e1e271dfed167458faa7747fb0a090630
 DIST xscreensaver-6.04.tar.gz 26112437 BLAKE2B 
42411d5f63a99d4aaccbc3bc34f8c31a1f25f1806eaf513a1ba59c2f24722e27fa2a7b1970c82a591502627224c4b4269176bda3475aba58bb945d5cd9a9464b
 SHA512 
7e8f01853b3d9252ce0120894db7dd4fa3cd19114602a09aa770ec750e2f3742585ca4daf19b009e97386f8c0e3cc89330fe760148c6388f41de8cc1f48f8071
+DIST xscreensaver-6.05.1.tar.gz 26110057 BLAKE2B 
97c16c9f0b2a0b4d00ddccd711b921ca683bd233bc3d07ecad38b68ff94b149a20512246dd6bae052323f00b1b433f56469c5638a031cbc65b61c2b84a0180e3
 SHA512 
c659a769ff71020b9f96b7e707bd1bcc667eb304179305d56b1be45eed095d650a8aa019890a0c5d444672f9dd68516c99c53b0df94cd96196d7f30a24b987e3

diff --git 
a/x11-misc/xscreensaver/files/xscreensaver-6.05-configure-exit-codes.patch 
b/x11-misc/xscreensaver/files/xscreensaver-6.05-configure-exit-codes.patch
new file mode 100644
index 000000000000..a8ef464d2db0
--- /dev/null
+++ b/x11-misc/xscreensaver/files/xscreensaver-6.05-configure-exit-codes.patch
@@ -0,0 +1,29 @@
+The configure scripts exits on a non zero exit code even with a warning. Even
+though for upstream this is just a warning, for portage this means failure and 
+it will exit.
+We therefore alter the exit codes where neccesary.
+
+--- a/configure.ac
++++ b/configure.ac
+@@ -4588,7 +4588,6 @@ if test "$have_motif" = no -a "$have_gtk" = no; then
+   else
+     warnL "The GTK libraries do not seem to be available; the"
+     warn2 "\`xscreensaver-settings' program requires them."
+-    CONF_STATUS=1
+ #   echo ''
+ #   warn2 'You can use Motif or Lesstif instead of GTK (use the'
+ #   warn2 "\`--with-motif' option) but that is NOT recommended."
+@@ -4615,7 +4614,6 @@ if test "$have_gtk" = yes -a "$have_gdk_pixbuf" = no ; 
then
+   warn  "GTK is being used, but the GDK-Pixbuf library and/or"
+   warn2 "headers were not found.  That can't be good.  Please"
+   warn2 "install the GDK-Pixbuf development kit and re-configure."
+-  CONF_STATUS=1
+ fi
+
+ if test "$have_motif" = yes -a "$have_lesstif" = yes ; then
+@@ -4733,7 +4731,6 @@ if test "$have_png" = no ; then
+
+   if test "$png_halfassed" = yes ; then halfassery ; fi
+   warn2 "Many things aren't going to work right."
+-  CONF_STATUS=1
+ fi

diff --git 
a/x11-misc/xscreensaver/files/xscreensaver-6.05-remove-update-icon-cache.patch 
b/x11-misc/xscreensaver/files/xscreensaver-6.05-remove-update-icon-cache.patch
new file mode 100644
index 000000000000..7d9ffdfae4d7
--- /dev/null
+++ 
b/x11-misc/xscreensaver/files/xscreensaver-6.05-remove-update-icon-cache.patch
@@ -0,0 +1,13 @@
+Remove update icon cache as it is a sandbox access violation.
+We do this in the ebuild by ourselves instead.
+
+--- a/driver/Makefile.in
++++ b/driver/Makefile.in
+@@ -564,7 +564,6 @@ install-gnome:: $(LOGO)
+         fi
+
+ install-gnome:: uninstall-old-gnome-icons
+-install-gnome:: update-icon-caches
+
+ update-icon-caches::
+        @for f in /usr/share/icons/index.theme  

diff --git 
a/x11-misc/xscreensaver/files/xscreensaver-6.05-teach-handsy-some-manners.patch 
b/x11-misc/xscreensaver/files/xscreensaver-6.05-teach-handsy-some-manners.patch
new file mode 100644
index 000000000000..0f09d970a920
--- /dev/null
+++ 
b/x11-misc/xscreensaver/files/xscreensaver-6.05-teach-handsy-some-manners.patch
@@ -0,0 +1,42 @@
+This is to teach handly some good manners and get his mind out of the gutter. 
He let himself go quite a bit lately.
+Fixes: https://bugs.gentoo.org/869218
+
+
+--- a/hacks/glx/handsy_anim.h
++++ b/hacks/glx/handsy_anim.h
+@@ -770,7 +770,6 @@ static const hand_anim goatse_anim[] = {
+ /**************************************************************************/
+
+ static const hand_anim_pair all_hand_anims[] = {
+-  {{ middle_anim,    middle_anim },    0.2 },
+   {{ tap_anim,       tap_anim },       0.7 },
+   {{ tap_anim,       tap_anim },       0.7 },
+   {{ tap_anim,       tap_anim },       0.7 },
+@@ -778,15 +777,12 @@ static const hand_anim_pair all_hand_anims[] = {
+   {{ spock_anim,     hidden_anim},     0 },
+   {{ horns_anim,     horns_anim},      0 },
+   {{ horns_anim,     horns_anim},      0 },
+-  {{ bs1_anim,       bs2_anim },       0 },
+-  {{ upyours_anim,   hidden_anim },    0 },
+   {{ peace_anim,     hidden_anim },    0 },
+   {{ scissor1_anim,  scissor2_anim },  0 },
+   {{ wave_anim,      hidden_anim },    0 },
+   {{ wave2_anim,     hidden_anim },    0 },
+   {{ jazzhands_anim, jazzhands_anim }, 0 },
+   {{ ok_anim,        ok_anim },        0 },
+-  {{ inout1_anim,    inout2_anim },    0 },
+   {{ clap_anim,      clap_anim },      0 },
+   {{ slow_clap_anim, slow_clap_anim }, 0 },
+   {{ pray_anim,      pray_anim },      0 },
+@@ -795,11 +791,9 @@ static const hand_anim_pair all_hand_anims[] = {
+   {{ thumbsup_anim,  thumbsup_anim },  0 },
+   {{ thumbsdn_anim,  thumbsdn_anim },  0 },
+   {{ thisguy_anim,   thisguy_anim },   0 },
+-  {{ outtahere_anim, hidden_anim },    0 },
+   {{ stahhhp_anim,   stahhhp_anim },   0 },
+   {{ gun_anim,       gun_anim },       0.25 },
+   {{ walk_anim,      walk_anim },      0.3 },
+-  {{ goatse_anim,    goatse_anim },    0 },
+   {{ 0, }}};
+
+ #endif /* __HANDSY_ANIM__ */

diff --git a/x11-misc/xscreensaver/metadata.xml 
b/x11-misc/xscreensaver/metadata.xml
index e6446e8ce0e8..11a85b2711e6 100644
--- a/x11-misc/xscreensaver/metadata.xml
+++ b/x11-misc/xscreensaver/metadata.xml
@@ -1,7 +1,14 @@
 <?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd";>
 <pkgmetadata>
-       <!-- maintainer-needed -->
+       <maintainer type="person">
+               <email>pascal.jae...@leimstift.de</email>
+               <name>Pascal Jäger</name>
+       </maintainer>
+       <maintainer type="project" proxied="proxy">
+               <email>proxy-ma...@gentoo.org</email>
+               <name>Proxy Maintainers</name>
+       </maintainer>
        <upstream>
                <maintainer>
                        <email>j...@jwz.org</email>

diff --git a/x11-misc/xscreensaver/xscreensaver-6.05.ebuild 
b/x11-misc/xscreensaver/xscreensaver-6.05.ebuild
new file mode 100644
index 000000000000..5e6910a7f3ff
--- /dev/null
+++ b/x11-misc/xscreensaver/xscreensaver-6.05.ebuild
@@ -0,0 +1,243 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit autotools flag-o-matic font optfeature pam strip-linguas
+
+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}.1.tar.gz";
+
+# Font license mapping for folder ./hacks/fonts/ as following:
+#   clacon.ttf       -- MIT
+#   gallant12x22.ttf -- unclear, hence dropped
+#   luximr.ttf       -- bh-luxi (package media-fonts/font-bh-ttf)
+#   OCRAStd.otf      -- unclear, hence dropped
+#   SpecialElite.ttf -- Apache-2.0
+LICENSE="BSD fonts? ( MIT Apache-2.0 )"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~mips ~ppc ~ppc64 
~riscv ~sparc ~x86 ~amd64-linux ~x86-linux"
+IUSE="elogind fonts +gdk-pixbuf gdm gles glx +gtk jpeg +locking new-login 
offensive pam +perl +png selinux suid systemd xinerama"
+REQUIRED_USE="
+       gles? ( !glx )
+       ?? ( elogind systemd )
+       gtk? ( || ( gdk-pixbuf png ) )
+"
+
+COMMON_DEPEND="
+       >=dev-libs/libxml2-2.4.6
+       x11-apps/appres
+       x11-apps/xwininfo
+       x11-libs/libX11
+       x11-libs/libXext
+       x11-libs/libXi
+       x11-libs/libXrandr
+       x11-libs/libXt
+       x11-libs/libXxf86vm
+       elogind? ( sys-auth/elogind )
+       gdk-pixbuf? (
+               x11-libs/gdk-pixbuf-xlib
+               >=x11-libs/gdk-pixbuf-2.42.0:2
+       )
+       gtk? ( >=x11-libs/gtk+-2.22.0:3 )
+       jpeg? ( media-libs/libjpeg-turbo:= )
+       locking? ( virtual/libcrypt:= )
+       new-login? (
+               gdm? ( gnome-base/gdm )
+               !gdm? ( || ( x11-misc/lightdm lxde-base/lxdm ) )
+       )
+       virtual/glu
+       virtual/opengl
+       pam? ( sys-libs/pam )
+       png? ( media-libs/libpng:= )
+       systemd? ( >=sys-apps/systemd-221 )
+       >=x11-libs/libXft-2.1.0
+       xinerama? ( x11-libs/libXinerama )
+"
+# For USE="perl" see output of `qlist xscreensaver | grep bin | xargs grep 
'::'`
+RDEPEND="
+       ${COMMON_DEPEND}
+       media-gfx/fbida
+       perl? (
+               dev-lang/perl
+               dev-perl/libwww-perl
+               virtual/perl-Digest-MD5
+       )
+       selinux? ( sec-policy/selinux-xscreensaver )
+"
+DEPEND="
+       ${COMMON_DEPEND}
+       x11-base/xorg-proto
+"
+BDEPEND="
+       dev-util/intltool
+       sys-devel/bc
+       sys-devel/gettext
+       virtual/pkgconfig
+"
+PATCHES=(
+       "${FILESDIR}"/${PN}-6.01-interix.patch
+       "${FILESDIR}"/${PN}-5.31-pragma.patch
+       "${FILESDIR}"/${PN}-6.01-gentoo.patch
+       "${FILESDIR}"/${PN}-5.45-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-configure-exit-codes.patch
+)
+
+DOCS=( README{,.hacking} )
+
+src_prepare() {
+       default
+
+       sed -i configure.ac -e '/^ALL_LINGUAS=/d' || die
+       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
+               eapply 
"${FILESDIR}/xscreensaver-6.05-teach-handsy-some-manners.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
+
+       # /proc/interrupts won't always have the keyboard bits needed
+       # Not clear this does anything in 6.03+(?) but let's keep it for now in 
case.
+       # (See also: configure argument)
+       export ac_cv_have_proc_interrupts=yes
+
+       # 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 gles)
+               $(use_with glx)
+               $(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)
+               --with-jpeg=$(usex jpeg 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-proc-interrupts
+               --with-randr-ext
+               --with-text-file="${EPREFIX}"/etc/gentoo-release
+               --with-xdbe-ext
+               --with-xf86gamma-ext
+               --with-xf86vmode-ext
+               --with-xinput-ext
+               --with-xkb-ext
+               --with-xshm-ext
+               --without-gle
+               --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 install fonts with unclear licensing
+               rm -v "${ED}${FONTDIR}"/{gallant12x22.ttf,OCRAStd.otf} || die
+
+               # 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 -v "${ED}${FONTDIR}"/*.{ttf,otf} || die
+               rmdir -v "${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
+       # Makefile installs xscreensaver.service regardless of --without-systemd
+       if ! use systemd; then
+               rm "${ED}/usr/share/xscreensaver.service" || die
+       fi
+}
+
+pkg_postinst() {
+       use fonts && font_pkg_postinst
+
+       # bug #811885
+       if ! use glx; then
+               elog "Enable USE='glx' if OpenGL screensavers are crashing."
+       fi
+
+       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
+}
+
+pkg_postrm() {
+       use fonts && font_pkg_postrm
+}

Reply via email to