]>
Commit | Line | Data |
---|---|---|
853916ff LT |
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 | ## | |
c5f7674a LT |
7 | ## Update: Ryan Anderson finally shamed me into naming this "applymbox". |
8 | ## | |
853916ff LT |
9 | ## You give it a mbox-format collection of emails, and it will try to |
10 | ## apply them to the kernel using "applypatch" | |
11 | ## | |
37275318 JH |
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. | |
ad4e9ce4 | 18 | |
215a7ad1 | 19 | . git-sh-setup || die "Not a git archive" |
d571c2be | 20 | |
d4a9ce78 | 21 | usage () { |
47f0b6d5 | 22 | echo >&2 "applymbox [-u] [-k] [-q] [-m] (-c .dotest/<num> | mbox) [signoff]" |
d4a9ce78 JH |
23 | exit 1 |
24 | } | |
25 | ||
26 | keep_subject= query_apply= continue= utf8= resume=t | |
37275318 JH |
27 | while case "$#" in 0) break ;; esac |
28 | do | |
29 | case "$1" in | |
d4a9ce78 | 30 | -u) utf8=-u ;; |
6bff6a60 | 31 | -k) keep_subject=-k ;; |
37275318 JH |
32 | -q) query_apply=t ;; |
33 | -c) continue="$2"; resume=f; shift ;; | |
47f0b6d5 | 34 | -m) fallback_3way=t ;; |
37275318 JH |
35 | -*) usage ;; |
36 | *) break ;; | |
37 | esac | |
38 | shift | |
39 | done | |
40 | ||
41 | case "$continue" in | |
42 | '') | |
43 | rm -rf .dotest | |
44 | mkdir .dotest | |
154d3d2d | 45 | git-mailsplit "$1" .dotest || exit 1 |
b50abe88 | 46 | shift |
ad4e9ce4 | 47 | esac |
37275318 | 48 | |
215a7ad1 | 49 | files=$(git-diff-index --cached --name-only HEAD) || exit |
d571c2be LT |
50 | if [ "$files" ]; then |
51 | echo "Dirty index: cannot apply patches (dirty: $files)" >&2 | |
52 | exit 1 | |
53 | fi | |
54 | ||
37275318 JH |
55 | case "$query_apply" in |
56 | t) touch .dotest/.query_apply | |
57 | esac | |
47f0b6d5 JH |
58 | case "$fall_back_3way" in |
59 | t) : >.dotest/.3way | |
60 | esac | |
6bff6a60 JH |
61 | case "$keep_subject" in |
62 | -k) : >.dotest/.keep_subject | |
63 | esac | |
37275318 | 64 | |
b50abe88 JH |
65 | signoff="$1" |
66 | set x .dotest/0* | |
67 | shift | |
68 | while case "$#" in 0) break;; esac | |
853916ff | 69 | do |
b50abe88 JH |
70 | i="$1" |
71 | case "$resume,$continue" in | |
72 | f,$i) resume=t;; | |
07a95d0e JH |
73 | f,*) shift |
74 | continue;; | |
b50abe88 | 75 | *) |
d4a9ce78 | 76 | git-mailinfo $keep_subject $utf8 \ |
6bff6a60 | 77 | .dotest/msg .dotest/patch <$i >.dotest/info || exit 1 |
b50abe88 JH |
78 | git-stripspace < .dotest/msg > .dotest/msg-clean |
79 | ;; | |
80 | esac | |
81 | while :; # for fixing up and retry | |
82 | do | |
83 | git-applypatch .dotest/msg-clean .dotest/patch .dotest/info "$signoff" | |
84 | case "$?" in | |
85 | 0 | 2 ) | |
ad4e9ce4 JB |
86 | # 2 is a special exit code from applypatch to indicate that |
87 | # the patch wasn't applied, but continue anyway | |
b50abe88 JH |
88 | ;; |
89 | *) | |
90 | ret=$? | |
91 | if test -f .dotest/.query_apply | |
92 | then | |
93 | echo >&2 "* Patch failed." | |
94 | echo >&2 "* You could fix it up in your editor and" | |
95 | echo >&2 " retry. If you want to do so, say yes here" | |
96 | echo >&2 " AFTER fixing .dotest/patch up." | |
97 | echo >&2 -n "Retry [y/N]? " | |
98 | read yesno | |
99 | case "$yesno" in | |
100 | [Yy]*) | |
101 | continue ;; | |
102 | esac | |
103 | fi | |
104 | exit $ret | |
105 | esac | |
106 | break | |
107 | done | |
108 | shift | |
853916ff | 109 | done |
ad4e9ce4 JB |
110 | # return to pristine |
111 | rm -fr .dotest |