diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2011-10-14 09:33:07 +0200 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2011-10-14 09:33:07 +0200 |
commit | b06b9f60109ad152e8a6ce8c20f9266648d9d70f (patch) | |
tree | 65199dc8d398671431f0fa5af6b65325dacde09e /archrelease.in | |
parent | 9715ddbe9df6e7a2a37a11c4f3e90a5446459217 (diff) | |
parent | a0c6bf4556e211037b9d9d6de3fd17f798a3c1fb (diff) | |
download | devtools-b06b9f60109ad152e8a6ce8c20f9266648d9d70f.tar.xz |
Merge remote-tracking branch 'cryptocrack/for-pierre'
Diffstat (limited to 'archrelease.in')
-rw-r--r-- | archrelease.in | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/archrelease.in b/archrelease.in new file mode 100644 index 0000000..2f7725e --- /dev/null +++ b/archrelease.in @@ -0,0 +1,66 @@ +#!/bin/bash + +abort() { + echo ${1:-'archrelease: Cancelled'} + exit 1 +} + +if [[ -z $1 ]]; then + abort 'Usage: archrelease <repo>...' +fi + +# TODO: validate repo is really repo-arch + +if [[ ! -f PKGBUILD ]]; then + abort 'archrelease: PKGBUILD not found' +fi + +trunk=${PWD##*/} + +# Normally this should be trunk, but it may be something +# such as 'gnome-unstable' +IFS='/' read -r -d '' -a parts <<< "$PWD" +if [[ "${parts[@]:(-2):1}" == "repos" ]]; then + abort 'archrelease: Should not be in repos dir (try from trunk/)' +fi +unset parts + +if [[ $(svn status -q) ]]; then + abort 'archrelease: You have not committed your changes yet!' +fi + +pushd .. >/dev/null +IFS=$'\n' read -r -d '' -a known_files < <(svn ls -r HEAD "$trunk") +for file in "${known_files[@]}"; do + if [[ ${file:(-1)} = '/' ]]; then + abort "archrelease: subdirectories are not supported in package directories!" + fi +done + +for tag in "$@"; do + echo -n "copying ${trunk} to ${tag}..." + + if [[ -d repos/$tag ]]; then + declare -a trash + trash=() + while read -r file; do + trash+=("repos/$tag/$file") + done < <(svn ls "repos/$tag") + [[ $trash ]] && svn rm -q "${trash[@]}" + else + mkdir -p "repos/$tag" + svn add --parents -q "repos/$tag" + fi + + # copy all files at once from trunk to the subdirectory in repos/ + svn copy -q -r HEAD ${known_files[@]/#/$trunk/} "repos/$tag/" + + echo 'done' +done + +echo -n "releasing package..." +printf -v tag_list ", %s" "$@"; tag_list="${tag_list#, }" +svn commit -q -m "archrelease: copy ${trunk} to $tag_list" || abort +echo 'done' + +popd >/dev/null |