X-Git-Url: http://git.jankratochvil.net/?p=nethome.git;a=blobdiff_plain;f=bin%2Fdashtopatch;h=a70dff1e5753b5b060b8f846817ca59c39e86348;hp=03ae6529a175637629b33acc26af371310c3f157;hb=f51a7283ffe021d8f9b3bfb14a9cedb37a7d15ca;hpb=9654d9375035f42eee1b5eda8ed0d0e780fc301b diff --git a/bin/dashtopatch b/bin/dashtopatch index 03ae652..a70dff1 100755 --- a/bin/dashtopatch +++ b/bin/dashtopatch @@ -1,29 +1,45 @@ #! /bin/sh set -ex -if [ $# != 1 ] || ! echo "$1" | grep -q '-';then +compile=false +if [ "$1" = -c ];then + compile=true + shift +fi +if [ $# != 1 ];then echo >&2 "Syntax: $0 branch-list-delimited-by-dashes" exit 1 fi -base="master" +if [ -f origin ];then + origin="`cat origin`" +else + origin="origin/master" +fi +base=$origin gerrit=true if git branch -D gerrit;then - git checkout master + git checkout $origin git checkout -b gerrit else gerrit=false fi for elem in $(echo "$1"|tr '-' ' ');do - if [ "$base" = "master" ];then + if [ "$base" = $origin ];then next="$elem" else next="$base-$elem" fi git checkout "$next" - git merge "$base" - if [ -e "$next".patch ];then - echo -e '/^--- /,$d\nw'|ed "$next".patch || : + git merge --no-edit "$base" + if $compile;then + make + fi + if [ "$origin" != "master" ];then + if [ -e "$next".patch ];then + echo -e '/^--- /,$d\nw'|ed "$next".patch || : + fi + git diff "$base" "$next" --|diffdecvs >>"$next".patch + git diff -U9999999 --binary "$base" "$next" -- >"$next".Upatch fi - git diff "$base" "$next"|diffdecvs >>"$next".patch if $gerrit;then cp "$next".patch dashtopatch.patch echo -e '/^--- /,$d\nw'|ed dashtopatch.patch