]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - pear-autoup.sh
on -j define __jobs instead of _smp_mflags
[packages/rpm-build-tools.git] / pear-autoup.sh
old mode 100644 (file)
new mode 100755 (executable)
index ab64c25..af1c41c
@@ -2,11 +2,22 @@
 # 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 <glen@pld-linux.org>
 
 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";'
 
@@ -31,24 +42,27 @@ rpm -q php-packagexml2cl php-pear-PEAR_Command_Packaging
 
 [ -f pear.installed ] || {
        sudo poldek  --update --upa
-       # as sudo & poldek don't allow us to capture (no pipe or redirection work),
-       # we create markers which we could grab when invoked via "script"
-       echo "BEGIN INSTALL PACKAGES"
        sed -e 's,^,install ,' pear.pkgs | sudo poldek
-       echo "END INSTALL PACKAGES"
-       # rm -f pear.installed && script -c ./pear-autoup.sh pear.install.log
-       # sed -ne '/BEGIN INSTALL PACKAGES/,/END INSTALL PACKAGES/p' pear.install.log | grep -vE 'poldek:/.*install|: ambiguous name|equal version installed, skipped|Nothing to do' | less
        touch pear.installed
 }
 [ -s pear.upgrades ] || pear list-upgrades > pear.upgrades
 
-subst=$(pear list-channels | awk -vORS="|" '/^[a-z]/{print $2}')
-subst="s/^php-(${subst%\|})-//"
+# 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=$(echo "$pkg" | sed -re "$subst")
-       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
@@ -56,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
@@ -66,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
This page took 0.046021 seconds and 4 git commands to generate.