]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - pear-autoup.sh
- disable ftp.pl.kernel.org mirror (nxdomain)
[packages/rpm-build-tools.git] / pear-autoup.sh
index 348948094146f62634c4edb85df4ef4b2acb5c8f..2811026b73d7ab8e95ad4dd2e933b3ece16fb1ff 100644 (file)
@@ -7,18 +7,60 @@
 
 set -e
 
-[ -f pear.ls ] || poldek -q --skip-installed --cmd 'ls php-pear-* | desc'
-[ -f pear.pkgs ] || awk '/^Source.package:/{print $3}' < pear.ls | sort -u | sed -re 's,-[^-]+-[^-]+.src.rpm$,,' > pear.pkgs
+# test that php is working
+php -r 'echo "PHP is working OK\n";'
 
-# filter out tests, see https://bugs.launchpad.net/poldek/+bug/620362
-sed -i -e '/-tests/d' pear.pkgs
-# more packages affected
-sed -i -e '/php-pear-Auth_Container_ADOdb/d' pear.pkgs
-sed -i -e '/php-pear-DB_DataObject-cli/d' pear.pkgs
+# test that pear is working
+pear info PEAR >/dev/null
+
+# 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
+
+       # filter out tests, see https://bugs.launchpad.net/poldek/+bug/620362
+       sed -i -e '/-tests/d' pear.pkgs
+       # more packages affected
+       sed -i -e '/php-pear-Auth_Container_ADOdb/d' pear.pkgs
+       sed -i -e '/php-pear-DB_DataObject-cli/d' pear.pkgs
+       # not pear pkg
+       sed -i -e '/^php-pear$/d' pear.pkgs
+}
+
+[ -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%\|})-//"
+
+# clear it if you do not want to upgrade pkgs. i.e bring ac to sync
+do_upgrade=1
+#do_upgrade=
 
 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" ] || continue
+
+       # skip already processed packages
        [ -d $pkg ] && continue
-       ./builder -bb -u $pkg || {
+
+       # try upgrading with specified version
+       # pldnotify.awk uses "pear remote-info" which does not respect preferred package states
+       ./builder -bb $pkg ${do_upgrade:+-u --upgrade-version $ver} --define "_unpackaged_files_terminate_build 1" || {
                cat >&2 <<-EOF
 
                $pkg failed
@@ -28,7 +70,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}' $pkg/$pkg.spec)
        case "$ver" in
        *RC* | *a* | *b* | *alpha* | *beta* | *dev*)
                cat >&2 <<-EOF
@@ -40,5 +82,4 @@ for pkg in $(cat pear.pkgs); do
                exit 1
                ;;
        esac
-
 done
This page took 0.045307 seconds and 4 git commands to generate.