archrelease: use bashier syntax

Signed-off-by: Dave Reisner <dreisner@archlinux.org>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
This commit is contained in:
Dave Reisner 2011-08-16 21:36:00 -04:00 committed by Pierre Schmitz
parent e1312ec493
commit 5688152f41
1 changed files with 11 additions and 9 deletions

View File

@ -5,48 +5,50 @@ abort() {
exit 1 exit 1
} }
if [ "$1" = '' ]; then if [[ -z $1 ]]; then
abort 'Usage: archrelease <repo>' abort 'Usage: archrelease <repo>'
fi fi
# TODO: validate repo is really repo-arch # TODO: validate repo is really repo-arch
if [ ! -f PKGBUILD ]; then if [[ ! -f PKGBUILD ]]; then
abort 'archrelease: PKGBUILD not found' abort 'archrelease: PKGBUILD not found'
fi fi
trunk=$(basename $(pwd)) trunk=${PWD##*/}
# Normally this should be trunk, but it may be something # Normally this should be trunk, but it may be something
# such as 'gnome-unstable' # such as 'gnome-unstable'
if [ "$(basename $(dirname $(pwd)))" == "repos" ]; then IFS='/' read -r -d '' -a parts <<< "$PWD"
if [[ "${parts[@]:(-2):1}" == "repos" ]]; then
abort 'archrelease: Should not be in repos dir (try from trunk/)' abort 'archrelease: Should not be in repos dir (try from trunk/)'
fi fi
unset parts
if [ ! -z "$(svn status -q)" ]; then if [[ $(svn status -q) ]]; then
abort 'archrelease: You have not committed your changes yet!' abort 'archrelease: You have not committed your changes yet!'
fi fi
echo -n "releasing package to ${1}..." echo -n "releasing package to ${1}..."
pushd .. >/dev/null pushd .. >/dev/null
if [ -d "repos/${1}" ]; then if [[ -d repos/$1 ]]; then
declare -a trash declare -a trash
while read -r file; do while read -r file; do
trash+=("repos/$1/$file") trash+=("repos/$1/$file")
done < <(svn ls "repos/$1") done < <(svn ls "repos/$1")
svn rm -q "${trash[@]}" svn rm -q "${trash[@]}"
fi fi
if [ ! -d repos ]; then if [[ ! -d repos ]]; then
mkdir repos mkdir repos
svn add -q repos svn add -q repos
fi fi
if [ ! -d "repos/${1}" ]; then if [[ ! -d "repos/$1" ]]; then
mkdir "repos/${1}" mkdir "repos/${1}"
svn add -q "repos/${1}" svn add -q "repos/${1}"
fi fi
known_files=$(svn ls "trunk") known_files=$(svn ls "trunk")
for file in $known_files; do for file in $known_files; do
if [ "$file" != "${file%/}" ]; then if [[ ${file:(-1)} = '/' ]]; then
abort "archrelease: subdirectories are not supported in package directories!" abort "archrelease: subdirectories are not supported in package directories!"
fi fi
done done