#!/bin/sh
+
+set -e
+
+die() {
+ echo >&2 "$0: $*"
+ exit 1
+}
+
+if [ "$1" = "-k" ]; then
+ cache=yes
+ shift
+else
+ cache=no
+fi
+
# product name
product=chrome
# name
# this package
specfile=$name.spec
# arch to check package. irrelevant for actual arch
-arch=i386
+arch=x86_64
# branch: stable, beta, unstable. default: stable
branch=${1:-stable}
stable|beta|unstable)
;;
*)
- echo "$0: Unknown branch: $branch. Supported branches: stable, beta, unstable." >&2
- exit 1
+ die "Unknown branch: $branch. Supported branches: stable, beta, unstable."
;;
esac
-sourceurl=http://dl.google.com/linux/$product/rpm/stable/$arch
-
-set -e
-
-echo -n "Fetching latest version... "
-t=$(mktemp)
+sourceurl=https://dl.google.com/linux/$product/rpm/stable/$arch
-# poldek is buggy, see https://bugs.launchpad.net/poldek/+bug/1026762
-#poldek -q --st=metadata --source "$sourceurl/" --update
-#poldek -q --skip-installed --st=metadata --source "$sourceurl/" --cmd "ls google-chrome-$branch" > $t
+fetch_version() {
+ echo -n "Fetching latest version for $branch... "
-wget -c $sourceurl/repodata/primary.xml.gz
-zcat primary.xml.gz | perl -ne 'm{<name>google-'$product-$branch'</name>} and m{<version epoch="0" ver="([\d.]+)" rel="(\d+)"/>} and print "$1 $2"' > $t
+ # poldek is buggy, see https://bugs.launchpad.net/poldek/+bug/1026762
+ #poldek -q --st=metadata --source "$sourceurl/" --update
+ #poldek -q --skip-installed --st=metadata --source "$sourceurl/" --cmd "ls google-chrome-$branch" > $t
-set -- $(sed -re "s,^.+-([^-]+)-([^-]+).$arch$,\1 \2," $t)
+ set -- $(
+ python3 <<-EOF
+ import repomd
+ repo = repomd.load('$sourceurl')
+ package = repo.find('google-$product-$branch')
+ print("{0} {1}".format(package.version, package.release))
+ EOF
+ )
-rm -f primary.xml.gz
+ ver=$1
+ rel=$2
+}
-ver=$1
-rev=$2
+if [ -n "$2" ]; then
+ ver=$2
+ rel=1
+else
+ fetch_version
+fi
-# extract flash version
-rpm=$name-$branch-$ver-$rev.$arch.rpm
-wget -c $sourceurl/$rpm
-echo ./opt/google/chrome/PepperFlash/manifest.json > $t
-rpm2cpio $rpm | cpio -i -E $t --to-stdout > manifest.json
-flashv=$(awk -F'"' '/version/{print $4}' manifest.json)
-rm -f $t
+if [ -z "$ver" -o -z "$rel" ]; then
+ die "Error: xml file is missing data for ${branch} type"
+fi
-echo "$ver-$rev"
+# check google-chrome ver only
+oldver=$(awk '/^Version:[ \t]+/{print $NF; exit}' $specfile)
+oldrel=$(awk '/^Release:[ \t]+/{print $NF; exit}' $specfile)
+if [ "$oldrel" = "$rel" -a "$oldver" = "$ver" ]; then
+ echo "Already up to date (google-chrome/$ver-$rel)"
+ exit 0
+fi
-oldrev=$(awk '/^%define[ ]+svnrev[ ]+/{print $NF}' $specfile)
-oldflash=$(awk '/^%define[ ]+flashv[ ]+/{print $NF}' $specfile)
-if [ "$oldrev" != "$rev" -o "$oldflash" != "$flashv" ]; then
- echo "Updating $specfile for $ver r$rev"
- sed -i -e "
- s/^\(%define[ \t]\+svnrev[ \t]\+\)[0-9]\+\$/\1$rev/
- s/^\(%define[ \t]\+state[ \t]\+\)[a-z]\+\$/\1$branch/
- s/^\(%define[ \t]\+flashv[ \t]\+\)[a-z]\+\$/\1$flashv/
- s/^\(Version:[ \t]\+\)[.0-9]\+\$/\1$ver/
- " $specfile
- ../builder -ncs -g $specfile || :
- ../builder -ncs -5 $specfile
-else
- echo "Already up to date"
+# check google-chrome
+if [ "$oldrel" = "$rel" -a "$oldver" = "$ver" ]; then
+ echo "Already up to date (google-chrome/$ver-$rel)"
+ exit 0
fi
+
+echo "Updating $specfile for google-chrome/$oldver-$oldrel -> $ver-$rel"
+sed -i -e "
+ s/^\(%define[ \t]\+state[ \t]\+\)[a-z]\+\$/\1$branch/
+ s/^\(Version:[ \t]\+\)[.0-9]\+\$/\1$ver/
+ s/^\(Release:[ \t]\+\)[.0-9]\+\$/\1$rel/
+" $specfile
+../builder -ncs -nd -n5 -g $specfile || :
+../builder -ncs -nd -5 $specfile