X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=pear-autoup.sh;h=af1c41ca881482992a0bbda2fa713b5a9e445777;hb=204944374e9a238b8f1e315d204bda5423fbc276;hp=801dfa38fb165f3391a9cd6a1c193576b08090ef;hpb=014c89d7bbe1f5e3868b1a656a094b0cd9d8fbab;p=packages%2Frpm-build-tools.git diff --git a/pear-autoup.sh b/pear-autoup.sh old mode 100644 new mode 100755 index 801dfa3..af1c41c --- a/pear-autoup.sh +++ b/pear-autoup.sh @@ -2,23 +2,32 @@ # Try to update pear packages from current distro repos to latest in # pear.php.net. # -# $Id$ +# Created Date: 2010-08-19 # Author: Elan Ruusamäe set -e +builder=builder + +if [ "$1" = "clean" ]; then + rm -rf php-pear-* php-phpunit-* php-symfony-* php-symfony2-* php-firephp-* php-horde-* php-phpdocs-* pear.* BUILD/* RPMS/* + exit 0 +fi + +if [ $# -gt 0 ]; then + echo "$*" | tr ' ' '\n' > pear.channels +fi + # test that php is working php -r 'echo "PHP is working OK\n";' # test that pear is working pear info PEAR >/dev/null -[ -s pear.ls ] || { poldek --upa; poldek -q -Q --skip-installed --cmd 'ls php-pear-*' > pear.ls; } -[ -s pear.desc ] || { - for pkg in $(cat pear.ls); do - poldek -q --skip-installed --cmd "desc $pkg" - done -} > pear.desc +# needed pkgs for upgrade test +rpm -q php-packagexml2cl php-pear-PEAR_Command_Packaging + +[ -s pear.desc ] || { poldek --upa; poldek -q -Q --skip-installed --cmd 'search -r php-pear | desc' > pear.desc; } [ -s pear.pkgs ] || { awk '/^Source.package:/{print $3}' < pear.desc | sed -re 's,-[^-]+-[^-]+.src.rpm$,,' | sort -u > pear.pkgs @@ -38,10 +47,22 @@ pear info PEAR >/dev/null } [ -s pear.upgrades ] || pear list-upgrades > pear.upgrades +# process urls to aliases +[ -s pear.rpms ] || { + [ -s pear.channels ] || pear list-channels | sed -ne '4,$p' > pear.channels + while read url alias desc; do + awk -vurl="$url" -valias="$alias" '$1 == url {printf("php-%s-%s %s\n", alias, $2, $5)}' pear.upgrades + done < pear.channels > pear.rpms +} + +# clear it if you do not want to upgrade pkgs. i.e bring ac to sync +do_upgrade=1 +#do_upgrade= + +topdir=$(rpm -E %_topdir) for pkg in $(cat pear.pkgs); do # check if there's update in channel - pearpkg=${pkg#php-pear-} - ver=$(awk -vpkg=$pearpkg '$2 == pkg {print $5}' pear.upgrades) + ver=$(awk -vpkg=$pkg '$1 == pkg {print $2}' pear.rpms) [ "$ver" ] || continue # skip already processed packages @@ -49,7 +70,7 @@ for pkg in $(cat pear.pkgs); do # try upgrading with specified version # pldnotify.awk uses "pear remote-info" which does not respect preferred package states - ./builder -bb -u $pkg --upgrade-version $ver --define "_unpackaged_files_terminate_build 1" || { + $builder -bb $pkg ${do_upgrade:+-u --upgrade-version $ver} --define "_unpackaged_files_terminate_build 1" || { cat >&2 <<-EOF $pkg failed @@ -59,7 +80,7 @@ for pkg in $(cat pear.pkgs); do } # check for bad versions (which needs macros - ver=$(awk '/^Version:/{print $2; exit}' $pkg/$pkg.spec) + ver=$(awk '/^Version:/{print $2; exit}' $topdir/$pkg/$pkg.spec) case "$ver" in *RC* | *a* | *b* | *alpha* | *beta* | *dev*) cat >&2 <<-EOF