1#!/bin/sh 2## 3## "dotest" is my stupid name for my patch-application script, which 4## I never got around to renaming after I tested it. We're now on the 5## second generation of scripts, still called "dotest". 6## 7## Update: Ryan Anderson finally shamed me into naming this "applymbox". 8## 9## You give it a mbox-format collection of emails, and it will try to 10## apply them to the kernel using "applypatch" 11## 12## The patch application may fail in the middle. In which case: 13## (1) look at .dotest/patch and fix it up to apply 14## (2) re-run applymbox with -c .dotest/msg-number for the current one. 15## Pay a special attention to the commit log message if you do this and 16## use a Signoff_file, because applypatch wants to append the sign-off 17## message to msg-clean every time it is run. 18## 19## git-am is supposed to be the newer and better tool for this job. 20 21USAGE='[-u] [-k] [-q] [-m] (-c .dotest/<num> | mbox) [signoff]' 22. git-sh-setup 23 24git var GIT_COMMITTER_IDENT >/dev/null ||exit 25 26keep_subject= query_apply=continue= utf8= resume=t 27while case"$#"in0)break;;esac 28do 29case"$1"in 30-u) utf8=-u;; 31-k) keep_subject=-k;; 32-q) query_apply=t ;; 33-c)continue="$2"; resume=f;shift;; 34-m) fall_back_3way=t ;; 35-*) usage ;; 36*)break;; 37esac 38shift 39done 40 41case"$continue"in 42'') 43rm-rf .dotest 44mkdir .dotest 45 num_msgs=$(git-mailsplit "$1" .dotest)||exit1 46echo"$num_msgspatch(es) to process." 47shift 48esac 49 50files=$(git-diff-index --cached --name-only HEAD)||exit 51if["$files"];then 52echo"Dirty index: cannot apply patches (dirty:$files)">&2 53exit1 54fi 55 56case"$query_apply"in 57t)touch .dotest/.query_apply 58esac 59case"$fall_back_3way"in 60t) : >.dotest/.3way 61esac 62case"$keep_subject"in 63-k) : >.dotest/.keep_subject 64esac 65 66signoff="$1" 67set x .dotest/0* 68shift 69while case"$#"in0)break;;esac 70do 71 i="$1" 72case"$resume,$continue"in 73 f,$i) resume=t;; 74 f,*)shift 75continue;; 76*) 77 git-mailinfo$keep_subject $utf8 \ 78 .dotest/msg .dotest/patch<$i>.dotest/info ||exit1 79 git-stripspace< .dotest/msg > .dotest/msg-clean 80;; 81esac 82while:;# for fixing up and retry 83do 84 git-applypatch .dotest/msg-clean .dotest/patch .dotest/info "$signoff" 85case"$?"in 860) 87# Remove the cleanly applied one to reduce clutter. 88rm-f .dotest/$i 89;; 902) 91# 2 is a special exit code from applypatch to indicate that 92# the patch wasn't applied, but continue anyway 93;; 94*) 95 ret=$? 96iftest -f .dotest/.query_apply 97then 98echo>&2"* Patch failed." 99echo>&2"* You could fix it up in your editor and" 100echo>&2" retry. If you want to do so, say yes here" 101echo>&2" AFTER fixing .dotest/patch up." 102echo>&2-n"Retry [y/N]? " 103read yesno 104case"$yesno"in 105[Yy]*) 106continue;; 107esac 108fi 109exit$ret 110esac 111break 112done 113shift 114done 115# return to pristine 116rm-fr .dotest