Compare commits

...

40 Commits
0.9.1 ... 0.9.8

Author SHA1 Message Date
Pierre Schmitz
f1c05d870b tagging 0.9.8 2010-08-17 08:33:23 +02:00
Pierre Schmitz
2e6d542220 add [staging] repository 2010-08-17 08:12:03 +02:00
Pierre Schmitz
cfddde22be Fix typo 2010-08-16 21:30:44 +02:00
Pierre Schmitz
f7b67c25ff Provide /dev/{shm,pts} within chroot
implements FS#20246
2010-08-12 18:26:07 +02:00
Pierre Schmitz
65d654a9d7 lddd: correct mktemp usage 2010-07-13 15:10:47 +02:00
Pierre Schmitz
cfdfbd99f8 checkpkg: Improve output message 2010-07-11 13:46:40 +02:00
Pierre Schmitz
a01ed3869c checkpkg: Use temporary working directory 2010-07-11 13:45:51 +02:00
Pierre Schmitz
e656ec7052 Check if ~/.makepkg.conf exists
Fixes FS#20041
2010-07-01 16:51:43 +02:00
Pierre Schmitz
dcc7b6728d prepare 0.9.7 release 2010-06-28 10:32:47 +02:00
Pierre Schmitz
88764c0298 local can only be used within functions 2010-06-28 10:26:38 +02:00
Pierre Schmitz
f2959b8dd5 check if changelog and install files are commited to svn 2010-06-28 09:54:50 +02:00
Pierre Schmitz
0564514df4 remove useless sourcing of PKGBUILD 2010-06-28 09:50:08 +02:00
Pierre Schmitz
edb24eb1a0 Simplify detection of changelog and install files
Thise code was copied from makepkg
2010-06-28 09:48:21 +02:00
Andrea Scarpino
a2132bc899 read {SRC, PKG}DEST from user makepkg.conf
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-06-28 09:35:20 +02:00
Eric Bélanger
964c0d1640 Fixed changelog support to work with makepkg 3.4
Signed-off-by: Eric Bélanger <snowmaniscool@gmail.com>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-06-28 08:07:41 +02:00
Pierre Schmitz
76f3e25949 keep partially transferred files 2010-06-25 21:40:45 +02:00
Pierre Schmitz
85251a1d7b removed mode lines; was not a good idea after all 2010-06-24 10:01:20 +02:00
Eric Bélanger
27df94f51b commitpkg: add newline to make output look more orderly
Signed-off-by: Eric Bélanger <snowmaniscool@gmail.com>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-06-22 17:09:49 +02:00
Pierre Schmitz
12eec95ff8 set version in Makefile 2010-05-02 15:46:51 +02:00
Pierre Schmitz
d4f00819ac copy namcap.log to working dir 2010-05-02 15:42:29 +02:00
Pierre Schmitz
4a4455c086 Set target CARCH before sourcing the PKGBUILD
CARCH might be used within the PKGBUILD to select correct sources
2010-05-02 15:23:54 +02:00
Pierre Schmitz
52e140f2fe exit 1 on build failure 2010-05-02 15:16:53 +02:00
Pierre Schmitz
48dead1af7 Force correct remote file permissions 2010-03-31 23:58:59 +02:00
Pierre Schmitz
17e875f6b3 makechrootpkg: Keep source files even if build fails
implementes FS#18437
2010-03-03 21:49:22 +01:00
Pierre Schmitz
a7c5010d24 Upload any pkg.tar.* file as long as it is canonical 2010-03-03 21:41:53 +01:00
Pierre Schmitz
f72775feac PKGEXT was not defined in the context 2010-03-03 21:38:59 +01:00
Pierre Schmitz
371f57b043 Don't check if package was released already
The checks aren't reliable enough and fail if the local repo is broken due to
network failures. So for now we just allways commit.
2010-02-22 19:11:17 +01:00
Pierre Schmitz
2fe5dbf904 be more fail safe 2010-02-22 08:13:43 +01:00
Eric Bélanger
5036f1250e mkarchroot: Added default pacman cache in usage help
Signed-off-by: Eric Bélanger <snowmaniscool@gmail.com>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-02-21 19:34:11 +01:00
Pierre Schmitz
f00c8f66bd escape line breaks in find command 2010-02-17 23:55:05 +01:00
Pierre Schmitz
df4310025b Use svnversion insead of svn info 2010-02-17 18:27:09 +01:00
Pierre Schmitz
53a864a5aa Use local information to determine if a commit is needed 2010-02-17 18:05:16 +01:00
Pierre Schmitz
849e6c6de5 Check if package was already released 2010-02-17 15:24:54 +01:00
Dan McGee
62e4272ca2 commitpkg: dereference symlinks on package upload
This is a regression introduced after switching to rsync in place of scp;
scp dereferenced symlinks automatically without need for a command-line
option.

Signed-off-by: Dan McGee <dan@archlinux.org>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-02-17 06:11:48 +01:00
Pierre Schmitz
dd488b3c90 add dist target to Makefile 2010-02-13 20:57:34 +01:00
Pierre Schmitz
de38f347a7 add common gitignore file 2010-02-13 20:41:46 +01:00
Pierre Schmitz
362a99b995 apply common coding style 2010-02-13 19:47:16 +01:00
Allan McRae
7a8130fec8 Further fixes to cache_dir handling
1) Typo cachedir -> cache_dir
2) Use $cache_dir when calling pacman

Signed-off-by: Allan McRae <allan@archlinux.org>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-02-13 15:55:23 +01:00
Allan McRae
a6e1f8cfd3 Read cachedir from pacman.conf in working dir
This allows setting a different cachedir for (e.g.) i686 and x86_64
chroots.

Signed-off-by: Allan McRae <allan@archlinux.org>
Signed-off-by: Pierre Schmitz <pierre@archlinux.de>
2010-02-13 09:57:49 +01:00
Pierre Schmitz
70d7baee68 set umask to 0022
this fixes commit 7ce9cd6965
2010-02-13 07:22:54 +01:00
13 changed files with 551 additions and 517 deletions

2
.gitignore vendored Normal file
View File

@@ -0,0 +1,2 @@
*~
devtools-*.tar.gz

