From 4ba911d4b8aaa7ee299674a6ef2d9409c01babf2 Mon Sep 17 00:00:00 2001 From: Erich Eckner Date: Mon, 3 May 2021 08:00:02 +0200 Subject: initial commit --- package-status | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ status.php | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ update-packages | 35 ++++++++++++++++++++++++++++++++ 3 files changed, 156 insertions(+) create mode 100755 package-status create mode 100644 status.php create mode 100755 update-packages diff --git a/package-status b/package-status new file mode 100755 index 0000000..a506398 --- /dev/null +++ b/package-status @@ -0,0 +1,59 @@ +#!/bin/bash + +for s in ${HOME}/.backend/archlinuxewe/*/.SRCINFO; do + pkgbase_infos=$( + sed -n ' + /^pkgbase = /,/^\s*$/ { + /^\s\+\(epoch\|pkgver\|pkgrel\|arch\) = / p + } + ' "$s" + ) + epoch=$( + printf '%s\n' "${pkgbase_infos}" \ + | sed ' + s/^\s\+epoch = \(\S\+\)$/\1:/ + t + d + ' + ) + pkgver=$( + printf '%s\n' "${pkgbase_infos}" \ + | sed ' + s/^\s\+pkgver = // + t + d + ' + ) + pkgrel=$( + printf '%s\n' "${pkgbase_infos}" \ + | sed ' + s/^\s\+pkgrel = // + t + d + ' + ) + sed ' + s/^pkgname = // + t + d + ' "$s" \ + | while read -r pkgname; do + pkgname_archs=$( + sed -n ' + /^pkgname = '"${pkgname}"'/,/^\s*$/ { + /^\s\+arch = / p + } + ' "$s" + ) + if [ -z "${pkgname_archs}" ]; then + printf '%s\n' "${pkgbase_infos}" + else + printf '%s\n' "${pkgname_archs}" + fi \ + | sed ' + s/^\s\+arch = /'"${pkgname}"'-'"${epoch}${pkgver}"'-'"${pkgrel}"'-/ + t + d + ' + done +done diff --git a/status.php b/status.php new file mode 100644 index 0000000..2b4e8a9 --- /dev/null +++ b/status.php @@ -0,0 +1,62 @@ + $name, + "pkgname" => $pkgname, + "pkgver" => $pkgver, + "pkgrel" => $pkgrel, + "arch" => $arch + ); +}; + +$f = fopen("packages", "r"); +while (!feof($f)) + $soll[] = trim(fgets($f)); +fclose($f); + +$f = popen("find ~archlinuxewe/os -type f -name '*.pkg.tar.zst.sig' -printf '%f\n'", "r"); +while (!feof($f)) + $ist[] = substr(trim(fgets($f)),0,-16); +pclose($f); + +$ist = array_map('parse', $ist); +$soll = array_map('parse', $soll); + +$pkgs = array(); + +foreach($ist as $i) { + $pkgs[$i["pkgname"]][$i["arch"]]["ist"] = $i; +} +foreach($soll as $i) { + $pkgs[$i["pkgname"]][$i["arch"]]["soll"] = $i; +} + +?> + + + $pkg) { + print "\n"; + foreach ($pkg as $arch => $apkg) { + print "\n"; + } +} + +?> +
" . $pkgname . "
" . $arch . ""; + if ($apkg["ist"]["filename"] == $apkg["soll"]["filename"]) + $farbe = "#008000"; + else + $farbe = "#c00000"; + print ""; + print $apkg["ist"]["filename"]; + print ""; + print $apkg["soll"]["filename"]; + print "
diff --git a/update-packages b/update-packages new file mode 100755 index 0000000..3df1022 --- /dev/null +++ b/update-packages @@ -0,0 +1,35 @@ +#!/bin/bash + +if [ $# -eq 0 ]; then + [ -f "$0.lock" ] && kill -0 $(cat "$0.lock") && exit + echo $$ > "$0.lock" + GIT="git -C ${HOME}/.backend/archlinuxewe" + $GIT pull --rebase >/dev/null + $GIT submodule update >/dev/null + commit=$($GIT rev-parse HEAD) + if ! grep -qxF "${commit}" "$0.commit"; then + $GIT diff "$(cat "$0.commit")" "${commit}" --name-status \ + | sed -n ' + s/^[AM]\s\+// + T + s@/PKGBUILD$@@ + p + ' \ + | parallel -j50 "$0" + fi + "${0%/*}/package-status" > "${0%/*}/packages" + echo "$commit" > "$0.commit" + rm "$0.lock" + exit +fi + +if [ $# -gt 1 ]; then + >&2 echo 'too many arguments' + exit 1 +fi + +cd "${HOME}/.backend/archlinuxewe/$1" +if git archive HEAD -- .SRCINFO >/dev/null 2>&1; then + exit +fi +makepkg --printsrcinfo > .SRCINFO -- cgit v1.2.3-54-g00ecf