]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - relup.sh
- search pear packages using php-pear dep to match other "pear" channels too
[packages/rpm-build-tools.git] / relup.sh
index a96b843836bdf48d66607c471575c748771c54b1..8b43efe7c6c09597d1846c253bbb2cdf50f96259 100644 (file)
--- a/relup.sh
+++ b/relup.sh
@@ -1,11 +1,8 @@
 #!/bin/sh
-# script to run after "rel up" style change.
+# script to run after "release bump" style change.
 # takes Release from spec and creates commit with message
 # groups similiar commits together.
-# "- rel $rel"
-# - fails when specfile defines Icon: but the icon is not present in SOURCES
-# TODO
-# - optional message after rel: "- rel 9 (rebuild with foolib)"
+# "- release $rel"
 
 set -e
 
@@ -19,9 +16,24 @@ get_dump() {
        echo "$out"
 }
 
+usage="Usage:
+${0##*/} [-i] [-u] [-t] [-n] [-m <MESSAGE>] <SPECLIST>
+
+Options:
+-i
+  Try to increment package release
+-u
+  cvs update first
+-t | -n
+  Test mode (dry-run). 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}')
@@ -32,8 +44,10 @@ get_release() {
 set_release() {
        local specfile="$1"
        local rel="$2"
+       local newrel="$3"
        sed -i -e "
-               s/^\(%define[ \t]\+_rel[ \t]\+\).\+/\1$rel/
+               s/^\(%define[ \t]\+_\?rel[ \t]\+\)$rel\$/\1$newrel/
+               s/^\(Release:[ \t]\+\)$rel\$/\1$newrel/
        " $specfile
 }
 
@@ -42,22 +56,29 @@ if [ ! -x /usr/bin/getopt ]; then
        exit 1
 fi
 
-t=$(getopt -o 'm:it' -n $(dirname "$0") -- "$@") || exit $?
+t=$(getopt -o 'm:inuth' -n "${0##*/}" -- "$@") || exit $?
 # Note the quotes around `$t': they are essential!
 eval set -- "$t"
 
 while true; do
        case "$1" in
-       -t)
-               test=1
-               ;;
        -i)
                inc=1
                ;;
+       -u)
+               update=1
+               ;;
+       -t | -n)
+               test=1
+               ;;
        -m)
                shift
                message="${1#- }"
                ;;
+       -h)
+               echo "$usage"
+               exit 0
+               ;;
        --)
                shift
                break
@@ -71,12 +92,25 @@ while true; do
 done
 
 tmpd=$(mktemp -d "${TMPDIR:-/tmp}/relXXXXXX")
-for spec in "$@"; do
-       spec=${spec%.spec}.spec
+topdir=$(rpm -E '%{_topdir}')
+cd "$topdir"
+for pkg in "$@"; do
+       spec=$(rpm -D "name ${pkg%.spec}" -E '%{_specdir}/%{name}.spec')
+       spec=${spec#$topdir/}
+       if [ "$update" = "1" ]; then
+               ./builder -g -ns "$spec"
+       fi
        rel=$(get_release "$spec")
        if [ "$inc" = 1 ]; then
-               rel=$(expr $rel + 1)
-               set_release "$spec" $rel
+               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")
@@ -84,10 +118,14 @@ for spec in "$@"; do
        echo "$spec" >> "$tmpd/$rel"
 done
 
+n="$(echo -e '\nn')"
+n="${n%%n}"
 for file in $(ls "$tmpd" 2>/dev/null); do
        files=$(cat "$tmpd/$file")
        rel=$(basename "$file")
-       msg="- rel $rel${message:+ ($message)}"
+       msg=""
+       [ -n "$message" ] && msg="$msg- $message$n"
+       msg="$msg- release ${rel%%%*}$n"
        echo cvs ci -m "'$msg'"
        if [ "$test" != 1 ]; then
                cvs ci -m "$msg" $files
This page took 0.0473 seconds and 4 git commands to generate.