View File

@@ -1,3 +1,5 @@
V=0.9.8
all: all:
install: install:
@@ -8,6 +10,7 @@ install:
ln -sf commitpkg $(DESTDIR)/usr/bin/extrapkg ln -sf commitpkg $(DESTDIR)/usr/bin/extrapkg
ln -sf commitpkg $(DESTDIR)/usr/bin/corepkg ln -sf commitpkg $(DESTDIR)/usr/bin/corepkg
ln -sf commitpkg $(DESTDIR)/usr/bin/testingpkg ln -sf commitpkg $(DESTDIR)/usr/bin/testingpkg
ln -sf commitpkg $(DESTDIR)/usr/bin/stagingpkg
ln -sf commitpkg $(DESTDIR)/usr/bin/communitypkg ln -sf commitpkg $(DESTDIR)/usr/bin/communitypkg
ln -sf commitpkg $(DESTDIR)/usr/bin/community-testingpkg ln -sf commitpkg $(DESTDIR)/usr/bin/community-testingpkg
# arch{co,release,rm} # arch{co,release,rm}
@@ -31,6 +34,7 @@ uninstall:
rm $(DESTDIR)/usr/bin/extrapkg rm $(DESTDIR)/usr/bin/extrapkg
rm $(DESTDIR)/usr/bin/corepkg rm $(DESTDIR)/usr/bin/corepkg
rm $(DESTDIR)/usr/bin/testingpkg rm $(DESTDIR)/usr/bin/testingpkg
rm $(DESTDIR)/usr/bin/stagingpkg
rm $(DESTDIR)/usr/bin/communitypkg rm $(DESTDIR)/usr/bin/communitypkg
rm $(DESTDIR)/usr/bin/community-testingpkg rm $(DESTDIR)/usr/bin/community-testingpkg
rm $(DESTDIR)/usr/sbin/mkarchroot rm $(DESTDIR)/usr/sbin/mkarchroot
@@ -42,3 +46,6 @@ uninstall:
rm $(DESTDIR)/usr/bin/archrm rm $(DESTDIR)/usr/bin/archrm
rm $(DESTDIR)/usr/bin/communityco rm $(DESTDIR)/usr/bin/communityco
rm $(DESTDIR)/usr/bin/rebuildpkgs rm $(DESTDIR)/usr/bin/rebuildpkgs
dist:
git archive --format=tar --prefix=devtools-$(V)/ $(V) | gzip -9 > devtools-$(V).tar.gz

4
archco
View File

@@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
if [ "$1" = "" ]; then if [ "$1" = '' ]; then
echo "Usage: archco <package name> [<package name>]" echo 'Usage: archco <package name> [<package name>]'
exit 1 exit 1
fi fi

View File

@@ -1,33 +1,33 @@
#!/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 [ "$(svn diff)" != "" ]; 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 'upgpkg' or 'svn commit' first"
exit 1
fi fi
echo -n 'releasing package...' echo -n 'releasing package...'
pushd .. >/dev/null pushd .. >/dev/null
if [ -d repos/$1 ]; then if [ -d "repos/${1}" ]; then
svn rm --force -q repos/$1 svn rm --force -q "repos/${1}"
svn commit -q -m "archrelease: remove $1" svn commit -q -m "archrelease: remove ${1}" || abort
fi fi
svn copy -q -r HEAD trunk repos/$1 svn copy -q -r HEAD trunk "repos/${1}"
svn commit -q -m "archrelease: copy trunk to $1" svn commit -q -m "archrelease: copy trunk to ${1}" || abort
popd >/dev/null popd >/dev/null
echo 'done' echo 'done'

4
archrm
View File

@@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
if [ "$1" = "" ]; then if [ "$1" = '' ]; then
echo "Usage: archrm <path to checkout>" echo 'Usage: archrm <path to checkout>'
exit 1 exit 1
fi fi

View File

@@ -1,10 +1,10 @@
#!/bin/bash #!/bin/bash
# Source makepkg.conf; fail if it is not found # Source makepkg.conf; fail if it is not found
if [ -r "/etc/makepkg.conf" ]; then if [ -r '/etc/makepkg.conf' ]; then
source "/etc/makepkg.conf" source '/etc/makepkg.conf'
else else
echo "/etc/makepkg.conf not found!" echo '/etc/makepkg.conf not found!'
exit 1 exit 1
fi fi
@@ -18,15 +18,18 @@ strip_url() {
} }
if [ ! -f PKGBUILD ]; then if [ ! -f PKGBUILD ]; then
echo "This must be run in the directory of a built package." echo 'This must be run in the directory of a built package.'
exit 1 exit 1
fi fi
source PKGBUILD . PKGBUILD
if [ "$arch" == "any" ]; then if [ "$arch" == 'any' ]; then
CARCH="any" CARCH='any'
fi fi
TEMPDIR=$(mktemp -d /tmp/checkpkg-script.XXXX)
cd $TEMPDIR
for _pkgname in ${pkgname[@]}; do for _pkgname in ${pkgname[@]}; do
pkgfile=${_pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT} pkgfile=${_pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT}
oldstylepkgfile=${_pkgname}-${pkgver}-${pkgrel}${PKGEXT} oldstylepkgfile=${_pkgname}-${pkgver}-${pkgrel}${PKGEXT}
@@ -61,7 +64,7 @@ for _pkgname in ${pkgname[@]}; do
fi fi
if [ ! -f $oldpkg ]; then if [ ! -f $oldpkg ]; then
if echo $pkgurl | grep "^file:///" > /dev/null 2>&1; then if echo $pkgurl | grep '^file:///' > /dev/null 2>&1; then
cp `echo $pkgurl | sed 's#^file://##'` . cp `echo $pkgurl | sed 's#^file://##'` .
elif [ -f $PKGDEST/$oldpkg ]; then elif [ -f $PKGDEST/$oldpkg ]; then
cp $PKGDEST/$oldpkg . cp $PKGDEST/$oldpkg .
@@ -87,8 +90,8 @@ for _pkgname in ${pkgname[@]}; do
objdump -p $i | grep SONAME objdump -p $i | grep SONAME
done done
else else
echo "No filename differences for $_pkgname." echo "No soname differences for $_pkgname."
fi fi
done done
# vim:ft=sh:ts=4:sw=4:et: echo "Files saved to $TEMPDIR"

