chiark / gitweb /
Merge commit 'refs/top-bases/fixes/tg--r-require-arg' into fixes/tg--r-require-arg
[topgit.git] / tg-mail.sh
1 #!/bin/sh
2 # TopGit - A different patch queue manager
3 # GPLv2
4
5 name=
6 head_from=
7 send_email_args=
8 in_reply_to=
9
10
11 ## Parse options
12
13 while [ -n "$1" ]; do
14         arg="$1"; shift
15         case "$arg" in
16         -i|-w)
17                 [ -z "$head_from" ] || die "-i and -w are mutually exclusive"
18                 head_from="$arg";;
19         -s)
20                 send_email_args="$1"; shift;;
21         -r)
22                 in_reply_to="$1"; shift;;
23         -*)
24                 echo "Usage: tg [...] mail [-s SEND_EMAIL_ARGS] [-r REFERENCE_MSGID] [-i | -w] [NAME]" >&2
25                 exit 1;;
26         *)
27                 [ -z "$name" ] || die "name already specified ($name)"
28                 name="$arg";;
29         esac
30 done
31
32 head="$(git symbolic-ref HEAD | sed 's#^refs/heads/##')"
33 [ -n "$name" ] || name="$head"
34 base_rev="$(git rev-parse --short --verify "refs/top-bases/$name" 2>/dev/null)" ||
35         die "not a TopGit-controlled branch"
36
37 if [ -n "$in_reply_to" ]; then
38         send_email_args="$send_email_args --in-reply-to='$in_reply_to'"
39 fi
40
41
42 patchfile="$(get_temp tg-mail)"
43
44 # let tg patch sort out whether $head_from makes sense for $name
45 $tg patch "$name" $head_from >"$patchfile"
46
47 header="$(sed -e '/^$/,$d' -e "s,','\\\\'',g" "$patchfile")"
48
49
50
51 from="$(echo "$header" | grep '^From:' | sed 's/From:\s*//')"
52 to="$(echo "$header" | grep '^To:' | sed 's/To:\s*//')"
53
54
55 people=
56 [ -n "$from" ] && people="$people --from '$from'"
57 # FIXME: there could be multimple To
58 [ -n "$to" ] && people="$people --to '$to'"
59
60 # NOTE: git-send-email handles cc itself
61 eval git send-email $send_email_args "$people" "$patchfile"
62
63 # vim:noet