X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=xscreensaver.spec;h=bc8a81b1c739136dfcf2137e062bdf2b6b0020b8;hb=82c5080773aae5e72ec155327c075775e023d2ee;hp=d4cfb709f18cb714d1670cd9cda0e0bac437e770;hpb=93f25dc6827112d98b8b855ea85c8f5eb8123086;p=xscreensaver diff --git a/xscreensaver.spec b/xscreensaver.spec index d4cfb709..bc8a81b1 100644 --- a/xscreensaver.spec +++ b/xscreensaver.spec @@ -1,12 +1,21 @@ -%define name xscreensaver -%define version 3.25 -%define release 1 -%define serial 1 -%define prefix /usr/X11R6 +%define name xscreensaver +%define version 3.31 +%define release 1 +%define serial 1 +%define x11_prefix /usr/X11R6 +%define gnome_prefix /usr +%define kde_prefix /usr + +%define gnome_datadir %{gnome_prefix}/share +%define gnome_ccdir %{gnome_datadir}/control-center/Desktop +%define gnome_paneldir %{gnome_datadir}/gnome/apps/Settings/Desktop +%define gnome_icondir %{gnome_datadir}/pixmaps # By default, builds the basic, non-GL package. # To build both the basic and GL-add-on packages: # rpm --define "USE_GL yes" ... +# or uncomment the following line. +# %define USE_GL yes Summary: X screen saver and locker Name: %{name} @@ -18,13 +27,13 @@ Copyright: BSD URL: http://www.jwz.org/xscreensaver Vendor: Jamie Zawinski Source: %{name}-%{version}.tar.gz -Buildroot: /var/tmp/%{name}-%{version}-root +Buildroot: %{_tmppath}/%{name}-%{version}-root %description A modular screen saver and locker for the X Window System. Highly customizable: allows the use of any program that can draw on the root window as a display mode. -More than 100 display modes are included in this package. +More than 120 display modes are included in this package. %{?USE_GL:See also the xscreensaver-gl package, which} %{?USE_GL:includes optional OpenGL display modes.} @@ -65,56 +74,65 @@ RPMOPTS="" %{!?USE_GL:RPMOPTS="$RPMOPTS --without-gl"} CFLAGS="$RPM_OPT_FLAGS" \ - ./configure --prefix=%{prefix} \ + ./configure --prefix=%{x11_prefix} \ --enable-subdir=../lib/xscreensaver \ + --without-setuid-hacks \ $RPMOPTS make %install -# This is a directory that "make install" won't make as needed -# (since Linux uses /etc/pam.d/* and Solaris uses /etc/pam.conf). +# Most xscreensaver executables go in the X bin directory (/usr/X11R6/bin/) +# but some of them (e.g., the control panel capplet) go in the GNOME bin +# directory instead (/usr/bin/). # -mkdir -p $RPM_BUILD_ROOT/etc/pam.d +mkdir -p $RPM_BUILD_ROOT%{gnome_prefix}/bin +mkdir -p $RPM_BUILD_ROOT%{gnome_ccdir} +mkdir -p $RPM_BUILD_ROOT%{gnome_paneldir} -# This is another (since "make install" doesn't try to install -# the xscreensaver.kss file unless $KDEDIR is set.) +# Likewise for KDE: the .kss file goes in the KDE bin directory (/usr/bin/). # -if [ -z "$KDEDIR" ]; then export KDEDIR=/usr; fi +export KDEDIR=%{kde_prefix} mkdir -p $RPM_BUILD_ROOT$KDEDIR/bin -# And two more for Gnome (same reason...) +# This is a directory that "make install" won't make as needed +# (since Linux uses /etc/pam.d/* and Solaris uses /etc/pam.conf). # -mkdir -p $RPM_BUILD_ROOT/usr/share/control-center/Desktop -mkdir -p $RPM_BUILD_ROOT/usr/share/gnome/apps/Settings/Desktop +mkdir -p $RPM_BUILD_ROOT/etc/pam.d make install_prefix=$RPM_BUILD_ROOT \ - AD_DIR=%{prefix}/lib/X11/app-defaults \ + AD_DIR=%{x11_prefix}/lib/X11/app-defaults \ + GNOME_BINDIR=%{gnome_prefix}/bin \ install-strip -# Make a pair of lists, of the GL and non-GL hacks. +# Make a pair of lists, of the GL and non-GL executables. # Do this by parsing the output of a dummy run of "make install" -# in the hacks/ and hacks/glx/ directories. +# in the driver/, hacks/ and hacks/glx/ directories. # list_files() { - make -s install_prefix=$RPM_BUILD_ROOT INSTALL=true install | + make -s install_prefix=$RPM_BUILD_ROOT INSTALL=true \ + GNOME_BINDIR=%{gnome_prefix}/bin \ + "$@" | sed -n -e 's@.* /\([^ ]*\)$@/\1@p' | sed -e "s@^$RPM_BUILD_ROOT@@" \ - -e "s@/bin/..@@" | + -e "s@/bin/\.\./@/@" | + sed -e 's@\(.*/man/.*\)@\1\*@' | sort } -( cd hacks ; list_files > $RPM_BUILD_DIR/xscreensaver-%{version}/hacks-non-gl ) -( cd hacks/glx ; list_files > $RPM_BUILD_DIR/xscreensaver-%{version}/hacks-gl ) - +( cd hacks ; list_files install ; \ + cd ../driver; list_files install-program ) \ + > $RPM_BUILD_DIR/xscreensaver-%{version}/exes-non-gl +( cd hacks/glx ; list_files install ) \ + > $RPM_BUILD_DIR/xscreensaver-%{version}/exes-gl # This line is redundant, except that it causes the "xscreensaver" # executable to be installed unstripped (while all others are stripped.) # You should install it this way so that jwz gets useful bug reports. # -install -m 4755 driver/xscreensaver $RPM_BUILD_ROOT%{prefix}/bin +install -m 4755 driver/xscreensaver $RPM_BUILD_ROOT%{x11_prefix}/bin # Even if we weren't compiled with PAM support, make sure to include # the PAM module file in the RPM anyway, just in case. @@ -126,25 +144,112 @@ install -m 4755 driver/xscreensaver $RPM_BUILD_ROOT%{prefix}/bin # chmod -R a+r,u+w,og-w $RPM_BUILD_ROOT + +# This is a tricky part... +# +# xscreensaver installs several files that are also installed by the +# "control-center" RPM. The versions from xscreensaver are better, +# and so should override control-center. But, the way RPM works, +# if the xscreensaver RPM contained those files, the end user would +# have to "--force" to make the xscreensaver RPM install. That's +# not something people are used to doing, so that's Bad. +# +# So instead, we rename the files so that they don't conflict with +# the control center. Then we have a "%post" script that creates +# symbolic links to our files. + +CCDIR=$RPM_BUILD_ROOT%{gnome_ccdir} +PADIR=$RPM_BUILD_ROOT%{gnome_paneldir} +CADIR=$RPM_BUILD_ROOT%{gnome_prefix}/bin +DESKF=screensaver-properties.desktop +CAPLT=screensaver-properties-capplet + +if [ -f $CCDIR/$DESKF ]; then + mv $CCDIR/$DESKF $CCDIR/x$DESKF + mv $PADIR/$DESKF $PADIR/x$DESKF + mv $CADIR/$CAPLT $CADIR/x$CAPLT +fi + +%post +# This part runs on the end user's system, when the RPM is installed. +# (See comment above, at end of "%install" section.) + +verbose=0 + +overwrite_links() { + dir="$1" + oname="$2" + nname="$3" + + # only do this if the file we're making a link *to* exists + # (i.e., was present in this rpm.) + # + if [ -f "$dir/$nname" ]; then + + # backup or delete the old version, if any. + # + existed=0 + if [ -f "$dir/$oname" ]; then + existed=1 + if [ -f "$dir/$oname.rpmsave" ]; then + rm -f "$dir/$oname" + if [ $verbose -gt 1 ]; then + echo "$dir/$oname.rpmsave already exists" >&2 + fi + else + mv "$dir/$oname" "$dir/$oname.rpmsave" + if [ $verbose -gt 1 ]; then + echo "saved $dir/$oname as $oname.rpmsave" >&2 + fi + fi + fi + + # install a relative symlink to the new name. + # + ln -s "$nname" "$dir/$oname" + if [ $verbose -ge 1 ]; then + if [ $existed = 1 ] ; then + echo "replaced $dir/$oname" >&2 + else + echo "created $dir/$oname" >&2 + fi + fi + fi +} + +CCDIR=%{gnome_ccdir} +PADIR=%{gnome_paneldir} +CADIR=%{gnome_prefix}/bin +DESKF=screensaver-properties.desktop +CAPLT=screensaver-properties-capplet + +overwrite_links $CCDIR $DESKF x$DESKF +overwrite_links $PADIR $DESKF x$DESKF +overwrite_links $CADIR $CAPLT x$CAPLT + + %clean if [ -d $RPM_BUILD_ROOT ]; then rm -r $RPM_BUILD_ROOT ; fi if [ -d $RPM_BUILD_ROOT-gl ]; then rm -r $RPM_BUILD_ROOT-gl ; fi -%files -f hacks-non-gl +%files -f exes-non-gl %defattr(-,root,root) # Files for the "xscreensaver" package: # %doc README README.debugging - %{prefix}/bin/* -%dir %{prefix}/lib/xscreensaver -%config %{prefix}/lib/X11/app-defaults/* - %{prefix}/man/man1/xscreensaver* +%dir %{x11_prefix}/lib/xscreensaver +%config %{x11_prefix}/lib/X11/app-defaults/* + %{x11_prefix}/man/man1/xscreensaver* /etc/pam.d/* -%config(missingok) /usr/bin/*.kss -%config(missingok) "/usr/share/control-center/Desktop/screensaver-properties.desktop" -%config(missingok) "/usr/share/gnome/apps/Settings/Desktop/screensaver-properties.desktop" + +%config(missingok) %{kde_prefix}/bin/*.kss + +%config(missingok) %{gnome_prefix}/bin/*-capplet +%config(missingok) %{gnome_ccdir}/*.desktop +%config(missingok) %{gnome_paneldir}/*.desktop +%config(missingok) %{gnome_icondir}/* # Files for the "xscreensaver-gl" package: # -%{?USE_GL:%files -f hacks-gl gl} +%{?USE_GL:%files -f exes-gl gl}