X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=50548880de371be3367cfb32f518f7f521edf3fa;hb=d755a548cb9c8e59a2a72634d32b40b967cbf3ca;hp=66f9c4b304c8789e7cca65b42181c09c3237002e;hpb=cc545e1ab86e7abde22069a988f366461499c413;p=packages%2Frpm.git diff --git a/rpm.macros b/rpm.macros index 66f9c4b..5054888 100644 --- a/rpm.macros +++ b/rpm.macros @@ -5,7 +5,7 @@ %__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@ %_topdir %(echo $HOME)/rpm @@ -93,6 +93,49 @@ --infodir=%{_infodir} \ } +# ------------------------------------------------------------------------ +# Conditional build stuff. + +# Check if symbol is defined. +# Example usage: %if %{defined with_foo} && %{undefined with_bar} ... +%defined() %{expand:%%{?%{1}:1}%%{!?%{1}:0}} +%undefined() %{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}} + +# 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. +# +# %bcond_with foo defines symbol with_foo if --with foo was specified on +# command line. +# %bcond_without foo defines symbol with_foo if --without foo was *not* +# specified on command line. +# +# For example: +# +# %bcond_with extra_fonts +# %bcond_without static +# %if %{with extra_fonts} +# ... +# %endif +# %ifdef %{with static} +# ... +# %endif +# %{?with_static: ... } +# %{!?with_static: ... } +# %{?with_extra_fonts: ... } +# %{!?with_extra_fonts: ... } +# +# The bottom line: never use without_foo, _with_foo nor _without_foo, only +# with_foo. This way changing default set of bconds for given spec is just +# a matter of changing single line in it and syntax is more readable. +%bcond_with() %{expand:%%{?_with_%{1}:%%global with_%{1} 1}} +%bcond_without() %{expand:%%{!?_without_%{1}:%%global with_%{1} 1}} +# ------------------------------------------------------------------------ + # Location of autoconf macros %_aclocaldir %(aclocal --print-ac-dir) @@ -100,7 +143,7 @@ %_omf_dest_dir %(scrollkeeper-config --omfdir) # Location of pkgconfig files -%_pkgconfigdir /usr/lib/pkgconfig +%_pkgconfigdir /usr/%{_lib}/pkgconfig # Location of top applink dir %_applnkdir /usr/X11R6/share/applnk @@ -108,15 +151,21 @@ # Location of desktop files %_desktopdir /usr/share/applications -# 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 + # Current date %date %(LC_ALL="C" date +"%a %b %d %Y") @@ -136,6 +185,9 @@ %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") + +%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) @@ -250,9 +302,9 @@ done; fi; } \ echo "Compress kernel modules if any."; \ %{?verbose:set -x;} \ if test -d $RPM_BUILD_ROOT/lib/modules ; then \ - find $RPM_BUILD_ROOT/lib/modules -name \*.o -type f -print | \ + 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 l -printf "%p %l\n" | \ while read a b; do ln -sf $b.gz $a.gz; rm -f $a; done; \ fi; \ } } @@ -281,48 +333,14 @@ echo "Compress kernel modules if any."; \ ################################################################### # 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 \ -fi \ -%{?_noautocompressdoc:echo '%{_noautocompressdoc}' > %{_builddir}/__rpm_noautocompressdoc}\ -%{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_* \ -fi \ -%{nil} - - -#%_noautoreqfiles "%{_defaultdocdir}.*" "%{_examplesdir}.*" +# +#%_noautoreqfiles '%{_defaultdocdir}.*' '%{_examplesdir}.*' #%_noautoreq %{nil} #%_noautoreqdep %{nil} #%_noautoprovfiles %{nil} #%_noautoprov %{nil} +#%_noautocompressdoc %{nil} +# %_missing_doc_files_terminate_build 1%{nil} %_unpackaged_files_terminate_build %{nil} # (X)emacs support @@ -361,5 +379,30 @@ fi \ # 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 >= 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, '.')"`) + +# depmod macro +%depmod() { \ +if [ -e /boot/System.map-%1 ]; then \ + /sbin/depmod -a -F /boot/System.map-%1 %1; \ +else \ + if [ -e /boot/System.map ]; then \ + /sbin/depmod -a -F /boot/System.map %1; \ + else \ + /sbin/depmod -a %1; \ + fi \ +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)