X-Git-Url: http://git.pld-linux.org/?p=packages%2Frpm.git;a=blobdiff_plain;f=rpm.macros;h=c4c5b061d17b9c10efd31c462e4baaedb51fd578;hp=a55a3960d109753c2da4726249acbd41b6632d3c;hb=6f0b14c3271a59aed2834d7af1902d825cc07896;hpb=989c01925e4c8b8963f658e48183ff4f02ca346c diff --git a/rpm.macros b/rpm.macros index a55a396..c4c5b06 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,11 +1,41 @@ +# PLD rpm macros + +%_defaultdocdir %{_usr}/share/doc +%_fixowner [ `%{__id_u}` = '0' ] && %{__chown_Rhf} root.@ROOT_GROUP@ +%_fixgroup true +%_topdir %(echo $HOME)/rpm +%_exec_prefix %{_prefix} +%_bindir %{_exec_prefix}/bin +%_sbindir %{_exec_prefix}/sbin +%_libexecdir %{_exec_prefix}/lib +%_datadir %{_prefix}/share +%_sharedstatedir %{_prefix}/com +%_lib lib +%_libdir %{_exec_prefix}/%{_lib} +%_includedir %{_prefix}/include +%_oldincludedir /usr/include +%_sysconfdir /etc +%_localstatedir /var +%_infodir /usr/share/info +%_mandir %{_prefix}/share/man +#----------------------------------------------------------------- +# CFLAGS and LDFLAGS used to build + +%debugcflags -O0 -g +%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags} +%rpmldflags %{!?debug:-s} + #----------------------------------------------------------------- -%configure { \ +%configure2_13 { \ if [ -n "$LINGUAS" ]; then unset LINGUAS; fi; \ - LDFLAGS="${LDFLAGS:-%{!?debug: -s}}" ; export LDFLAGS ; \ - CFLAGS="${CFLAGS:-%optflags}%{?debug: -g -O0}" ; export CFLAGS ; \ - CXXFLAGS="${CXXFLAGS:-%optflags}%{?debug: -g -O0}" ; export CXXFLAGS ; \ - FFLAGS="${FFLAGS:-%optflags}%{?debug: -g -O0}" ; 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 ; \ + %{?__cc:CC=%{__cc} ; export CC ; } \ + %{?__cxx:CXX=%{__cxx} ; export CXX ; } \ + ./configure \ + --host=%{_target_platform} \ --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ --bindir=%{_bindir} \ @@ -21,69 +51,45 @@ --infodir=%{_infodir} \ } -#------------------------------------------------------------------------------ -# The GNUconfigure macro does the following: -# update config.guess and config.sub. -# regenerate all autoconf/automake files -# optionally change to a directory (make the directory if requested). -# run configure with correct prefix, platform, and CFLAGS. -# optionally restore current directory. -# -# Based on autogen.sh from GNOME and orginal GNUconfigure -# -%GNUconfigure(MCs:) \ - %{-C:_mydir="`pwd`"; %{-M: %{__mkdir} -p %{-C*};} cd %{-C*}} \ - dirs="`find ${_mydir} -name configure.in -print`"; export dirs; \ - for coin in `echo ${dirs}` \ -do \ - dr=`dirname ${coin}`; \ -if test -f ${dr}/NO-AUTO-GEN; then \ - : \ -else \ - macrodirs=`sed -n -e 's,AM_ACLOCAL_INCLUDE(\(.*\)),\1,gp' < ${coin}`; \ - ( cd ${dr}; \ - aclocalinclude="${ACLOCAL_FLAGS}"; \ - for k in ${macrodirs}; do \ - if test -d ${k}; then \ - aclocalinclude="${aclocalinclude} -I ${k}"; \ - ##else \ - ## echo "**Warning**: No such directory \`${k}'. Ignored." \ - fi \ - done \ - if grep "^AM_GNU_GETTEXT" configure.in >/dev/null; then \ - if grep "sed.*POTFILES" configure.in >/dev/null; then \ - : do nothing -- we still have an old unmodified configure.in \ - else \ - test -r ${dr}/aclocal.m4 || touch ${dr}/aclocal.m4; \ - echo "no" | gettextize --force --copy; \ - test -r ${dr}/aclocal.m4 && %{__chmod} u+w ${dr}/aclocal.m4; \ - fi \ - fi \ - if grep "^AM_PROG_LIBTOOL" configure.in >/dev/null; then \ - %{__libtoolize} --force --copy; \ - fi \ - aclocal ${aclocalinclude}; \ - if grep "^AM_CONFIG_HEADER" configure.in >/dev/null; then \ - %{__autoheader}; \ - fi \ - echo "Running automake --gnu ${am_opt} ..."; \ - %{__automake} --add-missing --gnu ${am_opt}; \ - %{__autoconf}; \ - ); \ - fi \ -done \ - %{-C:${_mydir}}%{!-C:.}/%{configure} \ - %{-C:cd ${_mydir}; unset _mydir} +#---------------------------------------------------------------- +%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} \ + --sbindir=%{_sbindir} \ + --sysconfdir=%{_sysconfdir} \ + --datadir=%{_datadir} \ + --includedir=%{_includedir} \ + --libdir=%{_libdir} \ + --libexecdir=%{_libexecdir} \ + --localstatedir=%{_localstatedir} \ + --sharedstatedir=%{_sharedstatedir} \ + --mandir=%{_mandir} \ + --infodir=%{_infodir} \ +} # 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 +99,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 +147,64 @@ 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} + +%__os_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}\ +%{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}