X-Git-Url: http://git.pld-linux.org/?p=packages%2Frpm-build-macros.git;a=blobdiff_plain;f=rpm.macros;h=ddef34f0436ed4af8cf6b31f3fd36d57c82ffa7f;hp=bc79622056ff1e59b3f3e7f6e65d34ca691b6fb3;hb=ae6cd647e72155e9199deb0c0076374e18db56d8;hpb=0fc5cff87625cdad097d850ca4dc0f03c18b82fc diff --git a/rpm.macros b/rpm.macros index bc79622..ddef34f 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,20 +1,27 @@ # PLD rpm macros +# other macros +%epoch 0 +%_enable_debug_packages 1 + %__id @__ID@ %__id_u %{__id} -u %__chown_Rhf @__CHOWN_RHF@ %__chgrp_Rhf @__CHGRP_RHF@ -%_fixowner [ `%{__id_u}` = '0' ] && %{__chown_Rhf} root.@ROOT_GROUP@ +%_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 +%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} -%rpmldflags %{!?debug:-s} +%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags}%{?debuginfocflags} +%rpmcxxflags %{rpmcflags} -fvisibility-inlines-hidden +%rpmldflags %{nil} # kernel compiler %kgcc gcc @@ -22,7 +29,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 \ @@ -37,20 +47,24 @@ 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 ; } \ - %{?__cxx:CXX=%{__cxx} ; export CXX ; } \ + %{?__cc:CC="%{__cc}" ; export CC ; } \ + %{?__cxx:CXX="%{__cxx}" ; export CXX ; } \ %{?configuredir:%{configuredir}}%{!?configuredir:.}/configure \ --host=%{_target_platform} \ --prefix=%{_prefix} \ @@ -66,17 +80,19 @@ --sharedstatedir=%{_sharedstatedir} \ --mandir=%{_mandir} \ --infodir=%{_infodir} \ + --x-libraries=/usr/X11R6/%{_lib} \ + %{dependencytracking} \ } #---------------------------------------------------------------- %configure {./configure \ LDFLAGS="${LDFLAGS:-%rpmldflags}" \ CFLAGS="${CFLAGS:-%rpmcflags}" \ - CXXFLAGS="${CXXFLAGS:-%rpmcflags}" \ + CXXFLAGS="${CXXFLAGS:-%rpmcxxflags}" \ FFLAGS="${FFLAGS:-%rpmcflags}" \ CPPFLAGS="${CPPFLAGS:-}" \ - %{?__cc:CC=%{__cc}} \ - %{?__cxx:CXX=%{__cxx}} \ + %{?__cc:CC="%{__cc}"} \ + %{?__cxx:CXX="%{__cxx}"} \ --build=%{_target_platform} \ --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ @@ -91,8 +107,35 @@ --sharedstatedir=%{_sharedstatedir} \ --mandir=%{_mandir} \ --infodir=%{_infodir} \ + --x-libraries=/usr/X11R6/%{_lib} \ + %{dependencytracking} \ } +# ------------------------------------------------------------------------ +# Overloading of some basic macros +%prep \ +%%prep\ +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}}}\ +%%install\ +LANG=C\ +export LANG\ +unset DISPLAY ||:\ +unset LINGUAS ||:\ +%{nil} + # ------------------------------------------------------------------------ # Conditional build stuff. @@ -101,18 +144,10 @@ %defined() %{expand:%%{?%{1}:1}%%{!?%{1}:0}} %undefined() %{expand:%%{?%{1}:0}%%{!?%{1}:1}} -# Shorthand for %if %{defined ...} -%ifdef() %if %{expand:%%{?%{1}:1}%%{!?%{1}:0}} -%ifndef() %if %{expand:%%{?%{1}:0}%%{!?%{1}:1}} - # Shorthand for %{defined with_...} %with() %{expand:%%{?with_%{1}:1}%%{!?with_%{1}:0}} %without() %{expand:%%{?with_%{1}:0}%%{!?with_%{1}:1}} -# Shorthand for %if %{with ...} -%ifwith() %if %{expand:%%{?with_%{1}:1}%%{!?with_%{1}:0}} -%ifwithout() %if %{expand:%%{?with_%{1}:0}%%{!?with_%{1}:1}} - # Handle conditional builds. %bcond_with is for case when feature is # default off and needs to be activated with --with ... command line # switch. %bcond_without is for the dual case. @@ -126,10 +161,10 @@ # # %bcond_with extra_fonts # %bcond_without static -# %ifdef with_extra_fonts +# %if %{with extra_fonts} # ... # %endif -# %ifdef with_static +# %ifdef %{with static} # ... # %endif # %{?with_static: ... } @@ -151,23 +186,30 @@ %_omf_dest_dir %(scrollkeeper-config --omfdir) # Location of pkgconfig files -%_pkgconfigdir /usr/lib/pkgconfig - -# Location of top applink dir -%_applnkdir /usr/X11R6/share/applnk +%_pkgconfigdir /usr/%{_lib}/pkgconfig # Location of desktop files %_desktopdir /usr/share/applications +%_applnkdir ERROR:_applnkdir_is_obsolete_use_desktopdir_instead -# Location pixmaps for applnk/desktop files +# Location of pixmaps for applnk/desktop files %_pixmapsdir /usr/share/pixmaps +# Location of themable icons for applnk/desktop files +%_iconsdir /usr/share/icons + # Location of fonts directories %_fontsdir /usr/share/fonts # Location of Gtk and associated libraries documentation %_gtkdocdir %{_defaultdocdir}/gtk-doc/html +# 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") @@ -184,23 +226,31 @@ %_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_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 %(grep UTS_RELEASE %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | cut -d'"' -f2) -%__kernel_rel %(LC_ALL="C" rpm -qf %{_kernelsrcdir}/include/linux/version.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 --queryformat "%{RELEASE}" | grep -v "is not") +%__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 --' \ @@ -219,8 +269,8 @@ # #%no_install_post_compress_docs 1 %__spec_install_post_compress_docs { \ -echo "Compress man and info pages."; \ %{!?no_install_post_compress_docs: \ + echo "Compress man and info pages."; \ %{?verbose:set -x;} \ for i in /usr/share/man /usr/X11R6/man /usr/share/info; do \ if [ -d "$RPM_BUILD_ROOT$i" ]; then \ @@ -239,9 +289,10 @@ echo "Compress man and info pages."; \ #%no_install_post_strip 1 %__spec_install_post_strip {%{!?debug: \ %{!?no_install_post_strip: \ - %{?verbose:set -x;} \ + %{?verbose:set -x;} \ + if [ -d "$RPM_BUILD_ROOT" ]; then \ echo "Strip executable binaries, archives and shared object files."; \ - filelist=`find $RPM_BUILD_ROOT -type f ! -regex ".*ld-[0-9.]*so.*"`; \ + filelist=`find $RPM_BUILD_ROOT -type f ! -regex ".*ld-[0-9.]*so.*" %{?_noautostrip:! -regex "%{_noautostrip}"}`; \ elfexelist=`echo $filelist | xargs -r file | \ awk '/ELF.*executable/ {print $1}' | cut -d: -f1`; \ elfsharedlist=`echo $filelist | xargs -r file | \ @@ -249,14 +300,15 @@ echo "Compress man and info pages."; \ elfarchiveslist=`echo $filelist | xargs -r file | \ awk '/current ar archive/ {print $1}' | cut -d: -f1`; \ if [ -n "$elfexelist" ]; then \ - strip --remove-section=.note --remove-section=.comment $elfexelist; \ + %{__strip} --remove-section=.note --remove-section=.comment $elfexelist; \ fi; \ if [ -n "$elfsharedlist" ]; then \ - strip --strip-unneeded --remove-section=.note --remove-section=.comment $elfsharedlist; \ + %{__strip} --strip-unneeded --remove-section=.note --remove-section=.comment $elfsharedlist; \ fi; \ if [ -n "$elfarchiveslist" ]; then \ - strip --strip-debug --remove-section=.note --remove-section=.comment $elfarchiveslist; \ - fi; } \ + %{__strip} --strip-debug --remove-section=.note --remove-section=.comment $elfarchiveslist; \ + fi; \ + fi; } \ } } #----------------------------------------------------------------- # remove all RPATH from executable binaries and shared object files @@ -267,17 +319,17 @@ echo "Compress man and info pages."; \ %__spec_install_post_chrpath {%{!?debug: \ %{!?no_install_post_chrpath: \ %{?verbose:set -x;} \ +if [ -d "$RPM_BUILD_ROOT" ]; then \ echo "Remove RPATH from executable binaries and shared object files."; \ -if [ "$(uname -m)" != alpha ] ; then \ -find $RPM_BUILD_ROOT -type f ! -regex ".*ld-[0-9.]*so.*" | 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"; \ for dir in `chrpath -l "$file" | \ awk '/RPATH=/ { gsub(/.*RPATH=/,""); gsub(/:/," "); print $0 }'` ; do \ case $dir in \ - /home/* | /tmp/* | /usr/lib | /lib | /usr/local/lib | /usr/X11R6/lib ) \ + /home/* | /tmp/* | /usr/lib | /usr/lib64 | /lib | /lib64 | /usr/local/lib | /usr/local/lib64 | /usr/X11R6/lib | /usr/X11R6/lib64 ) \ echo "remove-rpath: $dir in $file"; \ ;; \ * ) \ @@ -288,7 +340,8 @@ while read file ; do \ done ; \ if [ "$rpath" = "" ] ; then chrpath -d "$file" > /dev/null ; \ else chrpath -r "$rpath" "$file" > /dev/null ; fi ; \ -done; fi; } \ +done; \ +fi; } \ } } #----------------------------------------------------------------- # Find and gzip all kernel modules @@ -298,82 +351,99 @@ done; fi; } \ #%no_install_post_compress_modules 1 %__spec_install_post_compress_modules { \ %{!?no_install_post_compress_modules: \ -echo "Compress kernel modules if any."; \ %{?verbose:set -x;} \ + 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 l -printf "%p %l\n" | \ + 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; \ + fi; \ } } %_source_payload w9.gzdio %_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} #----------------------------------------------------------------- -# post %install sequence: -# - autodeps exceptions -# - compress all man and info pages, -# - strip all ELF executables and ELF shared objects if not %debug. -# - compress kernel modules if any +# Update desktop MIME database +# requries: desktop-file-utils +# +%update_desktop_database_post() \ + umask 022; \ + /usr/bin/update-desktop-database; \ + %{nil} + +%update_desktop_database_postun() \ +if [ $1 = 0 ]; then \ + umask 022; \ + /usr/bin/update-desktop-database; \ +fi \ +%{nil} -################################################################### -# Requires/Provides automation -# exceptions system by Jacek Konieczny -%__spec_prep_pre \ -_autoreqprov=n \ -%{?_noautoreqfiles:_autoreqprov=y}\ -%{?_noautoreq:_autoreqprov=y}\ -%{?_noautoreqdep:_autoreqprov=y}\ -%{?_noautoprovfiles:_autoreqprov=y}\ -%{?_noautoprov:_autoreqprov=y}\ -%{?_noautocompressdoc:_autoreqprov=y}\ -if [ "$_autoreqprov" = "y" ] ; then \ - if [ -f %{_builddir}/__rpm_lock ] ; then \ - echo "Some package using \%_noauto* macros is already being built" >&2 \ - echo "If it is not true delete %{_builddir}/__rpm_lock" >&2 \ - exit 1 \ - else \ - rm -f %{_builddir}/__rpm_*\ - touch %{_builddir}/__rpm_lock \ - 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 \ -%{?_noautocompressdoc:echo '%{_noautocompressdoc}' > %{_builddir}/__rpm_noautocompressdoc}\ %{nil} +#----------------------------------------------------------------- +# Run ldconfig after installing/deinstalling libraries +# +%ldconfig_post() \ + /sbin/ldconfig; \ + %{nil} -%__spec_clean_pre %{___build_pre}\ -_autoreqprov=n \ -%{?_noautoreqfiles:_autoreqprov=y}\ -%{?_noautoreq:_autoreqprov=y}\ -%{?_noautoreqdep:_autoreqprov=y}\ -%{?_noautoprovfiles:_autoreqprov=y}\ -%{?_noautoprov:_autoreqprov=y}\ -%{?_noautoreqfiles:_autoreqprov=y}\ -%{?_noautocompressdoc:_autoreqprov=y}\ -if [ "$_autoreqprov" = "y" ] ; then \ - rm -f %{_builddir}/__rpm_* \ +%ldconfig_postun() \ +if [ $1 = 0 ]; then \ + /sbin/ldconfig; \ fi \ %{nil} +#----------------------------------------------------------------- +# post %install sequence: +# - autodeps exceptions +# - compress all man and info pages, +# - strip all ELF executables and ELF shared objects if not %debug. +# - compress kernel modules if any -#%_noautoreqfiles "%{_defaultdocdir}.*" "%{_examplesdir}.*" -#%_noautoreq %{nil} -#%_noautoreqdep %{nil} -#%_noautoprovfiles %{nil} -#%_noautoprov %{nil} +################################################################### +# Requires/Provides automation +# exceptions system by Jacek Konieczny +# +%__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} %_unpackaged_files_terminate_build %{nil} # (X)emacs support @@ -381,8 +451,10 @@ fi \ %_emacs_lispdir %(emacs %___emacs_lispdir_helper) %_xemacs_lispdir %(xemacs %___emacs_lispdir_helper) -%__php_provides @RPMCONFIGDIR@/php.prov -%__php_requires @RPMCONFIGDIR@/php.req +%__php_provides %{nil} +%__php_requires %{nil} +%__perl_provides %{nil} +%__perl_requires %{nil} # Perl specific macro definitions. %perl_privlib %(eval "`%{__perl} -V:installprivlib`"; echo $installprivlib) @@ -400,9 +472,11 @@ fi \ # directories %py_prefix %(echo `python -c "import sys; print sys.prefix"`) -%py_libdir %{py_prefix}/lib/python%{py_ver} +%py_libdir %{py_prefix}/%{_lib}/python%{py_ver} +%py_scriptdir %{py_prefix}/share/python%{py_ver} %py_incdir /usr/include/python%{py_ver} -%py_sitedir %{py_libdir}/site-packages +%py_sitedir %{py_libdir}/site-packages +%py_sitescriptdir %{py_scriptdir}/site-packages %py_dyndir %{py_libdir}/lib-dynload # pure python modules compilation @@ -411,11 +485,32 @@ fi \ %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 >= %py_ver %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' -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 \ @@ -427,3 +522,67 @@ else \ fi; \ } +# XMMS specific macros +%xmms_prefix %(xmms-config --prefix) +%xmms_exec_prefix %(xmms-config --exec-prefix) +%xmms_version %(xmms-config --version) +%xmms_datadir %(xmms-config --data-dir) +%xmms_plugindir %(xmms-config --plugin-dir) +%xmms_visualization_plugindir %(xmms-config --visualization-plugin-dir) +%xmms_input_plugindir %(xmms-config --input-plugin-dir) +%xmms_output_plugindir %(xmms-config --output-plugin-dir) +%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/') + +# 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 +