Skip to content
commitpkg 2.34 KiB
Newer Older
abort() {
    echo ${1:-"Cancelled"}
    exit 1
}

# Source makepkg.conf; fail if it is not found
if [ -r "/etc/makepkg.conf" ]; then
    source "/etc/makepkg.conf"
    abort "/etc/makepkg.conf not found!"
fi

# Source user-specific makepkg.conf overrides
if [ -r ~/.makepkg.conf ]; then
    source ~/.makepkg.conf
if [ ! -f PKGBUILD ]; then
    abort "No PKGBUILD file"
pkgbase=${pkgbase:-$pkgname}
# set up repo-specific opts depending on how we were called
server="gerolde.archlinux.org"
if [ "$cmd" == "extrapkg" ]; then
    repo="extra"
elif [ "$cmd" == "corepkg" ]; then
    repo="core"
elif [ "$cmd" == "testingpkg" ]; then
    repo="testing"
elif [ "$cmd" == "communitypkg" ]; then
    repo="community"
    server="aur.archlinux.org"
elif [ "$cmd" == "community-testingpkg" ]; then
    repo="community-testing"
    server="aur.archlinux.org"
else
    if [ $# -eq 0 ]; then
        abort "usage: commitpkg <reponame> [-l limit] [commit message]"
# check if all local source files are under version control
Pierre Schmitz's avatar
Pierre Schmitz committed
(for s in ${source[@]} $install; do
    echo $s | grep -vq '://' && \
    svn status $s | grep -q '?' && \
    abort "$s is not under version control"
done) || true

Pierre Schmitz's avatar
Pierre Schmitz committed
# see if any limit options were passed, we'll send them to rsync
unset rsyncopts
if [ "$1" = "-l" ]; then
    rsyncopts="--bwlimit=$2"
if [ -n "$1" ]; then
    svn commit -q -m "upgpkg: $pkgbase $pkgver-$pkgrel
$1" || abort
    svn commit -q || abort
for _arch in ${arch[@]}; do
    pkgfiles=''
    for _pkgname in ${pkgname[@]}; do
        pkgfile=$_pkgname-$pkgver-$pkgrel-${_arch}$PKGEXT
        if [ ! -f $pkgfile -a -f "$PKGDEST/$pkgfile" ]; then
            pkgfile="$PKGDEST/$pkgfile"
        elif [ ! -f $pkgfile ]; then
            echo "Skipping ${_arch}"
        pkgfiles="${pkgfiles} ${pkgfile}"
    rsync -c -h --progress $rsyncopts "${pkgfiles}" -e ssh $server:staging/$repo || abort
    archrelease $repo-${_arch} || abort
if [ "${arch[*]}" == "any" ]; then
    if [ -d ../repos/$repo-i686 -a -d ../repos/$repo-x86_64 ]; then
        pushd ../repos/
        svn rm $repo-i686
        svn rm $repo-x86_64
        svn commit -m "removed $repo-i686 and $repo-x86_64 for $pkgname"
        popd
    fi
fi

# vim:ft=sh:ts=4:sw=4:et: