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:
parent
e1312ec493
commit
5688152f41
20
archrelease
20
archrelease
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue