X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=2d9d369f33479e23df0d9b6a8fbe699e482def8a;hb=1af0d3698ca0e6b709aec1e5c1fb25db5aa23775;hp=c3ac1e4188b2af384f3f5a89568b00a7d6efc1ed;hpb=642305dbf0a98256b5f62580ce34a2d663a215a9;p=packages%2Frpm.git diff --git a/rpm.macros b/rpm.macros index c3ac1e4..2d9d369 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,11 +1,54 @@ +# 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 #----------------------------------------------------------------- -%configure { \ +# CFLAGS and LDFLAGS used to build + +%debugcflags -O0 -g +%rpmcflags %{?debug:%debugcflags}%{!?debug:%optflags} +%rpmldflags %{!?debug:-s} + +# kernel compiler +%kgcc gcc +%kgcc_package gcc + +#----------------------------------------------------------------- +# Build system path macros. +# +%__libtoolize libtoolize --copy --force +%__gettextize gettextize --copy --force +%__automake automake -a -c -f --foreign +%__autoconf autoconf %{?debug:-Wall} + +#----------------------------------------------------------------- +%configure2_13 { \ if [ -n "$LINGUAS" ]; then unset LINGUAS; fi; \ - LDFLAGS="${LDFLAGS:-%{!?debug: -s}}" ; export LDFLAGS ; \ - CFLAGS="${CFLAGS:-%{!?debug:%optflags}%{?debug: -g -O0}}" ; export CFLAGS ; \ - CXXFLAGS="${CXXFLAGS:-%{!?debug:%optflags}%{?debug: -g -O0}}" ; export CXXFLAGS ; \ - FFLAGS="${FFLAGS:-%{!?debug:%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 ; \ + CPPFLAGS="${CPPFLAGS:-}" ; export CPPFLAGS ; \ + %{?__cc:CC=%{__cc} ; export CC ; } \ + %{?__cxx:CXX=%{__cxx} ; export CXX ; } \ + ./configure \ + --host=%{_target_platform} \ --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ --bindir=%{_bindir} \ @@ -21,69 +64,49 @@ --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}" \ + CPPFLAGS="${CPPFLAGS:-%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 omf files +%_omf_dest_dir %(scrollkeeper-config --omfdir) + +# 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,8 +116,23 @@ done \ # Example files, programs, scripts... %_examplesdir /usr/src/examples +# 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 +%_rpmfilename %%{NAME}-%%{VERSION}-%%{RELEASE}%{?debug:dbg}.%%{ARCH}.rpm + +# requires name = version-release +%requires_releq() %(LC_ALL="C" rpm -q --queryformat 'Requires:%%{NAME} = %%{VERSION}-%%{RELEASE}' %1| grep -v "is not") +%requires_kernel_releq() %(LC_ALL="C" rpm -q --queryformat 'Prereq:kernel = %%{VERSION}-%%{RELEASE}' kernel-headers | grep -v "is not") +%requires_releq_kernel_up() %(LC_ALL="C" rpm -q --queryformat 'Prereq:kernel-up = %%{VERSION}-%%{RELEASE}' kernel-headers | grep -v "is not") +%requires_releq_kernel_smp() %(LC_ALL="C" rpm -q --queryformat 'Prereq:kernel-smp = %%{VERSION}-%%{RELEASE}' kernel-headers | grep -v "is not") + +# 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) #----------------------------------------------------------------- # find and gzip all files in %{_mandir} and %{infodir} @@ -138,37 +176,62 @@ 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_install_pre %{___build_pre}\ -rm -f %{_builddir}/__rpm_*\ +%__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_install_post \ +%__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}\ -%{__os_install_post}\ %{nil} %__spec_clean_pre %{___build_pre}\ -rm -f %{_builddir}/__rpm_*\ +_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} @@ -177,5 +240,3 @@ rm -f %{_builddir}/__rpm_*\ #%_noautoreqdep %{nil} #%_noautoprovfiles %{nil} #%_noautoprov %{nil} - -