Send patches - preferably formatted by git format-patch - to patches at archlinux32 dot org.
summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorAaron Griffin <aaron@archlinux.org>2006-12-05 07:30:15 +0000
committerAaron Griffin <aaron@archlinux.org>2006-12-05 07:30:15 +0000
commit6ec8dfc2f3b0923695ad740ac7836a8944073663 (patch)
treec3a54353bb46094c29cdeac8cae413764ee62971 /scripts
parentaad3f6ab1f5e3deac46f13ad5975d9be0759103f (diff)
Added 'abs' and configs to CVS
* Added testing-usability to abs
Diffstat (limited to 'scripts')
-rw-r--r--scripts/abs96
1 files changed, 96 insertions, 0 deletions
diff --git a/scripts/abs b/scripts/abs
new file mode 100644
index 00000000..36fe4c04
--- /dev/null
+++ b/scripts/abs
@@ -0,0 +1,96 @@
+#!/bin/bash
+# vim: set ft=sh ts=2 sw=2
+
+[ -f /etc/abs/abs.conf ] && source /etc/abs/abs.conf
+
+usage() {
+ echo "Arch Build System -- synchronization utility"
+ echo "usage: $0 [-p] [repository1 [repository2 ...]]"
+ echo
+ echo "abs will synchronize PKGBUILD scripts from the CVS repository"
+ echo "into $ABSROOT. You can follow different package trees by"
+ echo "editing /etc/abs/supfile.* files. If no argument is given, abs "
+ echo "will synchronize from supfiles specified in /etc/abs/abs.conf."
+ echo "If -p is specified, the connection is opened in passive mode."
+}
+
+update() {
+ cd $ABSROOT
+ for sup in "${SUPFILES[@]}"; do
+ if [ "$sup" != "testing" ]; then
+ if [ "$sup" = "${sup#!}" ]; then
+ cvsup -L 1 -r 0 -g -b $ABSROOT -c .sup /etc/abs/supfile.$sup
+ fi
+ elif [ "$sup" = "testing" ]; then
+ if [ ! -d /var/abs/testing ]; then
+ mkdir /var/abs/testing;
+ fi
+ cd $ABSROOT/testing
+ cvsup -L 1 -r 0 -g -b $ABSROOT/testing -c .sup /etc/abs/supfile.testing
+ cd $ABSROOT
+ fi
+ done
+}
+
+
+update() {
+ cd $ABSROOT
+ for sup in "${SUPFILES[@]}"; do
+ if [ "$sup" = "${sup#!}" ]; then
+ $CVSUP -L 1 -r 0 -g -b $ABSROOT -P $CONNMODE -c .sup /etc/abs/supfile.$sup
+ fi
+ done
+}
+
+if [ "$1" = "-h" ] || [ "$1" = "--help" ]; then
+ usage
+ exit 0
+fi
+
+if [ ! -d $ABSROOT ]; then
+ echo "abs: $ABSROOT does not exist (or is not a directory)"
+ exit 1
+fi
+if [ ! -w $ABSROOT ]; then
+ echo "abs: no write permissions in $ABSROOT"
+ exit 1
+fi
+
+if [ "`type -p cvsup`" ]; then
+ CVSUP="cvsup"
+elif [ "`type -p csup`" ]; then
+ CVSUP="csup"
+else
+ echo "abs: missing CVS synchronization utility. Install cvsup or csup."
+ exit 1
+fi
+
+if [ ! -d "$ABSROOT" ]; then
+ echo "abs: directory $ABSROOT does not exist"
+ exit 1
+fi
+
+if [ "$1" = "-p" ] || [ "$1" = "--passive" ]; then
+ CONNMODE="-"
+ shift
+else
+ CONNMODE="m"
+ shift
+fi
+
+if [ "$1" = "-p" ] || [ "$1" = "--passive" ]; then
+ CONNMODE="-"
+ shift
+else
+ CONNMODE="m"
+ shift
+fi
+
+if [ "$#" -ne "0" ]; then
+ SUPFILES=("$@")
+fi
+
+update
+
+exit 0
+# vim: set ts=2 noet: