X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=ad18aadaf456749232390ac8623b48fc835ed9d8;hb=974b020487cd5917b44f48d8906ec45c5d8d29c9;hp=1996cee5e74eddcd56db414b64fdc17fd390e437;hpb=a4b4c90f390694b9b593cd147f351bfcef5447f0;p=packages%2Frpm-build-macros.git diff --git a/rpm.macros b/rpm.macros index 1996cee..ad18aad 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,4 +1,6 @@ # $Revision$, $Date$ +# vim:ts=4 sw=4 noet ft=spec +# # PLD Linux rpm macros. # @@ -14,8 +16,8 @@ %kgcc_package gcc # compiler version -%cc_version %{expand:%%global cc_version %(%{__cc} -dumpversion || echo ERROR)}%cc_version -%cxx_version %{expand:%%global cxx_version %(%{__cxx} -dumpversion || echo ERROR)}%cxx_version +%cc_version %{expand:%%global cc_version %(%{__cc} -dumpversion 2>/dev/null || echo 0.0)}%cc_version +%cxx_version %{expand:%%global cxx_version %(%{__cxx} -dumpversion 2>/dev/null || echo 0.0)}%cxx_version %__rm /bin/rm --interactive=never @@ -239,16 +241,32 @@ %{dependencytracking} \ } -%cmake { \ -CC="%{__cc}" \ -CXX="%{__cxx}" \ -CFLAGS="%{rpmcflags}" \ -CXXFLAGS="%{rpmcxxflags}" \ -LDFLAGS="%{rpmldflags}" \ -%{__cmake} \ --DCMAKE_INSTALL_PREFIX=%{_prefix} \ --DCMAKE_BUILD_TYPE=%{!?debug:Release}%{?debug:Debug} \ -} +%cmake \ +%{?__cc:CC="%{__cc}"} \\\ +%{?__cxx:CXX="%{__cxx}"} \\\ +CPPFLAGS="${CPPFLAGS:-%{rpmcppflags}}" \\\ +CFLAGS="${CFLAGS:-%{rpmcflags}}" \\\ +FFLAGS="${FFLAGS:-%{rpmcflags}}" \\\ +FCFLAGS="${FCFLAGS:-%{rpmcflags}}" \\\ +CXXFLAGS="${CXXFLAGS:-%{rpmcxxflags}}" \\\ +LDFLAGS="${LDFLAGS:-%{rpmldflags}}" \\\ +%{__cmake} \\\ + -DCMAKE_VERBOSE_MAKEFILE=ON \\\ + -DCMAKE_BUILD_TYPE=%{!?debug:Release}%{?debug:Debug} \\\ + -DCMAKE_INSTALL_LIBDIR:PATH=%{_libdir} \\\ + -DCMAKE_INSTALL_PREFIX:PATH=%{_prefix} \\\ + -DINCLUDE_INSTALL_DIR:PATH=%{_includedir} \\\ + -DLIB_INSTALL_DIR:PATH=%{_libdir} \\\ + -DSHARE_INSTALL_PREFIX:PATH=%{_datadir} \\\ + -DSYSCONF_INSTALL_DIR:PATH=%{_sysconfdir} \\\ + -DCMAKE_CXX_FLAGS="${CXXFLAGS:-%{rpmcxxflags}" \\\ + -DCMAKE_CPP_FLAGS="${CPPFLAGS:-%{rpmcppflags}}" \\\ + -DCMAKE_C_FLAGS="${CFLAGS:-%{rpmcflags}}" \\\ +%if "%{_lib}" == "lib64" \ + -DLIB_SUFFIX=64 \\\ +%endif \ + -DBUILD_SHARED_LIBS:BOOL=ON \\\ +%{nil} %scons { \ %{__scons} \ @@ -636,15 +654,22 @@ fi; }; __spec_install_post_chrpath } } } # Find all shared object files with unresolved symbols. Warn # and terminate if any found (termination can be turned off by define). #%no_install_post_check_so 1 +#%skip_post_check_so libwithunresolvedok.so.* +# +# NOTE: define skip_post_check_so only if such library really requires +# unresolved symbols and always leave a comment why it is required: +# # executable provides symbols foo, bar for those libraries: +# %define skip_post_check_so libwithoutfoo.so.* libwithoutbar.so.* +# %__spec_install_post_check_so { \ - __spec_install_post_check_so() { \ - fail=0; \ - printf "Searching for shared objects with unresolved symbols..."; \ - for f in $(find $RPM_BUILD_ROOT -type f -name '*.so.*' -print); do \ - LC_ALL=C objdump -T $f 2> /dev/null | LC_ALL=C awk -v "file=$f" 'BEGIN { found=0; skip["program_name"]=1; symbols = "" } /^[0-9a-z]+ +D +\*UND\*/ { if ($NF in skip) { next; }; found = 1; symbols = symbols "\n\t" $NF } END { if (found) { print "\nUnresolved symbols found in: " file symbols; exit(1); } } ' || fail=1 ; \ - done ; \ - echo " DONE"; \ - %{!?no_install_post_check_so:[ $fail -eq 1 ] && : || :;} \ +__spec_install_post_check_so() { \ + fail=0; \ + printf "Searching for shared objects with unresolved symbols..."; \ + for f in $(find $RPM_BUILD_ROOT -type f -name '*.so.*' -print); do \ + LC_ALL=C objdump -T $f 2> /dev/null | LC_ALL=C awk -v "file=$f" 'BEGIN { found=0; skip["program_name"]=1; symbols = "" } /^[0-9a-z]+ +D +\*UND\*/ { if ($NF in skip) { next; }; found = 1; symbols = symbols "\n\t" $NF } END { if (found) { print "\nUnresolved symbols found in: " file symbols; %{?skip_post_check_so:split("%{skip_post_check_so}", R); for (i=1; i in R; i++) { if (file ~ "(^|/)" R[i] "$") { print "Library marked with skip_post_check_so, ignoring errors.\n"; exit(0); } } } exit(1); } } ' || fail=1 ; \ + done ; \ + echo " DONE"; \ + %{!?no_install_post_check_so:return $fail;} \ }; __spec_install_post_check_so }} #----------------------------------------------------------------- @@ -722,11 +747,13 @@ fi; \ #----------------------------------------------------------------- # Update icon cache -# requires: gtk+ +# BuildRequires: rpmbuild(macros) >= 1.596 +# Requires: hicolor-icon-theme # %update_icon_cache() {{ \ + %{!?1:%{error:%{0}: Required icon dir missing}exit 1} \ umask 022; \ - /usr/bin/gtk-update-icon-cache -qf %{_datadir}/icons/%1; \ + [ -x /usr/bin/gtk-update-icon-cache ] && /usr/bin/gtk-update-icon-cache -qf %{_datadir}/icons/%1 || :; \ };} \ %{nil} @@ -744,6 +771,16 @@ if [ "$1" = "0" ]; then \ fi; \ %{nil} +#----------------------------------------------------------------- +# Compile GSettings schemas +# requires: glib2 >= 1:2.26.0 +# +%glib_compile_schemas() {{ \ + umask 022; \ + /usr/bin/glib-compile-schemas %{_datadir}/glib-2.0/schemas; \ +};} \ +%{nil} + #----------------------------------------------------------------- # post %install sequence: # - autodeps exceptions @@ -813,7 +850,9 @@ fi; \ %php_debug %{expand:%%global php_debug %(awk '/#define ZEND_DEBUG/{print $3}' %{php_includedir}/main/php_config.h 2>/dev/null || echo ERROR)}%php_debug %zend_module_api %{expand:%%global zend_module_api %(awk '/#define ZEND_MODULE_API_NO/{print $3}' %{php_includedir}/Zend/zend_modules.h 2>/dev/null || echo ERROR)}%zend_module_api %zend_extension_api %{expand:%%global zend_extension_api %(awk '/#define ZEND_EXTENSION_API_NO/{print $3}' %{php_includedir}/Zend/zend_extensions.h 2>/dev/null || echo ERROR)}%zend_extension_api -%zend_zts %{expand:%%global zend_zts %(Z=$(grep -sc '^#define ZTS 1' %{php_includedir}/main/php_config.h); echo ${Z:-ERROR})}%zend_zts +%_zend_zts %{expand:%%global _zend_zts %(Z=$(grep -sc '^#define ZTS 1' %{php_includedir}/main/php_config.h); echo ${Z:-ERROR})}%_zend_zts +# "_ts" if ZTS enabled, empty otherwise +%zend_zts %{expand:%%global _zend_zts_%{?_zend_zts} 1}%{?_zend_zts_1:_ts} # helper macro %__php_api_requires(v:) Requires: php%{-v*}(%{expand:%1}) = %{expand:%{%{!?2:%{1}}%{?2}}} @@ -823,13 +862,13 @@ fi; \ %requires_php_extension %{__php_api_requires modules_api php_api_version} \ %{__php_api_requires zend_module_api} \ %{__php_api_requires -v %php_major_version debug php_debug} \ -%{__php_api_requires -v %php_major_version thread-safety zend_zts} +%{__php_api_requires -v %php_major_version thread-safety _zend_zts} # for zend extensions %requires_zend_extension %{__php_api_requires zend_module_api} \ %{__php_api_requires zend_extension_api} \ %{__php_api_requires -v %php_major_version debug php_debug} \ -%{__php_api_requires -v %php_major_version thread-safety zend_zts} +%{__php_api_requires -v %php_major_version thread-safety _zend_zts} # for php pdo modules (php-pecl-PDO_*) %requires_php_pdo_module %{__php_api_requires PDO_API php_pdo_api_version} @@ -1039,7 +1078,7 @@ fi; \ # banner support (useful in {pre,post}{,un} and triggers) # # Usage: -# %banner name [-a] [-e] [-n] [-tn] <= n; default n=5 +# -o - show only once, i.e when package is installed for the first time # # Tests: # (rpm -E '%banner -e banner < m; sh -x m +# (rpm -E '%banner -o -e banner < m; sh -x m +# (rpm -E '%banner -o -e banner < m; sh -x m 1 # rpm -E 'date | %banner -e banner' > m; sh -x m +# rpm -E 'date | %banner -o -e banner' > m; sh -x m # -%banner(aent:) ( \ +%banner(aenot:) %{-o:([ "$1" != 1 ] ||} ( \ RPM_SCRIPTVERBOSITY=5 \ [ -r /etc/sysconfig/rpm ] && . /etc/sysconfig/rpm \ if [ -x /usr/bin/banner.sh ]; then \ @@ -1063,7 +1106,7 @@ if [ -x /usr/bin/banner.sh ]; then \ else \ CMD="cat%{-e: >&2}" \ fi \ -eval $CMD %{?2:%2}%{?3: %3}) \ +eval $CMD %{?2:%2}%{?3: %3})%{-o:)} \ %{nil} # useradd/groupadd macros @@ -1355,7 +1398,7 @@ echo -e "\\n" >> %{_mavendepmapdir}/maven2-depmap.xml # %%pear_package_setup ... # # -a # - also unpack SOURCE#. for PEAR bootstrapping -# -n FMT - create builddir with FMT, instead of default %%{_pearname}-%%{version} +# -n FMT - create builddir with FMT, instead of default %%{pearname}-%%{version} # -z - unpack pear package and let pear use package.xml (not tarball) for install. for PEAR bootstrapping # -D - pass -D to %setup (so the build dir is not removed) # -c - register channel from local channel.xml file @@ -1417,7 +1460,7 @@ fi \ # as it's displayed to user after package install. and adding additional gzip # dep is just waste ;) %pear_package_setup(a:d:n:zDc:) \ -%define srcdir %{-n*}%{!-n:%{_pearname}-%{version}} \ +%define srcdir %{-n*}%{!-n:%{?_pearname}%{!?_pearname:%{pearname}}-%{version}} \ %define builddir %{_builddir}/%{srcdir} \ %setup -q -c -T %{-D:-D} -n %{srcdir} \ %{-z:%{__tar} zxf %{S:0}; %{-a:%{__tar} zxf %{S:%{-a*}}}} \ @@ -1427,17 +1470,18 @@ fi \ %{-z:cd ..} \ %{__tar} --wildcards -zvxf %{S:0} package*.xml \ cat %{-z:$_N/}.install.log | %__pear_install_log \ -\ -# undos sources \ -find -type f -print0 | xargs -0 sed -i -e 's,\\r$,,' \ +%undos -f php,html,js,xml \ %{!?_noautocompressdoc:%global _noautocompressdoc %{nil}}%{expand:%%global _noautocompressdoc %{_noautocompressdoc} optional-packages.txt} \ %{!?_noautoprov:%global _noautoprov %{nil}}%{expand:%%global _noautoprov %{_noautoprov} 'pear(tests/.*)'} \ %{nil} -# Copies exctracted PEAR package structure and PEAR registry to buildroot. +# Copies extracted PEAR package structure and PEAR registry to buildroot. # Author: Elan Ruusamäe %pear_package_install() \ cp -a ./%{php_pear_dir}/{.registry,*} $RPM_BUILD_ROOT%{php_pear_dir} \ +# tests should not be packaged \ +%{__rm} -rf $RPM_BUILD_ROOT%{php_pear_dir}/tests \ +# cleanup backups \ find $RPM_BUILD_ROOT%{php_pear_dir} '(' -name '*~' -o -name '*.orig' ')' | xargs -r rm -v \ # help the developer out a little: \ if [ -f _noautoreq ]; then \ @@ -1947,18 +1991,18 @@ else: \ # migrate from init script to upstart job %upstart_post() \ - if [ -f /var/lock/subsys/"%1" ] ; then \ - /sbin/service --no-upstart "%1" stop \ - /sbin/service "%1" start \ + if [ -f /var/lock/subsys/%1 ]; then \ + /sbin/service --no-upstart %1 stop \ + /sbin/service %1 start \ fi # restart the job after upgrade or migrate to init script on removal # cannot be stopped with 'service' as /etc/init/$name.conf may be missing # at this point %upstart_postun() \ - if [ -x /sbin/initctl ] && /sbin/initctl status "%1" 2>/dev/null | grep -q 'running' ; then \ - /sbin/initctl stop "%1" >/dev/null 2>&1 \ - [ -f "/etc/rc.d/init.d/%1" -o -f "/etc/init/%1.conf" ] && { echo -n "Re-" ; /sbin/service "%1" start ; } ; \ + if [ -x /sbin/initctl ] && /sbin/initctl status %1 2>/dev/null | grep -q 'running' ; then \ + /sbin/initctl stop %1 >/dev/null 2>&1 \ + [ -f /etc/rc.d/init.d/%1 -o -f /etc/init/%1.conf ] && { echo -n "Re-"; /sbin/service %1 start; }; \ fi -# vim:ts=4 sw=4 noet ft=spec +# EOF