]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - relup.sh
- rel may contain other macros, strip and readd them for increment
[packages/rpm-build-tools.git] / relup.sh
index 2c481aba8148bb8b18ed90cae77e191bd5ad4981..e7d90063f1e62576fd7b30b7bde86486be0031fb 100644 (file)
--- a/relup.sh
+++ b/relup.sh
@@ -8,7 +8,6 @@
 # - optional message after rel: "- rel 9 (rebuild with foolib)"
 
 set -e
-specfile="$1"
 
 get_dump() {
        local specfile="$1"
@@ -17,11 +16,27 @@ get_dump() {
                echo >&2 "You need icon files being present in SOURCES."
                exit 1
        fi
+       echo "$out"
 }
 
+usage="Usage:
+${0##*/} [-i] [-u] [-t] [-m <MESSAGE>] <SPECLIST>
+
+Options:
+-i
+  Try to increment package release
+-u
+  cvs update first
+-t
+  Test mode. do not commit
+-m
+  Specify commit message
+
+"
+
 get_release() {
        local specfile="$1"
-       rel=$(awk '/^%define.*_rel/{print $NF}' $specfile)
+       rel=$(awk '/^%define[   ]+_?rel[        ]+/{print $NF}' $specfile)
        if [ -z "$rel" ]; then
                dump=$(get_dump "$specfile")
                rel=$(echo "$dump" | awk '/PACKAGE_RELEASE/{print $NF; exit}')
@@ -29,15 +44,87 @@ get_release() {
        echo $rel
 }
 
+set_release() {
+       local specfile="$1"
+       local rel="$2"
+       local newrel="$3"
+       sed -i -e "
+               s/^\(%define[ \t]\+_\?rel[ \t]\+\)$rel\$/\1$newrel/
+               s/^\(Release:[ \t]\+\)$rel\$/\1$newrel/
+       " $specfile
+}
+
+if [ ! -x /usr/bin/getopt ]; then
+       echo >&1 "You need to install util-linux to use relup.sh"
+       exit 1
+fi
+
+t=$(getopt -o 'm:iuth' -n "${0##*/}" -- "$@") || exit $?
+# Note the quotes around `$t': they are essential!
+eval set -- "$t"
+
+while true; do
+       case "$1" in
+       -i)
+               inc=1
+               ;;
+       -u)
+               update=1
+               ;;
+       -t)
+               test=1
+               ;;
+       -m)
+               shift
+               message="${1#- }"
+               ;;
+       -h)
+               echo "$usage"
+               exit 0
+               ;;
+       --)
+               shift
+               break
+       ;;
+       *)
+               echo 2>&1 "Internal error: [$1] not recognized!"
+               exit 1
+               ;;
+       esac
+       shift
+done
+
 tmpd=$(mktemp -d "${TMPDIR:-/tmp}/relXXXXXX")
 for spec in "$@"; do
+       spec=${spec%.spec}.spec
+       if [ "$update" = "1" ]; then
+               cvs up "$spec"
+       fi
        rel=$(get_release "$spec")
+       if [ "$inc" = 1 ]; then
+               if [[ $rel = *%* ]]; then
+                       relmacro=${rel#*%}
+                       relnum=${rel%%%*}
+                       newrel=$(expr ${relnum} + 1)
+                       set_release "$spec" $rel "${newrel}%${relmacro}"
+               else
+                       newrel=$(expr ${rel} + 1)
+                       set_release "$spec" $rel $newrel
+               fi
+
+               # refetch release
+               rel=$(get_release "$spec")
+       fi
        echo "$spec" >> "$tmpd/$rel"
 done
 
 for file in $(ls "$tmpd" 2>/dev/null); do
        files=$(cat "$tmpd/$file")
        rel=$(basename "$file")
-       cvs ci -m "- rel $rel" $files
+       msg="- release $rel${message:+ ($message)}"
+       echo cvs ci -m "'$msg'"
+       if [ "$test" != 1 ]; then
+               cvs ci -m "$msg" $files
+       fi
 done
 rm -rf $tmpd
This page took 0.031774 seconds and 4 git commands to generate.