be more fail safe
This commit is contained in:
parent
5036f1250e
commit
2fe5dbf904
45
archrelease
45
archrelease
|
@ -1,44 +1,43 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [ "$1" = '' ]; then
|
abort() {
|
||||||
echo 'Usage: archrelease <repo>'
|
echo ${1:-'archrelease: Cancelled'}
|
||||||
exit 1
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ "$1" = '' ]; then
|
||||||
|
abort 'Usage: archrelease <repo>'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f PKGBUILD ]; then
|
if [ ! -f PKGBUILD ]; then
|
||||||
echo 'archrelease: PKGBUILD not found'
|
abort 'archrelease: PKGBUILD not found'
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(basename $(readlink -f .))" != 'trunk' ]; then
|
if [ "$(basename $(readlink -f .))" != 'trunk' ]; then
|
||||||
echo 'archrelease: Not in a package trunk dir'
|
abort 'archrelease: Not in a package trunk dir'
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -z "$(svn status -q)" ]; then
|
if [ ! -z "$(svn status -q)" ]; then
|
||||||
echo 'archrelease: You have not committed your changes yet!'
|
abort 'archrelease: You have not committed your changes yet!'
|
||||||
echo ' Please run "svn commit" first'
|
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -n 'releasing package...'
|
echo -n 'releasing package...'
|
||||||
pushd .. >/dev/null
|
pushd .. >/dev/null
|
||||||
|
|
||||||
trunk=$(svnversion -cn trunk | cut -f1 -d:)
|
trunk=$(svnversion -cn trunk)
|
||||||
repo=$(svnversion -cn "repos/${1}" 2>/dev/null | cut -f1 -d:)
|
[[ $? -gt 0 ]] && abort
|
||||||
if [[ ${trunk} -le ${repo} ]]; then
|
repo=$(svnversion -cn "repos/${1}" 2>/dev/null)
|
||||||
|
if [[ $? -eq 0 ]] && [[ ${trunk%:*} -le ${repo%:*} ]]; then
|
||||||
echo 'already done'
|
echo 'already done'
|
||||||
exit 1
|
else
|
||||||
|
if [ -d "repos/${1}" ]; then
|
||||||
|
svn rm --force -q "repos/${1}"
|
||||||
|
svn commit -q -m "archrelease: remove ${1}" || abort
|
||||||
|
fi
|
||||||
|
svn copy -q -r HEAD trunk "repos/${1}"
|
||||||
|
svn commit -q -m "archrelease: copy trunk to ${1}" || abort
|
||||||
|
popd >/dev/null
|
||||||
|
echo 'done'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d "repos/${1}" ]; then
|
|
||||||
svn rm --force -q "repos/${1}"
|
|
||||||
svn commit -q -m "archrelease: remove ${1}"
|
|
||||||
fi
|
|
||||||
svn copy -q -r HEAD trunk "repos/${1}"
|
|
||||||
svn commit -q -m "archrelease: copy trunk to ${1}"
|
|
||||||
popd >/dev/null
|
|
||||||
echo 'done'
|
|
||||||
|
|
||||||
# vim: set noexpandtab tabstop=8 shiftwidth=8 wrap:textwidth=132 autoindent
|
# vim: set noexpandtab tabstop=8 shiftwidth=8 wrap:textwidth=132 autoindent
|
||||||
# kate: indent-mode normal; indent-width 8; tab-indents on; tab-width 8; word-wrap on; word-wrap-column 132
|
# kate: indent-mode normal; indent-width 8; tab-indents on; tab-width 8; word-wrap on; word-wrap-column 132
|
||||||
|
|
Loading…
Reference in New Issue