]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - relup.sh
- haskell hackage support
[packages/rpm-build-tools.git] / relup.sh
old mode 100644 (file)
new mode 100755 (executable)
index 7963e2a..9a07402
--- a/relup.sh
+++ b/relup.sh
@@ -17,13 +17,15 @@ get_dump() {
 }
 
 usage="Usage:
-${0##*/} [-i] [-u] [-t] [-n] [-m <MESSAGE>] <SPECLIST>
+${0##*/} [-i] [-g] [-u] [-t|-n] [-m <MESSAGE>] <SPECLIST>
 
 Options:
 -i
   Try to increment package release
+-g
+ get packages if missing, do nothing else
 -u
-  cvs update first
+ update packages (git pull)
 -t | -n
   Test mode (dry-run). do not commit
 -m
@@ -51,12 +53,44 @@ set_release() {
        " $specfile
 }
 
+bump_release() {
+       local release=$1 rel
+
+       rel=$(expr ${release} + 1)
+       echo $rel
+}
+
+# normalize spec
+# takes as input:
+# - PACKAGE/
+# - ./PACKAGE/
+# - PACKAGE
+# - PACKAGE.spec
+# - ./PACKAGE.spec
+# - PACKAGE/PACKAGE
+# - PACKAGE/PACKAGE.spec
+# - ./PACKAGE/PACKAGE.spec
+# - rpm/PACKAGE/PACKAGE
+# - rpm/PACKAGE/PACKAGE.spec
+# - ./rpm/PACKAGE/PACKAGE.spec
+# returns PACKAGE
+package_name() {
+       local specfile="${1%/}" package
+
+       # basename
+       specfile=${specfile##*/}
+       # strip .spec
+       package=${specfile%.spec}
+
+       echo $package
+}
+
 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:inuth' -n "${0##*/}" -- "$@") || exit $?
+t=$(getopt -o 'm:inguth' -n "${0##*/}" -- "$@") || exit $?
 # Note the quotes around `$t': they are essential!
 eval set -- "$t"
 
@@ -68,6 +102,9 @@ while true; do
        -u)
                update=1
                ;;
+       -g)
+               get=1
+               ;;
        -t | -n)
                test=1
                ;;
@@ -91,45 +128,63 @@ while true; do
        shift
 done
 
-tmpd=$(mktemp -d "${TMPDIR:-/tmp}/relXXXXXX")
 topdir=$(rpm -E '%{_topdir}')
+
+n="$(echo -e '\nn')"
+n="${n%%n}"
+
 cd "$topdir"
 for pkg in "$@"; do
-       name=${pkg%.spec} name=${name##*/}
-       spec=$(rpm -D "name $name" -E '%{_specdir}/%{name}.spec')
+       # pkg: package %{name}
+       pkg=$(package_name "$pkg")
+
+       # spec: package/package.spec
+       spec=$(rpm -D "name $pkg" -E '%{_specdir}/%{name}.spec')
        spec=${spec#$topdir/}
-       if [ "$update" = "1" ]; then
+
+       # pkgdir: package/
+       pkgdir=${spec%/*}
+
+       # specname: only spec filename
+       specname=${spec##*/}
+
+       # start real work
+       echo "$pkg ..."
+
+       # get package
+       [ "$get" = 1 -a -d "$pkgdir" ] && continue
+
+       if [ "$update" = "1" -o "$get" = "1" ]; then
                ./builder -g -ns "$spec"
        fi
+
+       [ "$get" = 1 ] && continue
+
+       # update .spec files
        rel=$(get_release "$spec")
        if [ "$inc" = 1 ]; then
                if [[ $rel = *%* ]]; then
                        relmacro=${rel#*%}
-                       relnum=${rel%%%*}
-                       newrel=$(expr ${relnum} + 1)
+                       newrel=$(bump_release ${rel%%%*})
                        set_release "$spec" $rel "${newrel}%${relmacro}"
                else
-                       newrel=$(expr ${rel} + 1)
+                       newrel=$(bump_release ${rel})
                        set_release "$spec" $rel $newrel
                fi
 
                # refetch release
                rel=$(get_release "$spec")
        fi
-       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")
+       # commit the changes
        msg=""
        [ -n "$message" ] && msg="$msg- $message$n"
-       msg="$msg- release ${rel%%%*} (by relup.sh)$n"
-       echo cvs ci -m "'$msg'"
+       msg="$msg- release ${rel%%%*} (by relup.sh)"
+       echo git commit -m "$msg" $spec
        if [ "$test" != 1 ]; then
-               cvs ci -m "$msg" $files
+               cd $pkgdir
+               git commit -m "$msg" $specname
+               git push
+               cd ..
        fi
 done
-rm -rf $tmpd
This page took 0.077372 seconds and 4 git commands to generate.