View File

@@ -1,64 +1,89 @@
#!/bin/bash #!/bin/bash
abort() { abort() {
echo ${1:-"Cancelled"} echo ${1:-'Cancelled'}
exit 1 exit 1
} }
getpkgfile() {
if [[ ${#} -ne 1 ]]; then
echo 'ERROR: No canonical package found!' >&2
exit 1
elif [ ! -f "${1}" ]; then
echo "ERROR: Package ${1} not found!" >&2
exit 1
fi
echo ${1}
}
# Source makepkg.conf; fail if it is not found # Source makepkg.conf; fail if it is not found
if [ -r "/etc/makepkg.conf" ]; then if [ -r '/etc/makepkg.conf' ]; then
source "/etc/makepkg.conf" source '/etc/makepkg.conf'
else else
abort "/etc/makepkg.conf not found!" abort '/etc/makepkg.conf not found!'
fi fi
# Source user-specific makepkg.conf overrides # Source user-specific makepkg.conf overrides
if [ -r ~/.makepkg.conf ]; then if [ -r ~/.makepkg.conf ]; then
source ~/.makepkg.conf . ~/.makepkg.conf
fi fi
cmd=$(basename "$0") cmd=$(basename "$0")
if [ ! -f PKGBUILD ]; then if [ ! -f PKGBUILD ]; then
abort "No PKGBUILD file" abort 'No PKGBUILD file'
fi fi
source PKGBUILD . PKGBUILD
pkgbase=${pkgbase:-$pkgname} pkgbase=${pkgbase:-$pkgname}
# set up repo-specific opts depending on how we were called # set up repo-specific opts depending on how we were called
server="gerolde.archlinux.org" server='gerolde.archlinux.org'
if [ "$cmd" == "extrapkg" ]; then if [ "$cmd" == 'extrapkg' ]; then
repo="extra" repo='extra'
elif [ "$cmd" == "corepkg" ]; then elif [ "$cmd" == 'corepkg' ]; then
repo="core" repo='core'
elif [ "$cmd" == "testingpkg" ]; then elif [ "$cmd" == 'testingpkg' ]; then
repo="testing" repo='testing'
elif [ "$cmd" == "communitypkg" ]; then elif [ "$cmd" == 'stagingpkg' ]; then
repo="community" repo='staging'
server="aur.archlinux.org" elif [ "$cmd" == 'communitypkg' ]; then
elif [ "$cmd" == "community-testingpkg" ]; then repo='community'
repo="community-testing" server='aur.archlinux.org'
server="aur.archlinux.org" elif [ "$cmd" == 'community-testingpkg' ]; then
repo='community-testing'
server='aur.archlinux.org'
else else
if [ $# -eq 0 ]; then if [ $# -eq 0 ]; then
abort "usage: commitpkg <reponame> [-l limit] [commit message]" abort 'usage: commitpkg <reponame> [-l limit] [commit message]'
fi fi
repo="$1" repo="$1"
shift shift
fi fi
# check if all local source files are under version control # check if all local source files are under version control
(for s in ${source[@]} $install; do (for s in ${source[@]}; do
echo $s | grep -vq '://' && \ echo $s | grep -vq '://' && \
svn status $s | grep -q '?' && \ svn status $s | grep -q '?' && \
abort "$s is not under version control" abort "$s is not under version control"
done) || true done) || true
# check if changelog and install files are under version control
(for i in 'changelog' 'install'; do
filelist=$(sed -n "s/^[[:space:]]*$i=//p" PKGBUILD)
for file in $filelist; do
# evaluate any bash variables used
eval file=${file}
if svn status ${file} | grep -q '?'; then
abort "${file} is not under version control"
fi
done
done) || true
# see if any limit options were passed, we'll send them to rsync # see if any limit options were passed, we'll send them to rsync
unset rsyncopts unset rsyncopts
if [ "$1" = "-l" ]; then if [ "$1" = '-l' ]; then
rsyncopts="--bwlimit=$2" rsyncopts="--bwlimit=$2"
shift 2 shift 2
fi fi
@@ -74,25 +99,26 @@ echo 'done'
for _arch in ${arch[@]}; do for _arch in ${arch[@]}; do
for _pkgname in ${pkgname[@]}; do for _pkgname in ${pkgname[@]}; do
pkgfile=$_pkgname-$pkgver-$pkgrel-${_arch}$PKGEXT pkgfile=$(getpkgfile "$_pkgname-$pkgver-$pkgrel-${_arch}".pkg.tar.* 2>/dev/null)
pkgdestfile=$(getpkgfile "$PKGDEST/$_pkgname-$pkgver-$pkgrel-${_arch}".pkg.tar.* 2>/dev/null)
if [ ! -f $pkgfile -a -f "$PKGDEST/$pkgfile" ]; then if [ ! -f "$pkgfile" -a -f "$pkgdestfile" ]; then
pkgfile="$PKGDEST/$pkgfile" pkgfile="$pkgdestfile"
elif [ ! -f $pkgfile ]; then elif [ ! -f "$pkgfile" ]; then
echo "skipping ${_arch}" echo "skipping ${_arch}"
continue 2 continue 2
fi fi
echo -n 'uploading ' echo -n 'uploading '
rsync -c -h --progress $rsyncopts "${pkgfile}" -e ssh $server:staging/$repo || abort rsync -p --chmod 'ug=rw,o=r' -c -h -L --progress $rsyncopts --partial "${pkgfile}" -e ssh $server:staging/$repo || abort
done done
archrelease $repo-${_arch} || abort archrelease $repo-${_arch} || abort
done done
if [ "${arch[*]}" == "any" ]; then if [ "${arch[*]}" == 'any' ]; then
if [ -d ../repos/$repo-i686 -a -d ../repos/$repo-x86_64 ]; then if [ -d ../repos/$repo-i686 -a -d ../repos/$repo-x86_64 ]; then
pushd ../repos/ >/dev/null pushd ../repos/ >/dev/null
echo -n "removing $repo-i686 and $repo-x86_64..." echo "removing $repo-i686 and $repo-x86_64..."
svn rm $repo-i686 svn rm $repo-i686
svn rm $repo-x86_64 svn rm $repo-x86_64
svn commit -q -m "removed $repo-i686 and $repo-x86_64 for $pkgname" svn commit -q -m "removed $repo-i686 and $repo-x86_64 for $pkgname"
@@ -100,5 +126,3 @@ if [ "${arch[*]}" == "any" ]; then
popd >/dev/null popd >/dev/null
fi fi
fi fi
# vim:ft=sh:ts=4:sw=4:et:

View File

@@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
if [ "$1" = "" ]; then if [ "$1" = '' ]; then
echo "Usage: communityco <package name> [<package name>]" echo 'Usage: communityco <package name> [<package name>]'
exit 1 exit 1
fi fi

View File

@@ -3,12 +3,12 @@
# finddeps - find packages that depend on a given depname # finddeps - find packages that depend on a given depname
# #
if [ "$1" = "" ]; then if [ "$1" = '' ]; then
echo "usage: finddeps <depname>" echo 'usage: finddeps <depname>'
echo "" echo ''
echo "Find packages that depend on a given depname." echo 'Find packages that depend on a given depname.'
echo "Run this script from the top-level directory of your ABS tree." echo 'Run this script from the top-level directory of your ABS tree.'
echo "" echo ''
exit 0 exit 0
fi fi
@@ -37,5 +37,3 @@ for d in $(find . -type d); do
fi fi
cd $tld cd $tld
done done
# vim:ft=sh:ts=4:sw=4:et:

23
lddd
View File

@@ -6,24 +6,25 @@
ifs=$IFS ifs=$IFS
IFS=':' IFS=':'
libdirs="/lib:/usr/lib:/opt/qt/lib:/opt/kde/lib:/usr/lib/libfakeroot:/opt/NX/lib" libdirs='/lib:/usr/lib:/opt/qt/lib:/opt/kde/lib:/usr/lib/libfakeroot:/opt/NX/lib'
extras= extras=
TEMPDIR=$(mktemp /tmp/lddd-script.XXXX) TEMPDIR=$(mktemp -d /tmp/lddd-script.XXXX)
rm $TEMPDIR
mkdir -p $TEMPDIR
echo " Go out and drink some tea, this will take a while :) ..." echo 'Go out and drink some tea, this will take a while :) ...'
# Check ELF binaries in the PATH and specified dir trees. # Check ELF binaries in the PATH and specified dir trees.
for tree in $PATH $libdirs $extras for tree in $PATH $libdirs $extras; do
do
echo DIR $tree echo DIR $tree
# Get list of files in tree. # Get list of files in tree.
files=$(find $tree -type f ! -name '*.a' ! -name '*.la' ! -name '*.py*' ! -name '*.txt' ! -name '*.h' ! -name '*.ttf' ! -name '*.rb' ! -name '*.ko' ! -name '*.pc' ! -name '*.enc' ! -name '*.cf' ! -name '*.def' ! -name '*.rules' ! -name '*.cmi' ! -name '*.mli' ! -name '*.ml' ! -name '*.cma' ! -name '*.cmx' ! -name '*.cmxa' ! -name '*.pod' ! -name '*.pm' ! -name '*.pl' ! -name '*.al' ! -name '*.tcl' ! -name '*.bs' ! -name '*.o' ! -name '*.png' ! -name '*.gif' ! -name '*.cmo' ! -name '*.cgi' ! -name '*.defs' ! -name '*.conf' ! -name '*_LOCALE' ! -name 'Compose' ! -name '*_OBJS' ! -name '*.msg' ! -name '*.mcopclass' ! -name '*.mcoptype') files=$(find $tree -type f ! -name '*.a' ! -name '*.la' ! -name '*.py*' ! -name '*.txt' ! -name '*.h' ! -name '*.ttf' ! \
-name '*.rb' ! -name '*.ko' ! -name '*.pc' ! -name '*.enc' ! -name '*.cf' ! -name '*.def' ! -name '*.rules' ! -name \
'*.cmi' ! -name '*.mli' ! -name '*.ml' ! -name '*.cma' ! -name '*.cmx' ! -name '*.cmxa' ! -name '*.pod' ! -name '*.pm' \
! -name '*.pl' ! -name '*.al' ! -name '*.tcl' ! -name '*.bs' ! -name '*.o' ! -name '*.png' ! -name '*.gif' ! -name '*.cmo' \
! -name '*.cgi' ! -name '*.defs' ! -name '*.conf' ! -name '*_LOCALE' ! -name 'Compose' ! -name '*_OBJS' ! -name '*.msg' ! \
-name '*.mcopclass' ! -name '*.mcoptype')
IFS=$ifs IFS=$ifs
for i in $files for i in $files; do
do
if [ `file $i | grep -c 'ELF'` -ne 0 ]; then if [ `file $i | grep -c 'ELF'` -ne 0 ]; then
# Is an ELF binary. # Is an ELF binary.
if [ `ldd $i 2>/dev/null | grep -c 'not found'` -ne 0 ]; then if [ `ldd $i 2>/dev/null | grep -c 'not found'` -ne 0 ]; then
@@ -43,5 +44,3 @@ done
sort -u $TEMPDIR/pacman.txt >> $TEMPDIR/possible-rebuilds.txt sort -u $TEMPDIR/pacman.txt >> $TEMPDIR/possible-rebuilds.txt
echo "Files saved to $TEMPDIR" echo "Files saved to $TEMPDIR"
# vim:ft=sh:ts=4:sw=4:et:

View File

@@ -8,50 +8,49 @@
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details. # GNU General Public License for more details.
FORCE="n" FORCE='n'
RUN="" RUN=''
MAKEPKG_ARGS="-sr" MAKEPKG_ARGS='-sr'
REPACK="" REPACK=''
COPY="copy" COPY='copy'
WORKDIR=$PWD WORKDIR=$PWD
update_first="0" update_first='0'
clean_first="0" clean_first='0'
install_pkg="" install_pkg=''
add_to_db=0 add_to_db=0
chrootdir="" chrootdir=''
APPNAME=$(basename "${0}") APPNAME=$(basename "${0}")
usage () usage() {
{
echo "usage ${APPNAME} [options] -r <chrootdir> [--] [makepkg args]" echo "usage ${APPNAME} [options] -r <chrootdir> [--] [makepkg args]"
echo " Run this script in a PKGBUILD dir to build a package inside a" echo ' Run this script in a PKGBUILD dir to build a package inside a'
echo " clean chroot. All unrecognized arguments passed to this script" echo ' clean chroot. All unrecognized arguments passed to this script'
echo " will be passed to makepkg." echo ' will be passed to makepkg.'
echo "" echo ''
echo " The chroot dir consists of the following directories:" echo ' The chroot dir consists of the following directories:'
echo " <chrootdir>/{root, copy} but only 'root' is required" echo ' <chrootdir>/{root, copy} but only "root" is required'
echo " by default. The working copy will be created as needed" echo ' by default. The working copy will be created as needed'
echo "" echo ''
echo "The chroot 'root' directory must be created via the following" echo 'The chroot "root" directory must be created via the following'
echo "command:" echo 'command:'
echo " mkarchroot <chrootdir>/root base base-devel sudo" echo ' mkarchroot <chrootdir>/root base base-devel sudo'
echo "" echo ''
echo "Default makepkg args: $MAKEPKG_ARGS" echo "Default makepkg args: $MAKEPKG_ARGS"
echo "" echo ''
echo "Flags:" echo 'Flags:'
echo "-h This help" echo '-h This help'
echo "-c Clean the chroot before building" echo '-c Clean the chroot before building'
echo "-u Update the working copy of the chroot before building" echo '-u Update the working copy of the chroot before building'
echo " This is useful for rebuilds without dirtying the pristine" echo ' This is useful for rebuilds without dirtying the pristine'
echo " chroot" echo ' chroot'
echo "-d Add the package to a local db at /repo after building" echo '-d Add the package to a local db at /repo after building'
echo "-r <dir> The chroot dir to use" echo '-r <dir> The chroot dir to use'
echo "-I <pkg> Install a package into the working copy of the chroot" echo '-I <pkg> Install a package into the working copy of the chroot'
echo "-l <copy> The directory to use as the working copy of the chroot" echo '-l <copy> The directory to use as the working copy of the chroot'
echo " Useful for maintain multiple copies Default: copy" echo ' Useful for maintain multiple copies Default: copy'
exit 1 exit 1
} }
@@ -77,22 +76,21 @@ MAKEPKG_ARGS="$MAKEPKG_ARGS ${*:$OPTIND}"
# See if -R was passed to makepkg # See if -R was passed to makepkg
for arg in ${*:$OPTIND}; do for arg in ${*:$OPTIND}; do
if [ "$arg" = "-R" ]; then if [ "$arg" = '-R' ]; then
REPACK=1 REPACK=1
break; break;
fi fi
done done
if [ "$EUID" != "0" ]; then if [ "$EUID" != '0' ]; then
echo "This script must be run as root." echo 'This script must be run as root.'
exit 1 exit 1
fi fi
if [ ! -f PKGBUILD ]; then if [ ! -f PKGBUILD ]; then
echo "This must be run in a directory containing a PKGBUILD." echo 'This must be run in a directory containing a PKGBUILD.'
exit 1 exit 1
fi fi
source PKGBUILD
if [ ! -d "$chrootdir" ]; then if [ ! -d "$chrootdir" ]; then
echo "No chroot dir defined, or invalid path '$chrootdir'" echo "No chroot dir defined, or invalid path '$chrootdir'"
@@ -100,12 +98,12 @@ if [ ! -d "$chrootdir" ]; then
fi fi
if [ ! -d "$chrootdir/root" ]; then if [ ! -d "$chrootdir/root" ]; then
echo "Missing chroot dir root directory." echo 'Missing chroot dir root directory.'
echo "Try using: mkarchroot $chrootdir/root base base-devel sudo" echo "Try using: mkarchroot $chrootdir/root base base-devel sudo"
usage usage
fi fi
umask 000 umask 0022
if [ ! -d "$copydir" -o "$clean_first" -eq "1" ]; then if [ ! -d "$copydir" -o "$clean_first" -eq "1" ]; then
echo -n 'creating clean working copy...' echo -n 'creating clean working copy...'
mkdir -p "$copydir" mkdir -p "$copydir"
@@ -124,7 +122,7 @@ if [ -n "$install_pkg" ]; then
fi fi
if [ $update_first -eq 1 ]; then if [ $update_first -eq 1 ]; then
mkarchroot -r "pacman -Syu --noconfirm" "$copydir" mkarchroot -r 'pacman -Syu --noconfirm' "$copydir"
fi fi
[ -d "$copydir/build" ] || mkdir "$copydir/build" [ -d "$copydir/build" ] || mkdir "$copydir/build"
@@ -135,19 +133,25 @@ if [ "$REPACK" != "1" ]; then
fi fi
# Get SRC/PKGDEST from makepkg.conf # Get SRC/PKGDEST from makepkg.conf
SRCDEST=$(grep '^SRCDEST=' /etc/makepkg.conf | cut -d= -f2) if [ -f ~/.makepkg.conf ]; then
PKGDEST=$(grep '^PKGDEST=' /etc/makepkg.conf | cut -d= -f2) SRCDEST=$(grep '^SRCDEST=' ~/.makepkg.conf | cut -d= -f2)
PKGDEST=$(grep '^PKGDEST=' ~/.makepkg.conf | cut -d= -f2)
fi
[ -z ${SRCDEST} ] && SRCDEST=$(grep '^SRCDEST=' /etc/makepkg.conf | cut -d= -f2)
[ -z ${PKGDEST} ] && PKGDEST=$(grep '^PKGDEST=' /etc/makepkg.conf | cut -d= -f2)
[ -d "$copydir/pkgdest" ] || mkdir "$copydir/pkgdest" [ -d "$copydir/pkgdest" ] || mkdir "$copydir/pkgdest"
if ! grep "PKGDEST=/pkgdest" "$copydir/etc/makepkg.conf" >/dev/null 2>&1; then if ! grep 'PKGDEST=/pkgdest' "$copydir/etc/makepkg.conf" >/dev/null 2>&1; then
echo "PKGDEST=/pkgdest" >> "$copydir/etc/makepkg.conf" echo 'PKGDEST=/pkgdest' >> "$copydir/etc/makepkg.conf"
fi fi
[ -d "$copydir/srcdest" ] || mkdir "$copydir/srcdest" [ -d "$copydir/srcdest" ] || mkdir "$copydir/srcdest"
if ! grep "SRCDEST=/srcdest" "$copydir/etc/makepkg.conf" >/dev/null 2>&1; then if ! grep 'SRCDEST=/srcdest' "$copydir/etc/makepkg.conf" >/dev/null 2>&1; then
echo "SRCDEST=/srcdest" >> "$copydir/etc/makepkg.conf" echo 'SRCDEST=/srcdest' >> "$copydir/etc/makepkg.conf"
fi fi
# Set target CARCH as it might be used within the PKGBUILD to select correct sources
CARCH=$(eval $(grep '^CARCH=' "$copydir/etc/makepkg.conf"))
# Copy PKGBUILD and sources # Copy PKGBUILD and sources
source PKGBUILD source PKGBUILD
cp PKGBUILD "$copydir/build/" cp PKGBUILD "$copydir/build/"
@@ -160,31 +164,24 @@ for f in ${source[@]}; do
fi fi
done done
install_files=$(grep "install=" PKGBUILD) for i in 'changelog' 'install'; do
for pkg in ${pkgname[@]}; do filelist=$(sed -n "s/^[[:space:]]*$i=//p" PKGBUILD)
install_files+=' ' for file in $filelist; do
install_files+=$(echo $install_files |sed "s/\$pkgname/$pkg/"|sed "s/\${pkgname}/$pkg/") # evaluate any bash variables used
install_files=$(eval echo $install_files |tr '[:blank:]' '\n'|sort |uniq) eval file=${file}
done if [[ -f "$file" ]]; then
cp "$file" "$copydir/build/"
for f in $install_files;do
install="${f#"install="}"
if [ "$install" != "" -a -f "$install" ]; then
cp "$install" "$copydir/build/"
fi fi
done
done done
if [ -f "ChangeLog" ]; then
cp ChangeLog "$copydir/build/"
fi
chown -R nobody "$copydir/build" chown -R nobody "$copydir/build"
chown -R nobody "$copydir/srcdest" chown -R nobody "$copydir/srcdest"
chown -R nobody "$copydir/pkgdest" chown -R nobody "$copydir/pkgdest"
if ! grep "^nobody" "$copydir/etc/sudoers" >/dev/null 2>&1; then if ! grep "^nobody" "$copydir/etc/sudoers" >/dev/null 2>&1; then
touch "$copydir/etc/sudoers" touch "$copydir/etc/sudoers"
echo "nobody ALL=(ALL) NOPASSWD: ALL" >> "$copydir/etc/sudoers" echo 'nobody ALL=(ALL) NOPASSWD: ALL' >> "$copydir/etc/sudoers"
chmod 440 "$copydir/etc/sudoers" chmod 440 "$copydir/etc/sudoers"
fi fi
@@ -197,21 +194,20 @@ cd /build
export HOME=/build export HOME=/build
sudo -u nobody makepkg $MAKEPKG_ARGS || touch BUILD_FAILED sudo -u nobody makepkg $MAKEPKG_ARGS || touch BUILD_FAILED
[ -f BUILD_FAILED ] && exit 1 [ -f BUILD_FAILED ] && exit 1
which namcap &>/dev/null && namcap /build/PKGBUILD /pkgdest/*${PKGEXT} > /pkgdest/namcap.log which namcap &>/dev/null && namcap /build/PKGBUILD /pkgdest/*.pkg.tar.* > /build/namcap.log
exit 0 exit 0
EOF EOF
) > "$copydir/chrootbuild" ) > "$copydir/chrootbuild"
chmod +x "$copydir/chrootbuild" chmod +x "$copydir/chrootbuild"
if mkarchroot -r "/chrootbuild" "$copydir"; then if mkarchroot -r "/chrootbuild" "$copydir"; then
for pkgfile in "${copydir}"/pkgdest/*${PKGEXT}; do for pkgfile in "${copydir}"/pkgdest/*.pkg.tar.*; do
[ -e "$pkgfile" ] || continue [ -e "$pkgfile" ] || continue
_pkgname=$(basename "$pkgfile")
if [ "$add_to_db" -eq "1" ]; then if [ "$add_to_db" -eq "1" ]; then
[ -d "${copydir}/repo" ] || mkdir -p "${copydir}/repo" mkdir -p "${copydir}/repo"
pushd "${copydir}/repo" >/dev/null pushd "${copydir}/repo" >/dev/null
cp "$pkgfile" . cp "$pkgfile" .
repo-add repo.db.tar.gz "$_pkgname" repo-add repo.db.tar.gz "$(basename "$pkgfile")"
popd >/dev/null popd >/dev/null
fi fi
@@ -222,16 +218,7 @@ if mkarchroot -r "/chrootbuild" "$copydir"; then
fi fi
done done
for f in "${copydir}"/srcdest/*; do for l in "${copydir}"/build/{namcap,*-{build,package}}.log; do
[ -e "$f" ] || continue
if [ -d "$SRCDEST" ]; then
mv "$f" "${SRCDEST}"
else
mv "$f" "${WORKDIR}"
fi
done
for l in "${copydir}"/build/*-{build,package}.log; do
[ -f "$l" ] && mv "$l" "${WORKDIR}" [ -f "$l" ] && mv "$l" "${WORKDIR}"
done done
else else
@@ -239,12 +226,19 @@ else
touch "${copydir}/build/BUILD_FAILED" touch "${copydir}/build/BUILD_FAILED"
fi fi
for f in "${copydir}"/srcdest/*; do
[ -e "$f" ] || continue
if [ -d "$SRCDEST" ]; then
mv "$f" "${SRCDEST}"
else
mv "$f" "${WORKDIR}"
fi
done
if [ -e "${copydir}/build/BUILD_FAILED" ]; then if [ -e "${copydir}/build/BUILD_FAILED" ]; then
echo "Build failed, check $copydir/build" echo "Build failed, check $copydir/build"
rm "${copydir}/build/BUILD_FAILED" rm "${copydir}/build/BUILD_FAILED"
exit 1
else else
rm -rf "${copydir}"/build/* rm -rf "${copydir}"/build/*
fi fi
# vim:ft=sh:ts=4:sw=4:et:

View File

@@ -8,69 +8,73 @@
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details. # GNU General Public License for more details.
FORCE="n" FORCE='n'
RUN="" RUN=''
NOCOPY="n" NOCOPY='n'
working_dir="" working_dir=''
cache_dir=$((grep -m 1 '^CacheDir' /etc/pacman.conf || echo 'CacheDir = /var/cache/pacman/pkg') | sed 's/CacheDir\s*=\s*//')
APPNAME=$(basename "${0}") APPNAME=$(basename "${0}")
# usage: usage <exitvalue> # usage: usage <exitvalue>
usage () usage() {
{
echo "usage ${APPNAME} [options] working-dir [package-list | app]" echo "usage ${APPNAME} [options] working-dir [package-list | app]"
echo " options:" echo ' options:'
echo " -r <app> Run 'app' within the context of the chroot" echo ' -r <app> Run "app" within the context of the chroot'
echo " -u Update the chroot via pacman" echo ' -u Update the chroot via pacman'
echo " -f Force overwrite of files in the working-dir" echo ' -f Force overwrite of files in the working-dir'
echo " -C <file> Location of a pacman config file" echo ' -C <file> Location of a pacman config file'
echo " -M <file> Location of a makepkg config file" echo ' -M <file> Location of a makepkg config file'
echo " -n Do not copy config files into the chroot" echo ' -n Do not copy config files into the chroot'
echo " -c <dir> Set pacman cache. Default: ${cache_dir}" echo " -c <dir> Set pacman cache. Default: /var/cache/pacman/pkg"
echo " -h This message" echo ' -h This message'
exit $1 exit $1
} }
while getopts 'r:ufnhC:M:c:' arg; do while getopts 'r:ufnhC:M:c:' arg; do
case "${arg}" in case "${arg}" in
r) RUN="$OPTARG" ;; r) RUN="$OPTARG" ;;
u) RUN="pacman -Syu" ;; u) RUN='pacman -Syu' ;;
f) FORCE="y" ;; f) FORCE='y' ;;
C) pac_conf="$OPTARG" ;; C) pac_conf="$OPTARG" ;;
M) makepkg_conf="$OPTARG" ;; M) makepkg_conf="$OPTARG" ;;
n) NOCOPY="y" ;; n) NOCOPY='y' ;;
c) cache_dir="$OPTARG" ;; c) cache_dir="$OPTARG" ;;
h|?) usage 0 ;; h|?) usage 0 ;;
*) echo "invalid argument '${arg}'"; usage 1 ;; *) echo "invalid argument '${arg}'"; usage 1 ;;
esac esac
done done
if [ "$EUID" != "0" ]; then if [ "$EUID" != '0' ]; then
echo "error: this script must be run as root." echo 'error: this script must be run as root.'
exit 1 exit 1
fi fi
shift $(($OPTIND - 1)) shift $(($OPTIND - 1))
if [ "$RUN" = "" -a $# -lt 2 ]; then if [ "$RUN" = '' -a $# -lt 2 ]; then
echo "you must specify a directory and one or more packages" echo 'you must specify a directory and one or more packages'
usage 1 usage 1
elif [ $# -lt 1 ]; then elif [ $# -lt 1 ]; then
echo "you must specify a directory" echo 'you must specify a directory'
usage 1 usage 1
fi fi
working_dir="$(readlink -f ${1})" working_dir="$(readlink -f ${1})"
shift 1 shift 1
[ "${working_dir}" = "" ] && echo "error: please specify a working directory" && usage 1 [ "${working_dir}" = '' ] && echo 'error: please specify a working directory' && usage 1
if [ -z "$cache_dir" ]; then
cache_conf=${working_dir}/etc/pacman.conf
[ ! -f $cache_conf ] && cache_conf=${pac_conf:-/etc/pacman.conf}
cache_dir=$((grep -m 1 '^CacheDir' $cache_conf || echo 'CacheDir = /var/cache/pacman/pkg') | sed 's/CacheDir\s*=\s*//')
unset cache_conf
fi
# {{{ functions # {{{ functions
chroot_mount () chroot_mount() {
{
[ -e "${working_dir}/sys" ] || mkdir "${working_dir}/sys" [ -e "${working_dir}/sys" ] || mkdir "${working_dir}/sys"
mount -t sysfs sysfs "${working_dir}/sys" mount -t sysfs sysfs "${working_dir}/sys"
@@ -80,36 +84,41 @@ chroot_mount ()
[ -e "${working_dir}/dev" ] || mkdir "${working_dir}/dev" [ -e "${working_dir}/dev" ] || mkdir "${working_dir}/dev"
mount -o bind /dev "${working_dir}/dev" mount -o bind /dev "${working_dir}/dev"
[ -e "${working_dir}/var/cache/pacman/pkg" ] || mkdir -p "${working_dir}/var/cache/pacman/pkg" [ -e "${working_dir}/dev/shm" ] || mkdir "${working_dir}/dev/shm"
mount -t tmpfs shm "${working_dir}/dev/shm"
[ -e "${working_dir}/dev/pts" ] || mkdir "${working_dir}/dev/pts"
mount -t devpts devpts "${working_dir}/dev/pts"
[ -e "${cache_dir}" ] || mkdir -p "${cache_dir}" [ -e "${cache_dir}" ] || mkdir -p "${cache_dir}"
mount -o bind "${cache_dir}" "${working_dir}/var/cache/pacman/pkg" [ -e "${working_dir}/${cache_dir}" ] || mkdir -p "${working_dir}/${cache_dir}"
mount -o bind "${cache_dir}" "${working_dir}/${cache_dir}"
trap 'chroot_umount' 0 1 2 15 trap 'chroot_umount' 0 1 2 15
} }
copy_hostconf () copy_hostconf () {
{
cp /etc/mtab "${working_dir}/etc/mtab" cp /etc/mtab "${working_dir}/etc/mtab"
cp /etc/resolv.conf "${working_dir}/etc/resolv.conf" cp /etc/resolv.conf "${working_dir}/etc/resolv.conf"
} }
chroot_umount () chroot_umount () {
{
umount "${working_dir}/proc" umount "${working_dir}/proc"
umount "${working_dir}/sys" umount "${working_dir}/sys"
umount "${working_dir}/dev/pts"
umount "${working_dir}/dev/shm"
umount "${working_dir}/dev" umount "${working_dir}/dev"
umount "${working_dir}/var/cache/pacman/pkg" umount "${working_dir}/${cache_dir}"
} }
# }}} # }}}
umask 000 umask 0022
if [ "$RUN" != "" ]; then if [ "$RUN" != "" ]; then
# run chroot {{{ # run chroot {{{
#Sanity check #Sanity check
if [ ! -f "${working_dir}/.arch-chroot" ]; then if [ ! -f "${working_dir}/.arch-chroot" ]; then
echo "error: '${working_dir}' does not appear to be a Arch chroot" echo "error: '${working_dir}' does not appear to be a Arch chroot"
echo " please build the image using mkarchroot" echo ' please build the image using mkarchroot'
exit 1 exit 1
fi fi
@@ -119,7 +128,7 @@ if [ "$RUN" != "" ]; then
chroot "${working_dir}" ${RUN} chroot "${working_dir}" ${RUN}
# }}} # }}}
else else
# {{{ build chroot # {{{ build chroot
if [ -e "${working_dir}" -a "${FORCE}" = "n" ]; then if [ -e "${working_dir}" -a "${FORCE}" = "n" ]; then
echo "error: working dir '${working_dir}' already exists - try using -f" echo "error: working dir '${working_dir}' already exists - try using -f"
@@ -131,21 +140,21 @@ else
chroot_mount chroot_mount
pacargs="--noconfirm -v " #--noprogressbar -v pacargs='--noconfirm -v ' #--noprogressbar -v
pacargs="$pacargs --root=${working_dir}" pacargs="$pacargs --root=${working_dir}"
# pacman takes these as relative to the given root # pacman takes these as relative to the given root
pacargs="$pacargs --cachedir=/var/cache/pacman/pkg" pacargs="$pacargs --cachedir=${cache_dir}"
if [ "$pac_conf" != "" ]; then if [ "$pac_conf" != "" ]; then
pacargs="$pacargs --config=${pac_conf}" pacargs="$pacargs --config=${pac_conf}"
fi fi
if [ $# -ne 0 ]; then if [ $# -ne 0 ]; then
op="-Sy" op='-Sy'
if [ "$FORCE" = "y" ]; then if [ "$FORCE" = "y" ]; then
op="${op}f" op="${op}f"
fi fi
if ! pacman ${op} ${pacargs} $@; then if ! pacman ${op} ${pacargs} $@; then
echo "error: failed to install all packages" echo 'error: failed to install all packages'
exit 1 exit 1
fi fi
fi fi
@@ -172,5 +181,3 @@ else
fi fi
# }}} # }}}
fi fi
# vim:ft=sh:ts=4:sw=4:et:

View File

@@ -16,10 +16,10 @@ if [ $# -le 1 ]; then
fi fi
# Source makepkg.conf; fail if it is not found # Source makepkg.conf; fail if it is not found
if [ -r "/etc/makepkg.conf" ]; then if [ -r '/etc/makepkg.conf' ]; then
source "/etc/makepkg.conf" source '/etc/makepkg.conf'
else else
echo "/etc/makepkg.conf not found!" echo '/etc/makepkg.conf not found!'
exit 1 exit 1
fi fi
@@ -28,11 +28,11 @@ die () {
exit 1 exit 1
} }
bump_pkgrel () { bump_pkgrel() {
# Get the current pkgrel from SVN and update the working copy with it # Get the current pkgrel from SVN and update the working copy with it
# This prevents us from incrementing out of control :) # This prevents us from incrementing out of control :)
pbuild=".svn/text-base/PKGBUILD.svn-base" pbuild='.svn/text-base/PKGBUILD.svn-base'
oldrel=$(grep "pkgrel=" $pbuild | cut -d= -f2) oldrel=$(grep 'pkgrel=' $pbuild | cut -d= -f2)
#remove decimals #remove decimals
rel=$(echo $oldrel | cut -d. -f1) rel=$(echo $oldrel | cut -d. -f1)
@@ -42,16 +42,16 @@ bump_pkgrel () {
sed -i "s/pkgrel=$oldrel/pkgrel=$newrel/" PKGBUILD sed -i "s/pkgrel=$oldrel/pkgrel=$newrel/" PKGBUILD
} }
pkg_from_pkgbuild () { pkg_from_pkgbuild() {
# we want the sourcing to be done in a subshell so we don't pollute our current namespace # we want the sourcing to be done in a subshell so we don't pollute our current namespace
export CARCH PKGEXT export CARCH PKGEXT
(. PKGBUILD; echo "$pkgname-$pkgver-$pkgrel-$CARCH$PKGEXT") (source PKGBUILD; echo "$pkgname-$pkgver-$pkgrel-$CARCH$PKGEXT")
} }
chrootdir="$1"; shift chrootdir="$1"; shift
pkgs="$@" pkgs="$@"
SVNPATH="svn+ssh://gerolde.archlinux.org/srv/svn-packages" SVNPATH='svn+ssh://gerolde.archlinux.org/srv/svn-packages'
echo ":: Work will be done in $(pwd)/rebuilds" echo ":: Work will be done in $(pwd)/rebuilds"
@@ -92,10 +92,10 @@ done
cd "$REBUILD_ROOT" cd "$REBUILD_ROOT"
if [ "$FAILED" != "" ]; then if [ "$FAILED" != "" ]; then
echo "Packages failed:" echo 'Packages failed:'
for pkg in $FAILED; do for pkg in $FAILED; do
echo -e "\t$pkg" echo -e "\t$pkg"
done done
fi fi
echo "SVN pkgbumps in svn-packages/ - commit when ready" echo 'SVN pkgbumps in svn-packages/ - commit when ready'