X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=a1aa4b7c80092e1a204d9ab1d1885d60d8aadc8a;hb=15ee971e7caf60b4054d4b82246d25e47fb2c24c;hp=f4f7e1c2fe46da2101c1215305b28038e12297b4;hpb=b5b201297cee140d68038a19d87167f3958e17c2;p=packages%2Frpm.git diff --git a/rpm.macros b/rpm.macros index f4f7e1c..a1aa4b7 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,6 +1,7 @@ # PLD rpm macros # other macros +%epoch 0 %_enable_debug_packages 1 %__id @__ID@ @@ -10,18 +11,18 @@ %_fixowner [ `%{__id_u}` = '0' ] && %{__chown_Rhf} root:@ROOT_GROUP@ %_fixgroup true -%_fixperms %{__chmod} -Rf @FIXPERMS@ +%_fixperms %{__chmod} -Rf @FIXPERMS@ %_topdir %(echo $HOME)/rpm #----------------------------------------------------------------- # CFLAGS and LDFLAGS used to build -%if %{_enable_debug_packages}%{!?_enable_debug_packages:0} -%debuginfocflags -ggdb -Wall -%endif +%debuginfocflags %{expand:%%define __dic_%{?_enable_debug_packages} 1}%{?__dic_1: -ggdb}%{expand:%%undefine __dic_%{?_enable_debug_packages}} %debugcflags -O0 -g -Wall -%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags}%{?debuginfocflags:%debuginfocflags} +%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags}%{?debuginfocflags} +%rpmcxxflags %{rpmcflags} %rpmldflags %{nil} +# %rpmldflags -Wl,--as-needed # kernel compiler %kgcc gcc @@ -29,7 +30,10 @@ # Build system path macros. # -%__libtoolize libtoolize --copy --force +%__autoconf autoconf %{?debug:-Wall} +%__automake automake -a -c -f --foreign +%__autopoint autopoint --force + %__gettextize { \ if ! gettextize --version | grep -q '0\.10\.' ; then \ if grep -qs 'AM_GNU_GETTEXT.*external' configure.{ac,in} ; then \ @@ -44,16 +48,20 @@ gettextize --copy --force; \ fi; \ } -%__autopoint autopoint --force -%__automake automake -a -c -f --foreign -%__autoconf autoconf %{?debug:-Wall} +%__glib_gettextize glib-gettextize --copy --force +%__gnome_doc_common gnome-doc-common --copy +%__gtkdocize gtkdocize --copy +%__intltoolize intltoolize --copy --force +%__libtoolize libtoolize --copy --force + +%dependencytracking %{nil} #----------------------------------------------------------------- %configure2_13 { \ if [ -n "$LINGUAS" ]; then unset LINGUAS; fi; \ LDFLAGS="${LDFLAGS:-%rpmldflags}" ; export LDFLAGS ; \ CFLAGS="${CFLAGS:-%rpmcflags}" ; export CFLAGS ; \ - CXXFLAGS="${CXXFLAGS:-%rpmcflags}" ; export CXXFLAGS ; \ + CXXFLAGS="${CXXFLAGS:-%rpmcxxflags}" ; export CXXFLAGS ; \ FFLAGS="${FFLAGS:-%rpmcflags}" ; export FFLAGS ; \ CPPFLAGS="${CPPFLAGS:-}" ; export CPPFLAGS ; \ %{?__cc:CC="%{__cc}" ; export CC ; } \ @@ -74,13 +82,17 @@ --mandir=%{_mandir} \ --infodir=%{_infodir} \ --x-libraries=/usr/X11R6/%{_lib} \ + %{dependencytracking} \ } #---------------------------------------------------------------- +%global configure_cache 0 +%configure_cache_file %{buildroot}.configure.cache + %configure {./configure \ LDFLAGS="${LDFLAGS:-%rpmldflags}" \ CFLAGS="${CFLAGS:-%rpmcflags}" \ - CXXFLAGS="${CXXFLAGS:-%rpmcflags}" \ + CXXFLAGS="${CXXFLAGS:-%rpmcxxflags}" \ FFLAGS="${FFLAGS:-%rpmcflags}" \ CPPFLAGS="${CPPFLAGS:-}" \ %{?__cc:CC="%{__cc}"} \ @@ -100,6 +112,8 @@ --mandir=%{_mandir} \ --infodir=%{_infodir} \ --x-libraries=/usr/X11R6/%{_lib} \ + %{dependencytracking} \ + %{?configure_cache:--cache-file=%{configure_cache_file:-%{buildroot}.configure.cache}} \ } # ------------------------------------------------------------------------ @@ -109,12 +123,14 @@ LANG=C\ export LANG\ unset DISPLAY ||:\ +unset LINGUAS ||:\ %{nil} %build %%build\ LANG=C\ export LANG\ unset DISPLAY ||:\ +unset LINGUAS ||:\ %{nil} %install %{?_enable_debug_packages:%{?buildsubdir:%{debug_package}}}\ @@ -122,6 +138,7 @@ unset DISPLAY ||:\ LANG=C\ export LANG\ unset DISPLAY ||:\ +unset LINGUAS ||:\ %{nil} # ------------------------------------------------------------------------ @@ -176,11 +193,9 @@ unset DISPLAY ||:\ # Location of pkgconfig files %_pkgconfigdir /usr/%{_lib}/pkgconfig -# Location of top applink dir -%_applnkdir /usr/X11R6/share/applnk - # Location of desktop files %_desktopdir /usr/share/applications +%_applnkdir ERROR:_applnkdir_is_obsolete_use_desktopdir_instead # Location of pixmaps for applnk/desktop files %_pixmapsdir /usr/share/pixmaps @@ -197,6 +212,9 @@ unset DISPLAY ||:\ # Location of KDE documentation %_kdedocdir %{_defaultdocdir}/kde/HTML +# unsermake script +%__unsermake /usr/share/unsermake/unsermake + # Current date %date %(LC_ALL="C" date +"%a %b %d %Y") @@ -213,26 +231,31 @@ unset DISPLAY ||:\ %_rpmfilename %%{NAME}-%%{VERSION}-%%{RELEASE}%{?debug:dbg}.%%{ARCH}.rpm # Requires name = version-release -%requires_releq() %(LC_ALL="C" echo '%*' | xargs -r rpm -q --qf 'Requires: %%{name} = %%{epoch}:%%{version}-%%{release}\\n' | sed -e 's/ (none):/ /' -e 's/ 0:/ /' | grep -v "is not") -%requires_releq_kernel_up() %(LC_ALL="C" rpm -qf --qf 'Prereq: kernel-up = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' -e 's/ 0:/ /' | grep -vE "(is not|no such)") -%requires_releq_kernel_smp() %(LC_ALL="C" rpm -qf --qf 'Prereq: kernel-smp = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' -e 's/ 0:/ /' | grep -vE "(is not|no such)") -%requires_eq_to() %(LC_ALL="C" rpm -q --qf 'Requires: %1 = %%{epoch}:%%{version}\\n' %2 | sed -e 's/ (none):/ /' -e 's/ 0:/ /' | grep -v "is not") +%requires_releq() %(LC_ALL="C" echo '%*' | xargs -r rpm -q --qf 'Requires: %%{name} = %%{epoch}:%%{version}-%%{release}\\n' | sed -e 's/ (none):/ /' | grep -v "is not") + +%releq_kernel_up() %(LC_ALL="C" rpm -qf --qf '%%{name}-up = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | sed -e 's:-headers::' | grep -vE "(is not|no such)") +%releq_kernel_smp() %(LC_ALL="C" rpm -qf --qf '%%{name}-smp = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | sed -e 's:-headers::' | grep -vE "(is not|no such)") +%requires_releq_kernel_up() %(LC_ALL="C" rpm -qf --qf 'PreReq: %%{name}-up = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | sed -e 's:-headers::' | grep -vE "(is not|no such)") +%requires_releq_kernel_smp() %(LC_ALL="C" rpm -qf --qf 'PreReq: %%{name}-smp = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | sed -e 's:-headers::' | grep -vE "(is not|no such)") + +%requires_eq_to() %(LC_ALL="C" rpm -q --qf 'Requires: %1 = %%{epoch}:%%{version}\\n' %2 | sed -e 's/ (none):/ /' | grep -v "is not") %apache_modules_api %(awk '/#define MODULE_MAGIC_NUMBER_MAJOR/ {print $3}' /usr/include/apache/ap_mmn.h 2>/dev/null || echo ERROR) # kernel version-release handling -%__kernel_ver %([ -f %{_kernelsrcdir}/include/linux/version.h ] && (grep UTS_RELEASE %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | cut -d'"' -f2) || (awk '/^VERSION/ { ver = $0; gsub(/VERSION.*=/, NIL, ver); } /^PATCHLEVEL/ { plev = $0; gsub(/PATCHLEVEL.*=/, NIL, plev); } /^SUBLEVEL/ { slev = $0; gsub(/SUBLEVEL.*=/, NIL, slev); } END { printf("%d.%d.%d", ver, plev, slev); }' %{_kernelsrcdir}/Makefile 2> /dev/null)) -%__kernel_rel %(LC_ALL="C" rpm -qf %{_kernelsrcdir}/include/linux/fs.h --queryformat "%{RELEASE}" | grep -v "is not") -%_kernel_ver %(echo %{__kernel_ver}%{!?_without_dist_kernel:-%{__kernel_rel}}) -%_kernel_ver_str %(echo %{_kernel_ver} | sed s/-/_/g) +%__kernel_ver %([ -f %{_kernelsrcdir}/include/linux/version.h ] && (grep UTS_RELEASE %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | head -n 1 | cut -d'"' -f2) || (awk '/^VERSION/ { ver = $0; gsub(/VERSION.*=/, NIL, ver); } /^PATCHLEVEL/ { plev = $0; gsub(/PATCHLEVEL.*=/, NIL, plev); } /^SUBLEVEL/ { slev = $0; gsub(/SUBLEVEL.*=/, NIL, slev); } /^EXTRAVERSION/ { ever = $0; gsub(/EXTRAVERSION.*=/, NIL, ever); gsub(/ /, NIL, ever); } END { printf("%d.%d.%d%s", ver, plev, slev, ever); }' %{_kernelsrcdir}/Makefile 2> /dev/null)) +%__kernel_rel %(LC_ALL="C" rpm -qf %{_kernelsrcdir}/include/linux/fs.h 2>/dev/null --qf "%{RELEASE}" | grep -v "is not") +%__kernel_rpmvr %(LC_ALL="C" rpm -qf %{_kernelsrcdir}/include/linux/fs.h 2>/dev/null --qf "%{VERSION}-%{RELEASE}" | grep -v "is not") +%_kernel_ver %{__kernel_ver}%{?with_dist_kernel:%(echo %{__kernel_ver} | grep -q -e - || echo -%{__kernel_rel})} +%_kernel_ver_str %(echo %{!?_without_dist_kernel:%{__kernel_rpmvr}}%{?_without_dist_kernel:%{__kernel_ver}} | sed -e 's/-/_/g') # sgml macros -%xmlcat_add() /usr/bin/xmlcatalog --noout --add nextCatalog \"\" %1 /etc/xml/catalog -%xmlcat_del() /usr/bin/xmlcatalog --noout --del %1 /etc/xml/catalog +%xmlcat_add() /usr/bin/xmlcatalog --noout --add nextCatalog \"\" %1 /etc/xml/catalog ; +%xmlcat_del() /usr/bin/xmlcatalog --noout --del %1 /etc/xml/catalog ; %xmlcat_add_rewrite /usr/bin/xmlcatalog --noout --add rewriteSystem -%xmlcat_create() /usr/bin/xmlcatalog --noout --create %1 -%sgmlcat_add() /usr/bin/install-catalog --add %1 %2 > /dev/null -%sgmlcat_del() /usr/bin/install-catalog --remove %1 %2 > /dev/null +%xmlcat_create() /usr/bin/xmlcatalog --noout --create %1 ; +%sgmlcat_add() /usr/bin/install-catalog --add %1 %2 > /dev/null ; +%sgmlcat_del() /usr/bin/install-catalog --remove %1 %2 > /dev/null ; %docbook_sgmlcat_fix() { for l in \ '' \ ' -- default decl --' \ @@ -303,8 +326,8 @@ unset DISPLAY ||:\ %{?verbose:set -x;} \ if [ -d "$RPM_BUILD_ROOT" ]; then \ echo "Remove RPATH from executable binaries and shared object files."; \ -find $RPM_BUILD_ROOT -type f ! -regex ".*ld-[0-9.]*so.*" %{?_noautochrpath:! -regex "%{_noautochrpath}"} | xargs -r file | \ - awk '/ELF.*(executable|shared object)/ {print $1}' | cut -d: -f1 | \ +find $RPM_BUILD_ROOT -type f ! -regex ".*ld-[0-9.]*so.*" ! -regex ".*/usr/lib[0-9]*/debug/.*" %{?_noautochrpath:! -regex "%{_noautochrpath}"} | xargs -r file | \ + awk '/ELF.*(executable.*dynamically linked|shared object)/ {print $1}' | cut -d: -f1 | \ while read file ; do \ rpath= ; \ chmod u+w "$file"; \ @@ -337,8 +360,8 @@ fi; } \ if [ -d "$RPM_BUILD_ROOT" ]; then \ echo "Compress kernel modules if any."; \ if test -d $RPM_BUILD_ROOT/lib/modules ; then \ - find $RPM_BUILD_ROOT/lib/modules -name \*o -type f -print | \ - xargs -r %{__gzip} -9nf; \ + find $RPM_BUILD_ROOT/lib/modules -name \*o -type f -print | \ + xargs -r %{__gzip} -9nf; \ find $RPM_BUILD_ROOT/lib/modules -name \*o -type l -printf "%p %l\n" | \ while read a b; do ln -sf $b.gz $a.gz; rm -f $a; done; \ fi; \ @@ -349,15 +372,62 @@ echo "Compress kernel modules if any."; \ %_binary_payload w9.bzdio #----------------------------------------------------------------- -# Update all GConf2 schemas +# Update GConf2 schemas # # Requires: GConf2 # -%gconf_schema_install { umask 022; \ - GCONF_CONFIG_SOURCE="xml:readwrite:/etc/gconf/gconf.xml.defaults" \ - /usr/bin/gconftool-2 --makefile-install-rule \ - /etc/gconf/schemas/*.schemas > /dev/null \ -} +%gconf_schema_install() \ + umask 022; \ + GCONF_CONFIG_SOURCE="xml:readwrite:/etc/gconf/gconf.xml.defaults" /usr/bin/gconftool-2 --makefile-install-rule /etc/gconf/schemas/%{?1}%{!?1:*.schemas} > /dev/null \ + %{nil} + +%gconf_schema_uninstall() \ +if [ $1 = 0 ]; then \ + umask 022; \ + GCONF_CONFIG_SOURCE="xml:readwrite:/etc/gconf/gconf.xml.defaults" /usr/bin/gconftool-2 --makefile-uninstall-rule /etc/gconf/schemas/%{?1} > /dev/null \ +fi \ +%{nil} + +#----------------------------------------------------------------- +# Update desktop MIME database +# requries: desktop-file-utils +# +%update_desktop_database_post() {{ \ + umask 022; \ + /usr/bin/update-desktop-database; \ +}} + +%update_desktop_database_postun() {{ \ +if [ $1 = 0 ]; then \ + umask 022; \ + /usr/bin/update-desktop-database; \ +fi \ +}} + +#----------------------------------------------------------------- +# Update scrollkeeper database +# requires: scrollkeeper +# +%scrollkeeper_update_post() \ + /usr/bin/scrollkeeper-update -q; \ + %{nil} + +%scrollkeeper_update_postun() \ +if [ $1 = 0 ]; then \ + /usr/bin/scrollkeeper-update -q; \ +fi \ +%{nil} + +#----------------------------------------------------------------- +# Run ldconfig after installing/deinstalling libraries +# +%ldconfig_post() \ + /sbin/ldconfig; \ + %{nil} + +%ldconfig_postun() \ + /sbin/ldconfig; \ + %{nil} #----------------------------------------------------------------- # post %install sequence: @@ -370,11 +440,11 @@ echo "Compress kernel modules if any."; \ # Requires/Provides automation # exceptions system by Jacek Konieczny # -%_noautoreqfiles %(sed -e s'/#.*//' /etc/rpm/noautoreqfiles) -%_noautoprovfiles %(sed -e s'/#.*//' /etc/rpm/noautoprovfiles) -%_noautoreq %(sed -e s'/#.*//' /etc/rpm/noautoreq) -%_noautoreqdep %(sed -e s'/#.*//' /etc/rpm/noautoreqdep) -%_noautoprov %(sed -e s'/#.*//' /etc/rpm/noautoprov) +%__noautoreqfiles %(sed -e s'/#.*//' /etc/rpm/noautoreqfiles)%{?_noautoreqfiles: %{_noautoreqfiles}} +%__noautoprovfiles %(sed -e s'/#.*//' /etc/rpm/noautoprovfiles)%{?_noautoprovfiles: %{_noautoprovfiles}} +%__noautoreq %(sed -e s'/#.*//' /etc/rpm/noautoreq)%{?_noautoreq: %{_noautoreq}} +%__noautoreqdep %(sed -e s'/#.*//' /etc/rpm/noautoreqdep)%{?_noautoreqdep: %{_noautoreqdep}} +%__noautoprov %(sed -e s'/#.*//' /etc/rpm/noautoprov)%{?_noautoprov: %{_noautoprov}} #%_noautocompressdoc %{nil} # %_missing_doc_files_terminate_build 1%{nil} @@ -418,11 +488,32 @@ echo "Compress kernel modules if any."; \ %py_ocomp python -O -c "import compileall; import sys; compileall.compile_dir(sys.argv[1], ddir=sys.argv[1][len('$RPM_BUILD_ROOT'):])" # Software written in Python language require Python with main version -# unchanged -%pyrequires_eq() Requires: %1 >= 1:%py_ver %1 < 1:%(echo `python -c "import sys; import string; ver=sys.version[:3].split('.'); ver[1]=str(int(ver[1])+1); print string.join(ver, '.')"`) +%pyrequires_eq() Requires: %1 + + +# Hardlink binary identical .pyc and .pyo files +# (idea by glen pld-linux org) +%__spec_install_post_py_hardlink {\ +%{!?no_install_post_py_hardlink: \ +[ ! -d "$RPM_BUILD_ROOT" ] || find "$RPM_BUILD_ROOT" -name '*.pyc' | while read a; do \ + b="$(echo $a|sed -e 's/.pyc$/.pyo/')"; \ + if cmp -s "$a" "$b"; then \ + ln -f "$a" "$b"; \ + fi; \ +done \ +} } + +# remove python sources, so that check-files won't complain +# (idea by glen pld-linux org) +%py_postclean() \ +for d in %{py_sitescriptdir} %{py_sitedir}; do \ + [ ! -d "$RPM_BUILD_ROOT$d" ] || find "$RPM_BUILD_ROOT$d" -name '*.py' -print0 | xargs -0r -l512 rm;\ +done \ +%{nil} # depmod macro %depmod() { \ +umask 022; \ if [ -e /boot/System.map-%1 ]; then \ /sbin/depmod -a -F /boot/System.map-%1 %1; \ else \ @@ -446,4 +537,240 @@ fi; \ %xmms_effect_plugindir %(xmms-config --effect-plugin-dir) %xmms_general_plugindir %(xmms-config --general-plugin-dir) -%_target_base_arch %(echo %{_target_cpu} | sed 's/i.86/i386/;s/athlon/i386/;s/pentium./i386/;s/amd64/x86_64/') +%_target_base_arch %(echo %{_target_cpu} | sed 's/i.86/i386/;s/athlon/i386/;s/pentium./i386/;s/amd64/x86_64/;s/ia32e/x86_64/') + +%x8664 x86_64 amd64 ia32e + +# user/group checking macros +# +# Usage: +# %userremove myuser +# +%userremove /usr/lib/rpm/user_group.sh user del +%groupremove /usr/lib/rpm/user_group.sh group del +# +# Usage: +# if %usertestrm myuser; then +# /usr/sbin/userdel -r myuser +# Note: +# use these macros only if you need to call userdel/groupdel with +# a non-standard option or take an extra action; otherwise use the +# %userremove/%groupremove macros +# +%usertestrm /usr/lib/rpm/user_group.sh user testrm +%grouptestrm /usr/lib/rpm/user_group.sh group testrm +# user group membership management macros +# +# Usage: +# %addusertogroup myuser agroup +# +%addusertogroup /usr/lib/rpm/user_group.sh user addtogroup + +# banner support (useful in {pre,post}{,un} and triggers) +# +# Usage: +# %banner name [-a] [-e] [-n] [-tn] <= n; default n=5 +%banner(aent:) \ +RPM_SCRIPTVERBOSITY=5 \ +[ -r /etc/sysconfig/rpm ] && . /etc/sysconfig/rpm \ +if [ -x /usr/bin/banner.sh ]; then \ + CMD="/usr/bin/banner.sh %{-e:--stderr} %{!-n:$([ $RPM_SCRIPTVERBOSITY -ge %{-t:%{-t*}}%{!-t:5} ] && echo -s)} %{!-a:-m}%{-a:-M} %1" \ +else \ + CMD="cat%{-e: >&2}" \ +fi \ +$CMD %2%{?3: %3} \ +%nil + +# useradd/groupadd macros written by glen@pld-linux.org. +# All rights reserved. Permission to copy is hereby granted.. yada, yada, yada +# +# Usage: +# %useradd [-P package] [-u uid] [-d home_dir] [-s shell] [-c comment] +# [-g initial_group] [-G group[,...]] login +# +# -u uid. REQUIRED +# -g gid/group. REQUIRED +# -s defaults to /bin/false +# -d defaults to /usr/share/empty +# -c No default +# -r is accepted but ignored (it's always set) +# rpm specific flags +# -P package name. defaults to %{name} +# +%useradd(c:d:e:f:g:G:Mmk:op:s:u:rP:) \ +%{!-u:%{error:useradd: Required argument -u missing}} \ +%{!-g:%{error:useradd: Required argument -g missing}} \ +%{!?1:%{error:useradd: Required parameter login missing}} \ +if [ -n "`/bin/id -u %{expand:%{%{#}}} 2>/dev/null`" ]; then \ + if [ "`/bin/id -u %{expand:%{%{#}}}`" != "%{-u*}" ]; then \ + echo "Error: user %{expand:%{%{#}}} doesn't have uid=%{-u*}. Correct this before installing %{-P*}%{!?-P:%{name}}." 1>&2 \ + exit 1 \ + fi \ +else \ + echo "Adding user %{expand:%{%{#}}} UID=%{-u*}." \ + /usr/sbin/useradd \\\ + -u %{-u*} \\\ + -r \\\ + -d %{-d*}%{!-d:/usr/share/empty} \\\ + -s %{-s*}%{!-s:/bin/false} \\\ + %{-c:-c "%(set -- %{-c*} %{*}; echo $1)"}\\\ + -g %{-g*} \\\ + %{-M} \\\ + %{-G:-G %{-G*}} \\\ + %{expand:%{%{#}}} 1>&2 \ +fi; + +# Usage: +# %groupadd [-P package] [-g gid] group +# +# -g gid. REQUIRED +# +# Sample: +# %groupadd -P %{name}-base -g %{gid} %{name} + +%groupadd(g:P:rfo) \ +%{!-g:%{error:groupadd: Required argument -g missing}} \ +%{!?1:%{error:groupadd: Required parameter group missing}} \ +if [ -n "`/usr/bin/getgid %{1}`" ]; then \ + if [ "`/usr/bin/getgid %{1}`" != "%{-g*}" ]; then \ + echo "Error: group %{1} doesn't have gid=%{-g*}. Correct this before installing %{-P*}%{!?-P:%{name}}." 1>&2 \ + exit 1 \ + fi \ +else \ + echo "Adding group %{1} GID=%{-g*}." \ + /usr/sbin/groupadd -g %{-g*} -r %{1} 1>&2 \ +fi; + +# apache_config_{install/uninstall} macros written by glen@pld-linux.org. +# All rights reserved. Permission to copy is hereby granted.. yada, yada, yada +# +# The config is installed/removed inside trigger, this means that you can any +# time install apache1 or apache package and the configuration file is updated. +# if you don't need the config for various reason for specific apache, just +# remove the symlink from apache config directory. the trigger will not put the +# config again to that version of apache. In other words the config is linked +# to apache config directory on first install of PACKAGE or apache. +# +# should be called in trigger body: +# %triggerin -- apache1 >= 1.3.33-2 +# %apache_config_install -v 1 +# +# Add package's apache config to apache config. +# +# Usage: +# %apache_config_install -v {1|2} -c %{_sysconfdir}/apache-%{name}.conf -n 99 +# +# -v REQUIRED: specify apache version. can be 1 or 2. +# -c OPTIONAL: specify full path to PACKAGE's config. Defaults to %{_sysconfdir}/apache-%{name}.conf. +# -n OPTIONAL: specify config "slot". defaults to 99 +# +# Internal macros. don't use ;). +# expands apache config dir by apache version at build time. +%__apache_confdir() %(if [ %{1} = 1 ]; then echo /etc/apache/conf.d; elif [ %{1} = 2 ]; then echo /etc/httpd/httpd.conf; else echo >&2 Unknown apache version specified; fi) +# expands apache service name by apache version at build time. +%__apache_svcname() %(if [ %{1} = 1 ]; then echo apache; elif [ %{1} = 2 ]; then echo httpd; else echo >&2 Unknown apache version specified; fi) + +%apache_config_install(v:c:n:) \ +%{!-v:%{error:apache_config_install: Required argument -v missing}} \ +%{?debug:set -x; echo "apache_config_install:%{-v*} %{name}-%{version}-%{release} 1:[$1]; 2:[$2]"} \ +if [ "$1" = "1" ] && [ "$2" = "1" ] && [ -d %{__apache_confdir %{-v*}} ]; then\ + ln -sf %{-c*}%{!-c:%{_sysconfdir}/apache-%{name}.conf} %{__apache_confdir %{-v*}}/%{-n*}%{!-n:99}_%{name}.conf\ +fi\ +# reload apache if the config symlink is there\ +if [ -L %{__apache_confdir %{-v*}}/%{-n*}%{!-n:99}_%{name}.conf ]; then\ + # additionally don't reload if target package (the webserver) is upgraded, as webserver is restarted anyway in %post \ + if [ "$2" != "2" ] && [ -f /var/lock/subsys/%{__apache_svcname %{-v*}} ]; then\ + /etc/rc.d/init.d/%{__apache_svcname %{-v*}} reload 1>&2\ + fi\ +fi\ +%{nil} + +# Remove package's apache config from apache config. +# +# Usage: +# %apache_config_uninstall -v {1|2} -n 99 +# +# -v REQUIRED: specify apache version. can be 1 or 2. +# -n OPTIONAL: specify config "slot". defaults to 99 +%apache_config_uninstall(v:n:) \ +%{!-v:%{error:apache_config_uninstall: Required argument -v missing}} \ +%{?debug:set -x; echo "apache_config_uninstall:%{-v*} %{name}-%{version}-%{release}: 1:[$1]; 2:[$2]"} \ +# remove link if either of the packages are gone \ +if [ "$1" = "0" ] || [ "$2" = "0" ]; then \ + if [ -L %{__apache_confdir %{-v*}}/%{-n*}%{!-n:99}_%{name}.conf ]; then \ + rm -f %{__apache_confdir %{-v*}}/%{-n*}%{!-n:99}_%{name}.conf \ + if [ -f /var/lock/subsys/%{__apache_svcname %{-v*}} ]; then \ + /etc/rc.d/init.d/%{__apache_svcname %{-v*}} reload 1>&2 \ + fi \ + fi \ +fi \ +%{nil} + +# see browser-plugins.spec / template-browser-plugin.spec +# written by glen@pld-linux.org. +%nsplugin_install(d:) { \ +# create link if it's first install of either of the packages \ +if [ "$1" = "1" ] && [ "$2" = "1" ]; then \ +( \ +%( \ + for file in %{*}; do \ + echo echo Installing $file to %{-d*}; \ + echo "ln -sf %{_libdir}/browser-plugins/$file %{-d*};"; \ + done ) \ +) | ( %banner -t 5 -e %{name}-in ); fi; \ +} + +%nsplugin_uninstall(d:) { \ +# remove link if either of the packages are gone \ +if [ "$1" = "0" ] || [ "$2" = "0" ]; then \ +( \ +%( \ + for file in %{*}; do \ + echo echo Removing $file from %{-d*}; \ + echo "rm -f %{-d*}/$file;"; \ + done ) \ +) | ( %banner -t 5 -e %{name}-un ); fi; \ +} + +# service macro. +# +# calls usual service restart on package %post, but skips the restart if +# administrator has disabled automatic service restarts in either global +# /etc/sysconfig/rpm or per service /etc/sysconfig/SERVICE file. +# +# written by glen@pld-linux.org. +# All rights reserved. Permission to copy is hereby granted.. yada, yada, yada +# +# Usage: +# %service [-q] SERVICE ACTION +# +# -q be silent when service isn't started (for postun scriplets) +# +%service(q) {{ \ +# we use function, not to globber namespace with useless variables \ +skip_auto_restart() { \ + . /etc/sysconfig/rpm; # global setting \ + [ -f /etc/sysconfig/%1 ] && . /etc/sysconfig/%1; # per service setting \ + echo ${RPM_SKIP_AUTO_RESTART:-no}; \ +}; \ +if [ -f /var/lock/subsys/%1 ]; then \ + if [ $(skip_auto_restart) = no ]; then \ + /etc/rc.d/init.d/%1 %2 1>&2; \ + else \ + echo 'Run "/etc/rc.d/init.d/%1 %2" to %2 %1 service.'; \ + fi \ +else \ + %{!-q:echo 'Run "/etc/rc.d/init.d/%1 start" to start %1 service.';} \ + %{-q::;} \ +fi }; } +