X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=b6f613aeb2cac9266f2ca33a97c1ca875cf4bbad;hb=51b0fb84dd7cf3a54db7887674e688d1ff6f4dd3;hp=e1d10ea4b623ddd9c975dd82f9e01577554b9136;hpb=46041a9bed82cb2b6c5c0535fef8ef21d7163b6f;p=packages%2Frpm.git diff --git a/rpm.macros b/rpm.macros index e1d10ea..b6f613a 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,11 +1,43 @@ #----------------------------------------------------------------- -%configure { \ +# CFLAGS and LDFLAGS used to build + +%debugcflags -O0 -g +%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags} +%rpmldflags %{!?debug:-s} + +#----------------------------------------------------------------- +%configure2_13 { \ if [ -n "$LINGUAS" ]; then unset LINGUAS; fi; \ - LDFLAGS="${LDFLAGS}%{!?debug: -s}" ; export LDFLAGS ; \ - CFLAGS="${CFLAGS:-%optflags}%{?debug: -g -O}" ; export CFLAGS ; \ - CXXFLAGS="${CXXFLAGS:-%optflags}%{?debug: -g -O}" ; export CXXFLAGS ; \ - FFLAGS="${FFLAGS:-%optflags}%{?debug: -g -O}" ; export FFLAGS ; \ - ./configure %{_target_platform} \ + LDFLAGS="${LDFLAGS:-%rpmldflags}" ; export LDFLAGS ; \ + CFLAGS="${CFLAGS:-%rpmcflags}" ; export CFLAGS ; \ + CXXFLAGS="${CXXFLAGS:-%rpmcflags}" ; export CXXFLAGS ; \ + FFLAGS="${FFLAGS:-%rpmcflags}" ; export FFLAGS ; \ + ./configure \ + --host=%{_target_platform} \ + --prefix=%{_prefix} \ + --exec-prefix=%{_exec_prefix} \ + --bindir=%{_bindir} \ + --sbindir=%{_sbindir} \ + --sysconfdir=%{_sysconfdir} \ + --datadir=%{_datadir} \ + --includedir=%{_includedir} \ + --libdir=%{_libdir} \ + --libexecdir=%{_libexecdir} \ + --localstatedir=%{_localstatedir} \ + --sharedstatedir=%{_sharedstatedir} \ + --mandir=%{_mandir} \ + --infodir=%{_infodir} \ +} + +#---------------------------------------------------------------- +%configure {./configure \ + LDFLAGS="${LDFLAGS:-%rpmldflags}" \ + CFLAGS="${CFLAGS:-%rpmcflags}" \ + CXXFLAGS="${CXXFLAGS:-%rpmcflags}" \ + FFLAGS="${FFLAGS:-%rpmcflags}" \ + %{?__cc:CC=%{__cc}} \ + %{?__cxx:CXX=%{__cxx}} \ + --build=%{_target_platform} \ --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ --bindir=%{_bindir} \ @@ -78,12 +110,18 @@ done \ # Location of autoconf macros %_aclocaldir %(aclocal --print-ac-dir) +# Location of pkgconfig files +%_pkgconfigdir /usr/lib/pkgconfig + # Location of top applink dir %_applnkdir /usr/X11R6/share/applnk # Location pixmaps for applnk/desktop files %_pixmapsdir /usr/X11R6/share/pixmaps +# Location of fonts directories +%_fontsdir /usr/share/fonts + # Current date %date %(LC_ALL="C" date +"%a %b %d %Y") @@ -93,13 +131,8 @@ done \ # Example files, programs, scripts... %_examplesdir /usr/src/examples -# Find-requires and directories excluded from auto-req -%_noautoreqdir %{_defaultdocdir} %{_examplesdir} -%_noautoreqdep %{nil} -#%__find_requires_pre /usr/lib/rpm/find-requires-pre %{_noautoreqdir} -#%__find_requires_core /usr/lib/rpm/find-requires -#%__find_requires_post /usr/lib/rpm/find-requires-post -#%__find_requires %{__find_requires_pre} | %{__find_requires_core} | %{__find_requires_post} +# The directory holding Linux kernel sources +%_kernelsrcdir /usr/src/linux # If non-empty "debug" macro defined, add "dbg" suffix to release number %_rpmfilename %%{NAME}-%%{VERSION}-%%{RELEASE}%{?debug:dbg}.%%{ARCH}.rpm @@ -146,14 +179,65 @@ echo "Compress man and info pages."; \ fi; } \ } } +%_source_payload w9.gzdio +%_binary_payload w9.bzdio + #----------------------------------------------------------------- # post %install sequence: +# - autodeps exceptions # - compress all man and info pages, # - strip all ELF executables and ELF shared objects if not %debug. -# -%__spec_install_post { \ -%{__spec_install_post_strip} \ -%{__spec_install_post_compress_docs} } -%_source_payload w9.gzdio -%_binary_payload w9.bzdio +################################################################### +# 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}\ +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 \ +%{nil} + +%__spec_install_post \ +%{?_noautoreqfiles:for f in %{_noautoreqfiles} ; do echo %{?buildroot:%{buildroot}}$f >> %{_builddir}/__rpm_noautoreqfiles ; done }\ +%{?_noautoreq:for f in %{_noautoreq} ; do echo "$f" >> %{_builddir}/__rpm_noautoreq ; done }\ +%{?_noautoreqdep:for f in %{_noautoreqdep} ; do echo "$f" >> %{_builddir}/__rpm_noautoreqdep ; done }\ +%{?_noautoprovfiles:for f in %{_noautoprovfiles} ; do echo %{?buildroot:%{buildroot}}$f >> %{_builddir}/__rpm_noautoprovfiles ; done }\ +%{?_noautoprov:for f in %{_noautoprov} ; do echo "$f" >> %{_builddir}/__rpm_noautoprov ; done }\ +%{__spec_install_post_strip}\ +%{__spec_install_post_compress_docs}\ +%{__arch_install_post}\ +%{__os_install_post}\ +%{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}\ +if [ "$_autoreqprov" = "y" ] ; then \ + rm -f %{_builddir}/__rpm_* \ +fi \ +%{nil} + + +#%_noautoreqfiles "%{_defaultdocdir}.*" "%{_examplesdir}.*" +#%_noautoreq %{nil} +#%_noautoreqdep %{nil} +#%_noautoprovfiles %{nil} +#%_noautoprov %{nil}