X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=rpm.macros;h=68441a24747bea42248bd83ec982b574526f6b19;hb=eb5ba8b8955e706a9db3160772de278a56e454f2;hp=967bb880354034ad8f3e2382bb731d00e6212c80;hpb=a42b19b33b97743edbb1d867e2cd8ab6a949a92a;p=packages%2Frpm-build-macros.git diff --git a/rpm.macros b/rpm.macros index 967bb88..68441a2 100644 --- a/rpm.macros +++ b/rpm.macros @@ -1,20 +1,15 @@ -# $Revision$, $Date$ # vim:ts=4 sw=4 noet ft=spec # # PLD Linux rpm macros. # # can be used by builder script to check for version -%rpm_build_macros %(R="$Revision$"; RR="${R##: }"; echo ${RR%%?}) +%rpm_build_macros {Revision} %epoch 0 %x8664 x86_64 amd64 ia32e %arm armv3l armv4b armv4l armv5teb armv5tel -# kernel compiler -%kgcc %{__cc} -%kgcc_package gcc - # compiler 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 @@ -27,18 +22,20 @@ %__autopoint autopoint --force # add parallel build flags: -jN +# jobs macro is available since 1.657 # # if you want to disable parallel build do: -# echo '%_smp_mflags %{nil}' >> ~/.rpmmacros -# +# echo '%__jobs %{nil}' >> ~/.rpmmacros +%__jobs %{expand:%%global __jobs %(_NCPUS=$(/usr/bin/getconf _NPROCESSORS_ONLN); [ "$_NCPUS" -gt 3 ] && echo $(($_NCPUS / 2)))%%{nil}}%__jobs + +# expands to -jN if %__jobs has a value +%_smp_mflags %{expand:%%global _smp_mflags %(jobs=%{__jobs}; echo ${jobs:+-j$jobs}%%{nil})}%_smp_mflags + %__make /usr/bin/make %{?_smp_mflags} %__scons /usr/bin/scons %{?_smp_mflags} %__waf /usr/bin/waf %{?_smp_mflags} %__cmake /usr/bin/cmake -%_smp_mflags %(_NCPUS=$(/usr/bin/getconf _NPROCESSORS_ONLN); \\\ - [ "$_NCPUS" -gt 1 ] && echo "-j$(($_NCPUS * 2))") - %__gettextize { \ if grep -qs 'AM_GNU_GETTEXT.*external' configure.{ac,in} ; then \ gettextize --copy --force --no-changelog; \ @@ -88,10 +85,10 @@ %_specdir %{expand:%%global _specdir %([ ! -d %{_topdir}/SPECS ] && echo %{_topdir}/%{name} || echo %{_topdir}/SPECS)}%_specdir %_sourcedir %{expand:%%global _sourcedir %([ ! -d %{_topdir}/SOURCES ] && echo %{_specdir} || echo %{_topdir}/SOURCES)}%_sourcedir -# BUILD/RPMS/SRPMS are one same level by default as packages dir, if these exist +# BUILD/RPMS/SRPMS are on same level by default as packages dir, if these exist # if they don't exist assume we are having custom topdir (which is not named as # "packages", i.e ~/rpm/kde/{kdelibs,BUILD/RPMS/SRPMS}) -# NOTE: readlink fails if some parent dir is not readable (/home/services/builder for example can't read /home/services), therfore the extra echo +# NOTE: readlink fails if some parent dir is not readable (/home/services/builder for example can't read /home/services), therefore the extra echo %_builddir %{expand:%%global _builddir %(if [ -d %{_topdir}/BUILD ]; then echo %{_topdir}/BUILD; else readlink -m %{_topdir}/../BUILD || echo %{_topdir}/../BUILD; fi)}%_builddir %_rpmdir %{expand:%%global _rpmdir %(if [ -d %{_topdir}/RPMS ]; then echo %{_topdir}/RPMS; else readlink -m %{_topdir}/../RPMS || echo readlink -m %{_topdir}/../RPMS; fi)}%_rpmdir %_srcrpmdir %{expand:%%global _srcrpmdir %(if [ -d %{_topdir}/SRPMS ]; then echo %{_topdir}/SRPMS; else readlink -m %{_topdir}/../SRPMS || echo readlink -m %{_topdir}/../SRPMS; fi)}%_srcrpmdir @@ -126,8 +123,8 @@ # Regular expressions are supported, but to avoid some character be treated # as regular expression it must be escaped twice. -%filter_out \ - for (i = 1; i in I; i++) { A=0; \ +%filter_out \ + for (i = 1; i in I; i++) { A=0; \ for (f in F) { \ if (I[i] ~ "^" F[f] "$") A=1; \ }; \ @@ -185,8 +182,8 @@ %_preserve_env_base PATH HOME TMP TMPDIR SSH_AUTH_SOCK # "env -i" must end in first line of expaned macros because it's used as first line of shell script (#! env...) -%_clean_env %{!?_preserve_env:%global _preserve_env %{nil}}%{expand:%%global _preserve_env %{_preserve_env} %_preserve_env_base} env -i %(awk -vq="'" -vqq="\\"'\\"" -vq2q="'\\"'" 'BEGIN { - split("%{?_preserve_env}", P); +%_clean_env env -i %(awk -vq="'" -vqq="\\"'\\"" -vq2q="'\\"'" 'BEGIN { + split("%{?_preserve_env:%_preserve_env %_preserve_env_base}%{!?_preserve_env:%_preserve_env_base}", P); for (i in P) { p = P[i]; if (!ENVIRON[p] || d[p]) { @@ -211,6 +208,16 @@ } }') +# override %__spec_build_pre and %__spec_install_pre from macros.rpmbuild +# adding %{_clean_env} +%__spec_build_pre %{_clean_env}\ +%{___build_pre}\ +%{nil} +%__spec_install_pre %{_clean_env}\ +%{___build_pre}\ +%{?buildroot:%{__rm} -rf '%{buildroot}'; %{__mkdir_p} '%{buildroot}'}\ +%{nil} + #----------------------------------------------------------------- %configure2_13 { \ if [ -n "$LINGUAS" ]; then unset LINGUAS; fi; \ @@ -224,7 +231,7 @@ %{?__cxx:CXX="%{__cxx}" ; export CXX ; } \ %{?configuredir:%{configuredir}}%{!?configuredir:.}/configure \ --host=%{_target_platform} \ - --prefix=%{_prefix} \ + --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ --bindir=%{_bindir} \ --sbindir=%{_sbindir} \ @@ -241,22 +248,28 @@ %{dependencytracking} \ } +# Note: pass only standard cmake macros here. +# The only exception is SYSCONF_INSTALL_DIR, used commonly in KDE packages, +# where the default (${CMAKE_INSTALL_PREFIX}/etc) is not FHS-compliant and +# absolute path MUST be used to comply with FHS. +# The other non-standard cmake macros used commonly in KDE +# (INCLUDE_INSTALL_DIR, LIB_INSTALL_DIR, SHARE_INSTALL_PREFIX) +# have sane default values in KDE, and some packages use these names +# in different way (e.g. expect them to be always relative or always +# absolute). %cmake \ -%{?__cc:CC="%{__cc}"} \\\ -%{?__cxx:CXX="%{__cxx}"} \\\ +%{?__cc:CC="${CC:-%{__cc}}"} \\\ +%{?__cxx:CXX="${CXX:-%{__cxx}}"} \\\ CPPFLAGS="${CPPFLAGS:-%{rpmcppflags}}" \\\ %{__cmake} \\\ -DCMAKE_VERBOSE_MAKEFILE=ON \\\ -DCMAKE_BUILD_TYPE=%{!?debug:PLD}%{?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_PLD="${CXXFLAGS:-%{rpmcxxflags} -DNDEBUG}" \\\ - -DCMAKE_C_FLAGS_PLD="${CFLAGS:-%{rpmcflags} -DNDEBUG}" \\\ - -DCMAKE_Fortran_FLAGS_PLD="${CFLAGS:-%{rpmcflags} -DNDEBUG}" \\\ + -DCMAKE_CXX_FLAGS_PLD="${CXXFLAGS:-%{rpmcxxflags} -DNDEBUG -DQT_NO_DEBUG}" \\\ + -DCMAKE_C_FLAGS_PLD="${CFLAGS:-%{rpmcflags} -DNDEBUG -DQT_NO_DEBUG}" \\\ + -DCMAKE_Fortran_FLAGS_PLD="${CFLAGS:-%{rpmcflags} -DNDEBUG -DQT_NO_DEBUG}" \\\ -DCMAKE_EXE_LINKER_FLAGS_PLD="${LDFLAGS:-%{rpmldflags}}" \\\ -DCMAKE_SHARED_LINKER_FLAGS_PLD="${LDFLAGS:-%{rpmldflags}}" \\\ -DCMAKE_MODULE_LINKER_FLAGS_PLD="${LDFLAGS:-%{rpmldflags}}" \\\ @@ -286,6 +299,7 @@ CXX="%{__cxx}" \ CPP="%{__cpp}" \ CFLAGS="%{rpmcflags}" \ CXXFLAGS="%{rpmcxxflags}" \ +LINKFLAGS="%{rpmldflags}" \ %{__waf} \ } @@ -294,7 +308,7 @@ CXXFLAGS="%{rpmcxxflags}" \ %configure_cache_file %{buildroot}.configure.cache %configure {./configure \ - LDFLAGS="${LDFLAGS:-%rpmldflags}" \ + LDFLAGS="${LDFLAGS:-%rpmldflags}" \ CFLAGS="${CFLAGS:-%rpmcflags}" \ CXXFLAGS="${CXXFLAGS:-%rpmcxxflags}" \ FFLAGS="${FFLAGS:-%rpmcflags}" \ @@ -304,7 +318,7 @@ CXXFLAGS="%{rpmcxxflags}" \ %{?__cxx:CXX="%{__cxx}"} \ --host=%{_target_platform} \ --build=%{_target_platform} \ - --prefix=%{_prefix} \ + --prefix=%{_prefix} \ --exec-prefix=%{_exec_prefix} \ --bindir=%{_bindir} \ --sbindir=%{_sbindir} \ @@ -402,17 +416,11 @@ CXXFLAGS="%{rpmcxxflags}" \ %__unsermake /usr/share/unsermake/unsermake # Current date -%date %(LC_ALL=C date +"%a %b %d %Y") +%date %(LC_ALL=C date +"%a %b %d %Y") # Example files, programs, scripts... %_examplesdir /usr/src/examples -# Alternative kernel type/version -%_alt_kernel %{nil}%{?alt_kernel:-%{?alt_kernel}} - -# The directory holding Linux kernel sources -%_kernelsrcdir /usr/src/linux%{_alt_kernel} - # SysV-style initscripts dir %_initddir /etc/rc.d/init.d @@ -428,16 +436,48 @@ CXXFLAGS="%{rpmcxxflags}" \ # and release 0.zzz.bootstrap if built with bootstrap %bootstrap_release() %{!?with_bootstrap:%{1}%{?2:.%{2}}}%{?with_bootstrap:%{!?2:%(expr %{1} - 1)}%{?2:%{1}.%(expr %{2} - 1)}.zzz.bootstrap} +# Alternative kernel type/version +%_alt_kernel %{nil}%{?alt_kernel:-%{?alt_kernel}} + +# The directory holding Linux kernel sources +%_kernelsrcdir /usr/src/linux%{_alt_kernel} + +# rpm -qf on kernel version.h file +%__kernel_qf() %(R=$(cd %{_kernelsrcdir} 2>/dev/null && LC_ALL=C rpm -q --qf '%*' -f include/linux/version.h 2>/dev/null | grep -v 'is not'); echo ${R:-ERROR}) + +# kernel %{name} and kernel %{epoch}:%{version}-%{release} macro respecing alt_kernel +%kernel_name %(N=%{__kernel_qf %{N}}; echo ${N%%-headers}) +%kernel_version %{__kernel_qf %|E?{%{E}:}|%{V}-%{R}} + # -n drm to generate kernel%{_alt_kernel}-drm dependency -%releq_kernel(n:) %{expand:%%global releq_kernel %(R=$(LC_ALL=C rpm -q --qf '%{N}%{?-n:-%{-n*}} = %|E?{%{E}:}|%{V}-%{R}' -f %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | grep -v 'is not' | sed -e 's:-headers::;s:-config::'); echo ${R:-ERROR})}%releq_kernel -%releq_kernel_up(n:) %{expand:%%global releq_kernel_up %(R=$(LC_ALL=C rpm -q --qf '%{N}%{?-n:-%{-n*}}-up = %|E?{%{E}:}|%{V}-%{R}' -f %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | grep -v 'is not' | sed -e 's:-headers::;s:-config::'); echo ${R:-ERROR})}%releq_kernel_up -%releq_kernel_smp(n:) %{expand:%%global releq_kernel_smp %(R=$(LC_ALL=C rpm -q --qf '%{N}%{?-n:-%{-n*}}-smp = %|E?{%{E}:}|%{V}-%{R}' -f %{_kernelsrcdir}/include/linux/version.h 2>/dev/null | grep -v 'is not' | sed -e 's:-headers::;s:-config::'); echo ${R:-ERROR})}%releq_kernel_smp +%releq_kernel(n:) %{kernel_name}%{?-n:-%{-n*}} = %{kernel_version} +%releq_kernel_up(n:) %{kernel_name}-up%{?-n:-%{-n*}} = %{kernel_version} +%releq_kernel_smp(n:) %{kernel_name}-smp%{?-n:-%{-n*}} = %{kernel_version} # -s post to generate Requires(post) dependency %requires_releq_kernel(s:n:) Requires%{-s:(%{-s*})}: %releq_kernel %requires_releq_kernel_up(s:n:) Requires%{-s:(%{-s*})}: %releq_kernel_up %requires_releq_kernel_smp(s:n:) Requires%{-s:(%{-s*})}: %releq_kernel_smp +# kernel version-release handling +%__kernel_ver %( \\ + Z=$([ -f '%{_kernelsrcdir}/include/generated/utsrelease.h' ] && awk -F'"' '/UTS_RELEASE/{print $2}' %{_kernelsrcdir}/include/{linux/version,generated/utsrelease}.h 2>/dev/null || awk -F'"' '/UTS_RELEASE/{print $2}' %{_kernelsrcdir}/include/linux/{version,utsrelease}.h 2>/dev/null); \\ + Z=${Z:-$(awk -F' = ' '/^VERSION/{v=$2} /^PATCHLEVEL/{p=$2} /^SUBLEVEL/{s=$2} /^EXTRAVERSION/{e=$2} END {printf("%d.%d.%d%s", v, p, s, e)}' %{_kernelsrcdir}/Makefile 2>/dev/null)}; \\ + echo ${Z:-ERROR}; \\ +) + +%_kernel_version_code %( \\ + Z=$(awk '/LINUX_VERSION_CODE/{print $3}' %{_kernelsrcdir}/include/linux/version.h 2>/dev/null); \\ + echo ${Z:-ERROR}; \\ +) + +%_kernel_version_magic() %(echo $((%{1} * 65536 + %{2} * 256 + %{3}))) + +# `uname -r` used for building/installing kernel modules +%_kernel_ver %{__kernel_ver}%{!?_without_dist_kernel:%(echo %{__kernel_ver} | grep -q -e - || echo -%{__kernel_qf %{R}})} +# package version OR `uname -r` for non-dist kernel to be used in @release field +%_kernel_ver_str %(echo %{!?_without_dist_kernel:%{__kernel_qf %{V}-%{R}}}%{?_without_dist_kernel:%{__kernel_ver}} | tr '-' '_') + # Requires name = version-release %requires_releq() %{!?1:ERROR}%{?2:ERROR}%{?1:%{!?2:%{expand:%%requires_eq_to -r %1 %1}}} # Requires: name = version @@ -450,22 +490,13 @@ CXXFLAGS="%{rpmcxxflags}" \ # Requires: name >= version (version based on querying package %2) %requires_ge_to(r) %{!?2:ERROR}%{?3:ERROR}%{?2:%{!?3:%(if ! LC_ALL=C rpm -q --qf 'Requires: %1 >= %|E?{%{E}:}|%{V}%{?-r:-%{R}}\\n' %2 | grep '^Requires:'; then echo "BuildRequires: %2"; fi)}} -%apache_modules_api %{expand:%%global apache_modules_api %(awk '/#define MODULE_MAGIC_NUMBER_MAJOR/ {print $3}' /usr/include/apache/ap_mmn.h 2>/dev/null || echo ERROR)}%apache_modules_api +# helper for renaming packages +# %rename old-package +%rename() \ +Obsoletes: %{1} < %{?epoch:%{epoch}:}%{?version:%{version}}%{?release:-%{release}} \ +Provides: %{1} = %{?epoch:%{epoch}:}%{?version:%{version}}%{?release:-%{release}} -# kernel version-release handling -%__kernel_ver %{expand:%%global __kernel_ver %( \\ - Z=$([ -f '%{_kernelsrcdir}/include/generated/utsrelease.h' ] && awk -F'"' '/UTS_RELEASE/{print $2}' %{_kernelsrcdir}/include/{linux/version,generated/utsrelease}.h 2>/dev/null || awk -F'"' '/UTS_RELEASE/{print $2}' %{_kernelsrcdir}/include/linux/{version,utsrelease}.h 2>/dev/null); \\ - Z=${Z:-$(awk -F' = ' '/^VERSION/{v=$2} /^PATCHLEVEL/{p=$2} /^SUBLEVEL/{s=$2} /^EXTRAVERSION/{e=$2} END {printf("%d.%d.%d%s", v, p, s, e)}' %{_kernelsrcdir}/Makefile 2>/dev/null)}; \\ - echo ${Z:-ERROR}; \\ -)}%__kernel_ver - -%__kernel_rel %{expand:%%global __kernel_rel %(Z=$(LC_ALL=C rpm -qf %{_kernelsrcdir}/include/linux/fs.h 2>/dev/null --qf "%{R}" | grep -v "is not"); echo ${Z:-ERROR})}%__kernel_rel -%__kernel_rpmvr %{expand:%%global __kernel_rpmvr %(Z=$(LC_ALL=C rpm -qf %{_kernelsrcdir}/include/linux/fs.h 2>/dev/null --qf "%{V}-%{R}" | grep -v "is not"); echo ${Z:-ERROR})}%__kernel_rpmvr -%_kernel_ver %{expand:%%global _kernel_ver %{__kernel_ver}%{?with_dist_kernel:%(echo %{__kernel_ver} | grep -q -e - || echo -%{__kernel_rel})}}%_kernel_ver -%_kernel_ver_str %{expand:%%global _kernel_ver_str %(echo %{!?_without_dist_kernel:%{__kernel_rpmvr}}%{?_without_dist_kernel:%{__kernel_ver}} | sed -e 's/-/_/g')}%_kernel_ver_str - -# `uname -r` to be used in @release field -%_kernel_vermagic %{expand:%%global _kernel_vermagic %(echo %{_kernel_ver} | sed -e 's/-/_/g')}%_kernel_vermagic +%apache_modules_api %{expand:%%global apache_modules_api %(awk '/#define MODULE_MAGIC_NUMBER_MAJOR/ {print $3}' /usr/include/apache/ap_mmn.h 2>/dev/null || echo ERROR)}%apache_modules_api # sgml macros %xmlcat_add() /usr/bin/xmlcatalog --noout --add nextCatalog \"\" %1 /etc/xml/catalog ; @@ -521,12 +552,23 @@ CXXFLAGS="%{rpmcxxflags}" \ l=${l#/usr/share/man/}; \ l=${l#/usr/X11R6/man/}; \ else \ - l=$m; \ + l=${a#$RPM_BUILD_ROOT$i/}; \ + l=${l%/*}; \ + l="$l/$m"; \ fi; \ rm -f $a; \ echo ".so $l" > $a; \ echo >&2 "Converted ${a#$RPM_BUILD_ROOT} from symlink to man link: $l"; \ done; \ + # verify that .so links point to existing files (not allowed to point to "other package") \ + # TODO: iterate over all man dirs, but in Th there is only one true man dir \ + err=$(grep -rl '^\.so ' "$RPM_BUILD_ROOT$i" | while read doc; do \ + l=$(grep -r '^\.so ' "$doc"); \ + l=${l#.so }; \ + d=$(dirname $doc); \ + test -e $RPM_BUILD_ROOT$i/$l || test -e $d/$(basename $l) || echo " ${doc#$RPM_BUILD_ROOT} points to inexistent manpage: $l"; \ + done); \ + test "$err" != "" && { echo >&2 "Man page link errors:"; echo >&2 "$err"; exit 1; }; \ find "$RPM_BUILD_ROOT$i" -type f -size +%{_min_compress_bytes}c -print | xargs -r %{__gzip} -9nf; \ fi; \ done; \ @@ -613,7 +655,7 @@ if [ -d "$RPM_BUILD_ROOT" ]; then \ fi; }; __spec_install_post_strip } } } #----------------------------------------------------------------- -# remove all RPATH from executable binaries and shared object files +# remove all RPATH/RUNPATH from executable binaries and shared object files # # Requires: find, awk, cut, xargs, chrpath, uname # @@ -630,12 +672,12 @@ if [ -d "$RPM_BUILD_ROOT" ]; then \ objs=`echo "$files" | xargs -r -d'\\n' file | awk -F: '/ELF.*(executable.*dynamically linked|shared object)/ {print $1}'`; \ fi; \ if [ -n "$objs" ]; then \ - printf "Remove RPATH from %d executable binaries and shared object files.\n" $(echo "$objs" | wc -l); \ + printf "Remove RPATH/RUNPATH from %d executable binaries and shared object files.\n" $(echo "$objs" | wc -l); \ echo "$objs" | \ while read file; do \ rpath= ; \ chmod u+w "$file"; \ - for dir in $(chrpath -l "$file" | awk '/RPATH=/ { gsub(/.*RPATH=/,""); gsub(/:/," "); print $0 }'); do \ + for dir in $(chrpath -l "$file" | awk '/(R|RUN)PATH=/ { gsub(/.*RPATH=/,""); gsub(/.*RUNPATH=/,""); gsub(/:/," "); print $0 }'); do \ case $dir in \ '$ORIGIN' ) \ if [ "$rpath" = "" ] ; then rpath="$dir" ; \ @@ -686,6 +728,30 @@ __spec_install_post_check_so() { \ %{!?no_install_post_check_so:return $fail;} \ }; __spec_install_post_check_so }} +#----------------------------------------------------------------- +# Verify that for each directory under /var/run package contains +# tmpfiles.d configuration. Warn and terminate build if config is +# missing. +# +#%no_install_post_check_tmpfiles 1 +# +%__spec_install_post_check_tmpfiles { \ +__spec_install_post_check_tmpfiles() { \ +%{!?debug:set +x;} \ + fail=0; \ + echo "Checking /var/run <-> tmpfiles.d completeness..."; \ + for d in $RPM_BUILD_ROOT/var/run/*; do \ + [ -d "$d" ] || continue; \ + d=${d##$RPM_BUILD_ROOT}; \ + if ! grep -qsF "$d" $RPM_BUILD_ROOT/usr/lib/tmpfiles.d/*.conf $RPM_BUILD_ROOT/etc/tmpfiles.d/*.conf; then\ + echo "No tmpfiles configuration for '$d'";\ + fail=1 ; \ + fi \ + done ; \ + echo " DONE"; \ + %{!?no_install_post_check_tmpfiles:return $fail;} \ +}; __spec_install_post_check_tmpfiles }} + #----------------------------------------------------------------- # Find and gzip all kernel modules # @@ -812,9 +878,24 @@ fi; \ # %__noautoreqfiles %(sed -e s'/#.*//' /etc/rpm/noautoreqfiles)%{?_noautoreqfiles: %{_noautoreqfiles}} %__noautoprovfiles %(sed -e s'/#.*//' /etc/rpm/noautoprovfiles)%{?_noautoprovfiles: %{_noautoprovfiles}} -%__noautoreq %(sed -e s'/#.*//' /etc/rpm/noautoreq)%{?_noautoreq: %{_noautoreq}} %__noautoreqdep %(sed -e s'/#.*//' /etc/rpm/noautoreqdep)%{?_noautoreqdep: %{_noautoreqdep}} %__noautoprov %(sed -e s'/#.*//' /etc/rpm/noautoprov)%{?_noautoprov: %{_noautoprov}} +%__noautoreq %(sed -e s'/#.*//' /etc/rpm/noautoreq) \ + %{?_noautoreq: %{_noautoreq}} \ + %{?_noautoreq_pear: %{__noauto_regexp_helper -p pear %{_noautoreq_pear}}} \ + %{?_noautoreq_perl: %{__noauto_regexp_helper -p perl %{_noautoreq_perl}}} \ + %{?_noautoreq_java: %{__noauto_regexp_helper -p java %{_noautoreq_java}}} \ + %{nil} + +# helper for wrapping _noautoreq between perl() or pear() +# Author: Elan Ruusamäe +# Usage: +# BuildRequires: rpmbuild(macros) >= 1.654 +# %define _noautoreq_pear Excluded.php PEAR/Something.php +# %define _noautoreq_perl Apache::.* +# BuildRequires: rpmbuild(macros) >= 1.672 +# %define _noautoreq_java ClassDataVersion +%__noauto_regexp_helper(p:) %(echo "%*" | awk 'BEGIN{RS=" "}{printf("%{-p*}\\\\\\(%%s\\\\\\) ", $1)}') #%_noautocompressdoc %{nil} # @@ -842,15 +923,27 @@ fi; \ # Ruby %__ruby /usr/bin/ruby -%ruby_archdir %{expand:%%global ruby_archdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["archdir"]' 2>/dev/null || echo ERROR)}%ruby_archdir -%ruby_ridir %{expand:%%global ruby_ridir %(%{__ruby} -r rbconfig -e 'include Config; print File.join(CONFIG["datadir"], "ri", CONFIG["ruby_version"], "system")' 2>/dev/null || echo ERROR)}%ruby_ridir -%ruby_rubylibdir %{expand:%%global ruby_rubylibdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["rubylibdir"]' 2>/dev/null || echo ERROR)}%ruby_rubylibdir -%ruby_vendorarchdir %{expand:%%global ruby_vendorarchdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["vendorarchdir"]' 2>/dev/null || echo ERROR)}%ruby_vendorarchdir -%ruby_vendorlibdir %{expand:%%global ruby_vendorlibdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["vendorlibdir"]' 2>/dev/null || echo ERROR)}%ruby_vendorlibdir -%ruby_sitearchdir %{expand:%%global ruby_sitearchdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["sitearchdir"]' 2>/dev/null || echo ERROR)}%ruby_sitearchdir -%ruby_sitelibdir %{expand:%%global ruby_sitelibdir %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["sitelibdir"]' 2>/dev/null || echo ERROR)}%ruby_sitelibdir + +# get rbconfig parameter +%__ruby_rbconfig() %(%{__ruby} -r rbconfig -e 'print RbConfig::CONFIG["%1"]' 2>/dev/null || echo ERROR) + +%ruby_archdir %{expand:%%global ruby_archdir %{__ruby_rbconfig archdir}}%ruby_archdir +%ruby_libdir %{expand:%%global ruby_libdir %{__ruby_rbconfig rubylibdir}}%ruby_libdir +%ruby_ridir %{expand:%%global ruby_ridir %(%{__ruby} -r rbconfig -e 'print File.join(RbConfig::CONFIG["datadir"], "ri", RbConfig::CONFIG["ruby_version"], "system")' 2>/dev/null || echo ERROR)}%ruby_ridir +%ruby_rubylibdir %{expand:%%global ruby_rubylibdir %{__ruby_rbconfig rubylibdir}}%ruby_rubylibdir +%ruby_vendorarchdir %{expand:%%global ruby_vendorarchdir %{__ruby_rbconfig vendorarchdir}}%ruby_vendorarchdir +%ruby_vendorlibdir %{expand:%%global ruby_vendorlibdir %{__ruby_rbconfig vendorlibdir}}%ruby_vendorlibdir +%ruby_sitearchdir %{expand:%%global ruby_sitearchdir %{__ruby_rbconfig sitearchdir}}%ruby_sitearchdir +%ruby_sitedir %{expand:%%global ruby_sitedir %{__ruby_rbconfig sitedir}}%ruby_sitedir +%ruby_sitelibdir %{expand:%%global ruby_sitelibdir %{__ruby_rbconfig sitelibdir}}%ruby_sitelibdir %ruby_rdocdir /usr/share/rdoc -%ruby_version %{expand:%%global ruby_version %(%{__ruby} -r rbconfig -e 'print Config::CONFIG["ruby_version"]' 2>/dev/null || echo ERROR)}%ruby_version +%ruby_vendordir %{expand:%%global ruby_vendordir %{__ruby_rbconfig vendordir}}%ruby_vendordir +%ruby_version %{expand:%%global ruby_version %{__ruby_rbconfig ruby_version}}%ruby_version + +%ruby_gemdir %{expand:%%global ruby_gemdir %(%{__ruby} -r rbconfig -e 'print RbConfig::CONFIG["rubylibdir"].sub(RbConfig::CONFIG["ruby_version"], "gems/#{RbConfig::CONFIG["ruby_version"]}")' 2>/dev/null || echo ERROR)}%{ruby_gemdir} +%ruby_specdir %{ruby_gemdir}/specifications + +# deprecated, similar functionality autogenerated with rpm5 %ruby_ver_requires_eq Requires: ruby(ver) = %ruby_version %ruby_mod_ver_requires_eq Requires: ruby-modules(ver) = %ruby_version @@ -872,21 +965,33 @@ fi; \ # "_ts" if ZTS enabled, empty otherwise %zend_zts %{expand:%%global _zend_zts_%{?_zend_zts} 1}%{?_zend_zts_1:_ts} +# name of php package +%php_name php%{?php_suffix} +# use rpmbuild -D 'php_suffix 54' to build php extension for php 5.4 +# NOTE: error output must be empty. otherwise can't build pecl packages if no php*-devel is installed +%php_suffix %{expand:%%global php_suffix %(c=$(php-config --sysconfdir 2>/dev/null) || echo '' && echo ${c#/etc/php})%%{nil}}%php_suffix + +# phpXY, version always present for using current php version (in regards of php*-devel package) +%php_versuffix %{expand:%%global php_versuffix %((IFS=.; set -- $(php-config --version); echo $1$2))%%{nil}}%php_versuffix + +# php cli. version that php headers are installed for +%__php /usr/bin/php%{php_versuffix} + # helper macro -%__php_api_requires(v:) Requires: php%{-v*}(%{expand:%1}) = %{expand:%{%{!?2:%{1}}%{?2}}} +%__php_api_requires(v:) Requires: %{php_name}(%{expand:%1}) = %{expand:%{%{!?2:%{1}}%{?2}}} # macros for public use # for php extensions (php-pecl) %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 debug php_debug} \ +%{__php_api_requires 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 debug php_debug} \ +%{__php_api_requires thread-safety _zend_zts} # for php pdo modules (php-pecl-PDO_*) %requires_php_pdo_module %{__php_api_requires PDO_API php_pdo_api_version} @@ -901,8 +1006,8 @@ if [ -x /etc/rc.d/init.d/php-fcgi ]; then \ %service -q php-fcgi restart \ fi \ fi \ -if [ -x /etc/rc.d/init.d/php-fpm ]; then \ - %service -q php-fpm restart \ +if [ -x /etc/rc.d/init.d/%{php_name}-fpm ]; then \ + %service -q %{php_name}-fpm restart \ fi \ %{nil} @@ -986,7 +1091,7 @@ fi \ # Python 3.x # python main version -%__python3 python3 +%__python3 /usr/bin/python3 %py3_ver %{expand:%%global py3_ver %(%{__python3} -c "import sys; print(sys.version[:3])" 2>/dev/null || echo ERROR)}%py3_ver # directories @@ -1003,14 +1108,24 @@ fi \ %py3_ocomp %{__python3} -O -c "import compileall; import sys; compileall.compile_dir(sys.argv[1], ddir=sys.argv[1][len('$RPM_BUILD_ROOT'):])" +# node.js libdir +# Requirements: +# BuildRequires: rpmbuild(macros) >= 1.634 +%nodejs_libdir /usr/lib/node_modules + +# bash-completion 2.0 completions dir +# Requirements: +# BuildRequires: rpmbuild(macros) >= 1.673 +# Requires: bash-completion >= 2.0 +%bash_compdir /usr/share/bash-completion/completions # Hardlink binary identical .pyc and .pyo files %__spec_install_post_py_hardlink {\ %{!?no_install_post_py_hardlink: __spec_install_post_py_hardlink() { \ %{!?debug:set +x;} \ -local a b c=0 t=0; \ +local a b c=0 t=0 pyc=%{tmpdir}/%{name}-%{version}-%{release}__rpm_pyc; \ if [ -d "$RPM_BUILD_ROOT" ]; then \ - find "$RPM_BUILD_ROOT" -name '*.pyc' > __rpm_pyc; \ + find "$RPM_BUILD_ROOT" -name '*.pyc' > $pyc; \ while read a; do \ b="${a%.pyc}.pyo"; \ if cmp -s "$a" "$b"; then \ @@ -1018,16 +1133,27 @@ if [ -d "$RPM_BUILD_ROOT" ]; then \ c=$((c + 1)); \ fi; \ t=$((t + 1)); \ - done < __rpm_pyc; \ + done < $pyc; \ [ $t -gt 0 ] && printf "Hardlink Python files: %d/%d files hardlinked\n" $c $t; \ - rm -f __rpm_pyc; \ + rm -f $pyc; \ fi; \ }; __spec_install_post_py_hardlink } } -# remove python sources, so that check-files won't complain -%py_postclean() \ +# Remove Python 2.x sources, +# PLD Linux policy is to package only compiled .py[co] for Python 2.x libraries. +# Author: Elan Ruusamäe +# +# Usage: +# %py_postclean /usr/share/extra -x keepme.py,keeptoo.py +# Options: +# -x - comma separated of file basenames to preserve (rpmbuild(macros) >= 1.658) +# ARGS - extra directories to clean for .py sources +# +# BuildRequires: rpmbuild(macros) >= 1.189 +# +%py_postclean(x:) \ for d in %{py_sitescriptdir} %{py_sitedir} %*; do \ - [ ! -d "$RPM_BUILD_ROOT$d" ] || find "$RPM_BUILD_ROOT$d" -name '*.py' -print0 | xargs -0r -l512 rm;\ + [ ! -d "$RPM_BUILD_ROOT$d" ] || find "$RPM_BUILD_ROOT$d" -name '*.py' -print0 %{-x:| grep -ZzvE '/(%(echo '%{-x*}' | tr ',' '|'))$'} | xargs -0r -l512 rm;\ done \ %{nil} @@ -1057,6 +1183,7 @@ fi; \ %xmms_effect_plugindir %{expand:%%global xmms_effect_plugindir %(xmms-config --effect-plugin-dir 2>/dev/null || echo ERROR)}%xmms_effect_plugindir %xmms_general_plugindir %{expand:%%global xmms_general_plugindir %(xmms-config --general-plugin-dir 2>/dev/null || echo ERROR)}%xmms_general_plugindir +%_host_base_arch %{expand:%%global _host_base_arch %(echo %{_host_cpu} | sed 's/i.86/i386/;s/athlon/i386/;s/pentium./i386/;s/amd64/x86_64/;s/ia32e/x86_64/;s/sparcv./sparc/;s/arm.*/arm/')}%_host_base_arch %_target_base_arch %{expand:%%global _target_base_arch %(echo %{_target_cpu} | sed 's/i.86/i386/;s/athlon/i386/;s/pentium./i386/;s/amd64/x86_64/;s/ia32e/x86_64/;s/sparcv./sparc/;s/arm.*/arm/')}%_target_base_arch # user/group checking macros @@ -1244,8 +1371,7 @@ fi \ # Requires: rc-scripts # -n option: # BuildRequires: rpmbuild(macros) >= 1.450 -%service(qn) {{%(export noop=%{-n:1} quiet=%{-q:1}; /usr/lib/rpm/service_generator.sh %{*}) };} - +%service(qn) {{%(export noop=%{-n:1} quiet=%{-q:1} RPM_BUILD_ROOT=%{buildroot}; /usr/lib/rpm/service_generator.sh %{*}) };} # Java macros. based on jpackage macros.java # @@ -1389,7 +1515,7 @@ echo -e "\\n" >> %{_mavendepmapdir}/maven2-depmap.xml # JAVA macros specific for PLD # Directory for tomcat context configuration files -%_tomcatconfdir %{_sharedstatedir}/tomcat/conf/Catalina/localhost +%_tomcatconfdir /etc/tomcat/Catalina/localhost # Tomcat cache path %_tomcatcachedir %{_sharedstatedir}/tomcat/work/Catalina/localhost @@ -1448,7 +1574,7 @@ fi \ # Command invoking PEAR CLI # Same as /usr/bin/pear, except we force GMT timezone -%__pear %__php -doutput_buffering=1 -dopen_basedir="" -dmemory_limit=-1 -ddate.timezone=GMT %{php_pear_dir}/pearcmd.php +%__pear %__php -doutput_buffering=1 -dopen_basedir="" -dmemory_limit=-1 -ddate.timezone=GMT /usr/share/pear/pearcmd.php %pear_install(a:d:n:zD) \ %__pear \\\ @@ -1516,6 +1642,7 @@ fi \ f = io.open("%{_docdir}/%{name}-%{version}/optional-packages.txt", "r") \ if f then \ for l in f:lines() do print(l); end \ + f:close() \ end \ %{nil} @@ -1601,17 +1728,76 @@ done \ %build_kernel_modules(p:P:m:C:c) \ %{!?-m:%{error:%{0}: Required module name/list missing} exit 1} \ \ -%define Opts \\\\\\\ -%if "%{_target_base_arch}" != "%{_arch}" \\\ - %if "%{_arch}" == "x86_64" && "%{_target_base_arch}" == "i386" \\\ - CC="%{kgcc}" ARCH=%{_target_base_arch} \\\ +%define Opts \\\\\\\ +%if "%{_target_base_arch}" != "%{_host_base_arch}" \\\ + %if "%{_host_base_arch}" == "x86_64" && "%{_target_base_arch}" == "i386" \\\ + CC="%{__cc}" ARCH=%{_target_base_arch} \\\ %else \\\ ARCH=%{_target_base_arch} CROSS_COMPILE=%{_target_cpu}-pld-linux- \\\ %endif \\\ %else \\\ - CC="%{kgcc}" \\\ + CC="%{__cc}" \\\ %endif \ -%define MakeOpts HOSTCC="%{kgcc}" SYSSRC=%{_kernelsrcdir} SYSOUT=$PWD/o \\\\\\\ +%define MakeOpts HOSTCC="%{__cc}" SYSSRC=%{_kernelsrcdir} SYSOUT=$PWD/o \\\\\\\ + O=$PWD/o %{?with_verbose:V=1} %{Opts} \ + \ +%{?-C:cd %{-C*}} \ +compile() { \ + local L="<" PATCH_SH; \ + [[ '%{*}' != *$L$L* ]] || PATCH_SH="set -x -e;$(cat)" \ + set -e -x \ + \ + [ -r "%{_kernelsrcdir}/.config" ] || exit 1 \ + rm -rf o \ + install -d o/include/linux o/include/generated o/arch/x86/include o/arch/powerpc/lib \ + ln -sf %{_kernelsrcdir}/.config o/.config \ + ln -sf %{_kernelsrcdir}/Module.symvers o/Module.symvers \ + if [ -f %{_kernelsrcdir}/include/generated/autoconf.h ]; then \ + ln -sf %{_kernelsrcdir}/include/generated/autoconf.h o/include/generated/autoconf.h \ + ln -s ../generated/autoconf.h o/include/linux/autoconf.h \ + else \ + ln -sf %{_kernelsrcdir}/include/linux/autoconf.h o/include/linux/autoconf.h \ + fi \ + if [ -d %{_kernelsrcdir}/arch/x86/include/generated ]; then \ + ln -s %{_kernelsrcdir}/arch/x86/include/generated o/arch/x86/include \ + fi \ + \ + set +x \ + [ -z "$PATCH_SH" ] || echo "$PATCH_SH" | %__spec_build_shell \ + set -x \ + \ + install -d o/include/config \ + touch o/include/config/MARKER \ + ln -sf %{_kernelsrcdir}/include/config/auto.conf o/include/config/auto.conf \ + ln -sf %{_kernelsrcdir}/scripts o/scripts \ + \ + %{!?-c:%{__make} -C %{_kernelsrcdir} clean \\\ + RCS_FIND_IGNORE="-name '*.[ks]o' -o" \\\ + ${1+"$@"} \\\ + M=$PWD %{MakeOpts}} \ + \ + %{__make} -C %{_kernelsrcdir} modules \\\ + ${1+"$@"} \\\ + M=$PWD CONSTIFY_PLUGIN="" %{MakeOpts} \ +%{?-C:cd -} \ +} \ +compile %{*} \ +%{nil} + +%build_kernel_modules_compat(p:P:m:C:c) \ +%{!?-m:%{error:%{0}: Required module name/list missing} exit 1} \ + \ +%define Opts \\\\\\\ +%if "%{_target_base_arch}" != "%{_host_base_arch}" \\\ + %if "%{_host_base_arch}" == "x86_64" && "%{_target_base_arch}" == "i386" \\\ + CC="%{__cc}" ARCH=%{_target_base_arch} \\\ + %else \\\ + ARCH=%{_target_base_arch} CROSS_COMPILE=%{_target_cpu}-pld-linux- \\\ + %endif \\\ +%else \\\ + CC="%{__cc}" \\\ +%endif \ +%define MakeOpts HOSTCC="%{__cc}" SYSSRC=%{_kernelsrcdir} SYSOUT=$PWD/o \\\\\\\ O=$PWD/o %{?with_verbose:V=1} %{Opts} \ \ %{?-C:cd %{-C*}} \ @@ -1630,7 +1816,7 @@ for cfg in ${cfgs:-dist}; do \ ln -sf %{_kernelsrcdir}/Module.symvers-$cfg o/Module.symvers \ if [ -f %{_kernelsrcdir}/include/generated/autoconf-$cfg.h ]; then \ ln -sf %{_kernelsrcdir}/include/generated/autoconf-$cfg.h o/include/generated/autoconf.h \ - ln -s ../generated/autoconf.h o/include/linux/autoconf.h \ + ln -s ../generated/autoconf.h o/include/linux/autoconf.h \ else \ ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h o/include/linux/autoconf.h \ fi \ @@ -1651,7 +1837,7 @@ for cfg in ${cfgs:-dist}; do \ %endif \ \ %{!?-c:%{__make} -C %{_kernelsrcdir} clean \\\ - RCS_FIND_IGNORE="-name '*.[ks]o' -o" \\\ + RCS_FIND_IGNORE="-name '*.[ks]o' -o" \\\ ${1+"$@"} \\\ M=$PWD %{MakeOpts}} \ \ @@ -1665,7 +1851,7 @@ for cfg in ${cfgs:-dist}; do \ done \ %{?-C:cd -} \ } \ -compile %{*}\ +compile %{*} \ %{nil} @@ -1684,17 +1870,48 @@ compile %{*}\ # with same name exists in kernel already # -n -- name of modprobe config file to use (without .conf extension) # for defining aliases, only useful with -s +# -D -- DESTDIR, base directory for installed files, +# defaults to RPM_BUILD_ROOT -%install_kernel_modules(m:d:s:n:) \ +%install_kernel_modules(m:d:s:n:D:) \ %{!?-m:%{error:%{0}: Required module name (-m) missing}exit 1} \ %{!?-d:%{error:%{0}: Required module directory missing}exit 1} \ %{?-n:%{!?-s:%{error:%{0}: Modprobe .conf file requires module suffix}exit 1}} \ \ -%define KernelD $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver} \ -%define ModprobeD $RPM_BUILD_ROOT%{_sysconfdir}/modprobe.d/%{_kernel_ver} \ +INSTALLROOT=%{-D*} \ +[ -n "$INSTALLROOT" ] || INSTALLROOT=$RPM_BUILD_ROOT \ + \ +%define KernelD $INSTALLROOT/lib/modules/%{_kernel_ver} \ +%define ModprobeD $INSTALLROOT%{_sysconfdir}/modprobe.d/%{_kernel_ver} \ \ __install_kernel_modules() { \ -%{!?debug:set +x;} \ +%{!?debug:set +x;} \ + \ +for MODULE in {%{-m*},}; do \ + [ -n "${MODULE}" ] || continue \ + MNAME=${MODULE##*/} \ + install -m 644 -D ${MODULE}.ko %{KernelD}/%{-d*}/${MNAME}%{-s:-%{-s*}}.ko \ + %{?-s:install -d %{ModprobeD} \ + echo "alias ${MNAME} ${MNAME}-%{-s*}" >> %{ModprobeD}/%{-n*}.conf} \ +done \ +} \ +__install_kernel_modules \ +unset INSTALLROOT \ +%{nil} + +%install_kernel_modules_compat(m:d:s:n:D:) \ +%{!?-m:%{error:%{0}: Required module name (-m) missing}exit 1} \ +%{!?-d:%{error:%{0}: Required module directory missing}exit 1} \ +%{?-n:%{!?-s:%{error:%{0}: Modprobe .conf file requires module suffix}exit 1}} \ + \ +INSTALLROOT=%{-D*} \ +[ -n "$INSTALLROOT" ] || INSTALLROOT=$RPM_BUILD_ROOT \ + \ +%define KernelD $INSTALLROOT/lib/modules/%{_kernel_ver} \ +%define ModprobeD $INSTALLROOT%{_sysconfdir}/modprobe.d/%{_kernel_ver} \ + \ +__install_kernel_modules() { \ +%{!?debug:set +x;} \ local cfgs='%{?with_dist_kernel:%{?with_smp: smp}%{?with_up: up}}%{!?with_dist_kernel: nondist}' \ \ for MODULE in {%{-m*},}; do \ @@ -1702,7 +1919,7 @@ for MODULE in {%{-m*},}; do \ for cfg in ${cfgs:-dist}; do \ [ "$cfg" = smp ] && suf=smp || suf= \ MNAME=${MODULE##*/} \ - install -D ${MODULE}-$cfg.ko \\\ + install -m 644 -D ${MODULE}-$cfg.ko \\\ %{KernelD}$suf/%{-d*}/${MNAME}%{-s:-%{-s*}}.ko \ %{?-s:install -d %{ModprobeD}$suf \ echo "alias ${MNAME} ${MNAME}-%{-s*}" \\\ @@ -1711,27 +1928,48 @@ for MODULE in {%{-m*},}; do \ done \ } \ __install_kernel_modules \ +unset INSTALLROOT \ %{nil} # patchset macros +# generate SourceX urls from range START STOP +# Format can be SINGLE format char of %e, %f, %g, see seq(1) +# The sources start from 10000 +# # Author: Elan Ruusamäe # # Usage: # %patchset_source -f [] # %patchset_patch [] -# # If is omited, it is assumed to be . # # For example in preamble: # %patchset_source -f ftp://ftp.vim.org/pub/editors/vim/patches/7.0/7.0.%03g 33 44 # and in %prep: # %patchset_patch 33 44 - -# generate SourceX urls from range START STOP -# Format can be SINGLE format char of %e, %f, %g, see seq(1) -# The sources start from 10000 -%patchset_source(f:b:) %( - base=%{-b*}%{!-b*:10000}; +# +# Using sources list: +# BuildRequires: rpmbuild(macros) >= 1.426 +# %patchset_source -f -s +# %patchset_patch -s +# For example (ncurses): +# BuildRequires: rpmbuild(macros) >= 1.683 +# %patchset_source -f ftp://dickey.his.com/ncurses/%{basever}/ -s sources +# %patchset_patch -s sources -p1 +# + +%patchset_source(f:b:s:) %( + base=%{-b*}%{!-b*:10000} +%{-s: + baseurl='%{-f*}' + filelist='%{-s*}' + i=$base + while read checksum file; do + printf "Patch%d: %s%s\\n" $i "$baseurl" "$file" + i=$((i+1)) + done < $filelist +} +%{!-s: start=$(expr $base + %1); end=$(expr $base + %{?2}%{!?2:%{1}}); # we need to call seq twice as it doesn't allow two formats @@ -1739,21 +1977,37 @@ __install_kernel_modules \ seq -f '%{-f*}' %1 %{?2}%{!?2:%{1}} > %{tmpdir}/__ps2; paste %{tmpdir}/__ps{1,2}; rm -f %{tmpdir}/__ps{1,2}; +} ) \ %{nil} # apply sources from %patchset_source # -p specify -pX for %patch line # -b base offset: defaults to 10000 -%patchset_patch(f:p:b:) %( - base=%{-b*}%{!-b*:10000}; +# -s filelist to read files from +%patchset_patch(f:p:b:s:) %( + base=%{-b*}%{!-b*:10000} + patchlevel=%{-p*:-p%{-p*}} +%{-s: + filelist='%{-s*}' + i=$base + while read checksum file; do + printf "patch%d %s\\n" $i "$patchlevel" | sed -e s,^,%%, + i=$((i+1)) + done < $filelist +} +%{!-s: start=$(expr $base + %1); end=$(expr $base + %{?2}%{!?2:%{1}}); echo ": patchset_patch %1%{?2: to %2}"; - seq -f 'patch%g %{-p*:-p%{-p*}}' $start $end | sed -e s,^,%%,; + seq -f "patch%g $patchlevel" $start $end | sed -e s,^,%%,; +} ) \ %{nil} +# return EXPANDED source url N from current spec +%sourceurl(n:) %(test "$IN_RPM" = 1 && exit 1; export IN_RPM=1; rpmbuild --nodigest --nosignature --nobuild -D "prep %%dump" %{_specdir}/%{name}.spec 2>&1 | awk '$2 ~ /^SOURCEURL%{-n*}/ {print $3}') + # browser plugins v2 # Author: Elan Ruusamäe # @@ -1815,7 +2069,11 @@ end\ for _, s in ipairs({%{expand:%%__lua_split %*}}) do\ if not t[s] then\ print("Adding "..s.." to /etc/shells")\ - f = io.open("/etc/shells", "a"); f:write(s.."\\n"); f:close()\ + f = io.open("/etc/shells", "a")\ + if f then\ + f:write(s.."\\n")\ + f:close()\ + end\ end\ end\ %{nil} @@ -1835,7 +2093,11 @@ s=""\ for _, l in pairs(t) do\ s=s..l.."\\n"\ end\ -io.open("/etc/shells", "w"):write(s)\ +f = io.open("/etc/shells", "w")\ +if f then\ + f:write(s)\ + f:close()\ +end\ %{nil} # Backwards compat. Use of %lua_ prefixed macros is preferred as these are cleaner to read. @@ -1927,11 +2189,11 @@ else: \ # # Requirements: # BuildRequires: sed >= 4.0 -# BuildRequires: rpmbuild(macros) >= 1.565 +# BuildRequires: rpmbuild(macros) >= 1.674 # NB: make sure this macro stays on one line # NB: make sure it includes newline escape -%undos(f:i) %{-f:%{__find} -regextype posix-extended -%{-i:i}regex '^.+\\.(%(echo %{-f*} | tr ',' '|'))$' -print0 | xargs -0} %{__sed} -i -e 's,\\r$,,' %* \ +%undos(f:i) %{-f:%{__find} -type f -regextype posix-extended -%{-i:i}regex '^.+\\.(%(echo %{-f*} | tr ',' '|'))$' -print0 | xargs -0} %{__sed} -i -e 's,\\r$,,' %* \ %{nil} # Hook to register nagios object based plugins in Nagios NRPE daemon config. @@ -1953,20 +2215,25 @@ else: \ # Requirements: # Requires: grep # Requires: sed >= 4.0 -# BuildRequires: rpmbuild(macros) >= 1.552 +# BuildRequires: rpmbuild(macros) >= 1.685 %nagios_nrpe(a:d:c:f:) {\ - m=$(md5sum < /etc/nagios/nrpe.cfg); \ + if %{__grep} -q '^include_dir=/etc/nagios/nrpe.d' /etc/nagios/nrpe.cfg && [ -d /etc/nagios/nrpe.d ]; then \ + file=/etc/nagios/nrpe.d/%{-a*}%{-d*}.cfg; \ + else \ + file=/etc/nagios/nrpe.cfg; \ + fi; \ + m=$(test -f $file && md5sum < $file); \ %{-a:# on -a and config exists \ if [ -f /etc/nagios/nrpe.cfg ]; then \ - if ! %{__grep} -q '^command\[%{-a*}\]' /etc/nagios/nrpe.cfg; then \ - %{__sed} -ne 's/^[ \t]*command_line[ \t]\+\(.\+\)/command[%{-a*}]=\1/p' %{-f*} >> /etc/nagios/nrpe.cfg; \ + if [ ! -f $file ] || ! %{__grep} -q '^command\[%{-a*}\]' $file; then \ + %{__sed} -ne 's/^[ \t]*command_line[ \t]\+\(.\+\)/command[%{-a*}]=\1/p' %{-f*} >> $file; \ fi; \ fi;} \ %{-d:# on package remove, -d and config exists \ - if [ "$1" = "0" -a -f /etc/nagios/nrpe.cfg ]; then \ - %{__sed} -i -e '/^[ \t]*command\[%{-d*}\]/d' /etc/nagios/nrpe.cfg; \ + if [ "$1" = "0" -a -f $file ]; then \ + %{__sed} -i -e '/^[ \t]*command\[%{-d*}\]/d' $file; \ fi;} \ - if [ "$m" != "$(md5sum < /etc/nagios/nrpe.cfg)" ]; then \ + if [ "$m" != "$(md5sum < $file)" ]; then \ %service -q nrpe restart; \ fi; \ }%{nil} @@ -1998,6 +2265,7 @@ fi; \ # pre/post script for -upstart subpackages # # Author: Jacek Konieczny +# Author: Elan Ruusamäe # # Usage: # %upstart_post service_name @@ -2011,15 +2279,16 @@ fi; \ # %upstart_postun %{name} # # Requirements: -# BuildRequires: rpmbuild(macros) >= 1.560 +# BuildRequires: rpmbuild(macros) >= 1.690 # Requires: rc-scripts >= 0.4.3 # migrate from init script to upstart job %upstart_post() \ - if [ -f /var/lock/subsys/%1 ]; then \ + if [ -x /sbin/initctl ] && [ -f /var/lock/subsys/%1 ]; then \ /sbin/service --no-upstart %1 stop \ /sbin/service %1 start \ - fi + fi \ +%{nil} # 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 @@ -2028,7 +2297,8 @@ fi; \ 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 + fi \ +%{nil} # Haskell Macros # BuildRequires: rpmbuild(macros) >= 1.608 @@ -2040,60 +2310,134 @@ fi; \ # %ghc_pkg_recache() {{ \ umask 022; \ - /usr/bin/ghc-pkg recache; \ + [ ! -x /usr/bin/ghc-pkg ] || /usr/bin/ghc-pkg recache; \ };} \ %{nil} -# pre/post script for -systemd subpackages +# pre/post script for packages supporting systemd units # # Author: Bartlomiej Zimon +# Jan Rękorajski # # Usage: # %systemd_reload +# %systemd_service service_name1.service service_name2.service +# %systemd_service_enable service_name1.service service_name2.service +# %systemd_service_disable service_name1.service service_name2.service +# %systemd_service_start service_name1.service service_name2.service +# %systemd_service_stop service_name1.service service_name2.service +# %systemd_service_restart service_name1.service service_name2.service +# %systemd_service_reload service_name1.service service_name2.service +# # %systemd_post service_name1.service service_name2.service -# %systemd_preun service_name1.service service_name2.service +# %systemd_preun service_name1.service service_name2.service +# %systemd_trigger service_name1.service service_name2.service # # Sample: -# %post systemd -# %systemd_reload -# or if service must be enabled by default: -# %post systemd +# %post # %systemd_post %{name}.service # -# %preun systemd +# %preun # %systemd_preun %{name}.service # -# %postun systemd +# %postun # %systemd_reload # +# %triggerpostun -- %{name} < first-version-with-systemd-units +# %systemd_trigger %{name}.service +# # Requirements: -# BuildRequires: rpmbuild(macros) >= 1.627 -# Requires: systemd-units >= 37-0.10 +# BuildRequires: rpmbuild(macros) >= 1.671 +# Requires: systemd-units >= 38 %systemd_reload /bin/systemd_booted && SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog /bin/systemctl --quiet daemon-reload || : +%systemd_service_enable() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemctl --quiet enable %{*} || : \ + /bin/systemd_booted && echo 'Run "/bin/systemctl start %{*}" to start %{*}.' || : \ +%{nil} + +%systemd_service_disable() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemctl --quiet disable %{*} || : \ +%{nil} + +%systemd_service() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet %{*} || : \ +%{nil} + +%systemd_service_start() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet start %{*} || : \ +%{nil} + +%systemd_service_stop() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet stop %{*} || : \ +%{nil} + +%systemd_service_restart() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet try-restart %{*} || : \ +%{nil} + +%systemd_service_reload() \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet reload %{*} || : \ +%{nil} + +%systemd_trigger() \ +want_enable_service() { \ + [ -f /etc/sysconfig/rpm ] && . /etc/sysconfig/rpm \ + [ ${RPM_ENABLE_SYSTEMD_SERVICE:-yes} = no ] && return 1 \ + [ "$(echo /etc/rc.d/rc[0-6].d/S[0-9][0-9]${1%.service})" = "/etc/rc.d/rc[0-6].d/S[0-9][0-9]${1%.service}" ] && return 1 \ + return 0 \ +}\ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + for s in %{*}; do \ + if want_enable_service $s; then \ + /bin/systemctl --quiet enable $s || : \ + fi \ + done \ +%{nil} + %systemd_post() \ export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ /bin/systemd_booted && /bin/systemctl --quiet daemon-reload || : \ if [ $1 -eq 1 ]; then \ /bin/systemctl --quiet enable %{*} || : \ - fi \ - if [ $1 -gt 1 ] && [ -z "$NORESTART" ]; then \ - /bin/systemctl --quiet try-restart %{*} || : \ + /bin/systemd_booted && echo 'Run "/bin/systemctl start %{*}" to start %{*}.' || : \ + elif [ -z "$NORESTART" ]; then \ + /bin/systemd_booted && /bin/systemctl --quiet try-restart %{*} || : \ + else \ + /bin/systemd_booted && echo 'Run "/bin/systemctl restart %{*}" to restart %{*}.' || : \ fi \ %{nil} %systemd_preun() \ if [ $1 -eq 0 ]; then \ - export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog; \ - /bin/systemctl --no-reload --quiet disable %{*} || : \ - if /bin/systemd_booted; then \ - /bin/systemctl --quiet stop %{*} || : \ - fi \ + export SYSTEMD_LOG_LEVEL=warning SYSTEMD_LOG_TARGET=syslog \ + /bin/systemd_booted && /bin/systemctl --quiet stop %{*} || : \ + /bin/systemctl --quiet disable %{*} || : \ fi \ %{nil} %systemdunitdir /lib/systemd/system +%systemduserunitdir /usr/lib/systemd/user +%systemdtmpfilesdir /usr/lib/tmpfiles.d + +#----------------------------------------------------------------- +# Update hardware database index +# +# Requirements: +# BuildRequires: rpmbuild(macros) >= 1.691 +# Requires: udev-core >= 1:196 + +%udev_hwdb_update() \ +/sbin/udevadm hwdb --update >/dev/null 2>&1 || : \ +%{nil} # EOF