X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=a0a83181a109a3c0d3025b8344db918a70331f42;hb=5b8ed3c0e176e631dc29695f4bb222149f8ee747;hp=3afc2cf71d3a42a07c5a97d21229534ea50f7f11;hpb=8b4be1e111a115c8b80fae50ae012748d0d71005;p=packages%2Frpm.git diff --git a/rpm.macros b/rpm.macros index 3afc2cf..a0a8318 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,7 +11,7 @@ %_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 @@ -19,6 +20,7 @@ %debugcflags -O0 -g -Wall %rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags}%{?debuginfocflags} +%rpmcxxflags %{rpmcflags} -fvisibility-inlines-hidden %rpmldflags %{nil} # kernel compiler @@ -46,13 +48,13 @@ %__automake automake -a -c -f --foreign %__autoconf autoconf %{?debug:-Wall} -%dependencytracking " " +%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 ; } \ @@ -80,7 +82,7 @@ %configure {./configure \ LDFLAGS="${LDFLAGS:-%rpmldflags}" \ CFLAGS="${CFLAGS:-%rpmcflags}" \ - CXXFLAGS="${CXXFLAGS:-%rpmcflags}" \ + CXXFLAGS="${CXXFLAGS:-%rpmcxxflags}" \ FFLAGS="${FFLAGS:-%rpmcflags}" \ CPPFLAGS="${CPPFLAGS:-}" \ %{?__cc:CC="%{__cc}"} \ @@ -110,12 +112,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}}}\ @@ -123,6 +127,7 @@ unset DISPLAY ||:\ LANG=C\ export LANG\ unset DISPLAY ||:\ +unset LINGUAS ||:\ %{nil} # ------------------------------------------------------------------------ @@ -177,11 +182,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 @@ -198,6 +201,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") @@ -214,26 +220,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 'kernel-up = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | grep -vE "(is not|no such)") +%releq_kernel_smp() %(LC_ALL="C" rpm -qf --qf 'kernel-smp = %%{epoch}:%%{version}-%%{release}\\n' %{_kernelsrcdir}/include/linux/version.h | sed -e 's/ (none):/ /' | grep -vE "(is not|no such)") +%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):/ /' | 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):/ /' | 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_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 --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_rpmvr %(LC_ALL="C" rpm -qf %{_kernelsrcdir}/include/linux/fs.h --queryformat "%{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 --' \ @@ -304,7 +315,7 @@ 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 | \ +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= ; \ @@ -338,8 +349,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; \ @@ -350,15 +361,21 @@ 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_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 \ -} + /usr/bin/gconftool-2 --makefile-install-rule %{?1}%{!?1:/etc/gconf/schemas/*.schemas} > /dev/null \ + %{nil} + +%gconf_schema_uninstall() \ + umask 022; \ + GCONF_CONFIG_SOURCE="xml:readwrite:/etc/gconf/gconf.xml.defaults" \ + /usr/bin/gconftool-2 --makefile-uninstall-rule %{?1} > /dev/null \ + %{nil} #----------------------------------------------------------------- # post %install sequence: @@ -419,11 +436,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: python(abi) = %py_ver %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' -exec 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 \ @@ -467,3 +505,35 @@ fi; \ # %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 +