summaryrefslogtreecommitdiffstats
path: root/db-repo-remove
diff options
context:
space:
mode:
authorDan McGee <dan@archlinux.org>2011-11-01 15:55:26 +0100
committerPierre Schmitz <pierre@archlinux.de>2011-11-05 14:14:05 +0100
commitbbf00cc90ed8d1bf3bbed1f78acca71b2d624ee2 (patch)
tree755e4fb0a2b93b55716b1d531aef62e093c1e55e /db-repo-remove
parent22dd30328ec4229321f1f96026704ff3cf1cc621 (diff)
downloaddbscripts-bbf00cc90ed8d1bf3bbed1f78acca71b2d624ee2.tar.gz
dbscripts-bbf00cc90ed8d1bf3bbed1f78acca71b2d624ee2.tar.xz
db-repo-{add, remove}: allow specifying multiple packages
This allows invoking these commands for more than one package at a time which is incredibly more efficient as the database doesn't need to be locked, unpacked, modified, changed, and unlocked for every single passed package name or file if you have more than one. Signed-off-by: Dan McGee <dan@archlinux.org>
Diffstat (limited to 'db-repo-remove')
-rwxr-xr-xdb-repo-remove13
1 files changed, 7 insertions, 6 deletions
diff --git a/db-repo-remove b/db-repo-remove
index e55cd07..4f04ed1 100755
--- a/db-repo-remove
+++ b/db-repo-remove
@@ -3,14 +3,14 @@
. "$(dirname $0)/db-functions"
. "$(dirname $0)/config"
-if [ $# -ne 3 ]; then
- msg "usage: $(basename $0) <repo> <arch> <pkgname>"
+if [ $# -lt 3 ]; then
+ msg "usage: $(basename $0) <repo> <arch> <pkgname> ..."
exit 1
fi
repo="$1"
arch="$2"
-pkgname="$3"
+pkgnames=(${@:3})
ftppath="$FTP_BASE/$repo/os"
@@ -28,9 +28,10 @@ for tarch in ${tarches[@]}; do
repo_lock $repo $tarch || exit 1
done
-msg "Removing $pkgname from [$repo]..."
-
for tarch in ${tarches[@]}; do
- arch_repo_remove "${repo}" "${tarch}" ${pkgname}
+ for pkgname in ${pkgnames[@]}; do
+ msg "Removing $pkgname from [$repo]..."
+ done
+ arch_repo_remove "${repo}" "${tarch}" ${pkgnames[@]}
repo_unlock $repo $tarch
done