2 # TopGit - A different patch queue manager
3 # (c) Petr Baudis <pasky@suse.cz> 2008
16 [ -z "$head_from" ] || die
"-i and -w are mutually exclusive"
21 echo "Usage: ${tgname:-tg} [...] patch [-i | -w] [--binary] [<name>]" >&2
24 [ -z "$name" ] || die
"name already specified ($name)"
29 head="$(git symbolic-ref HEAD)"
30 head="${head#refs/heads/}"
34 name
="$(verify_topgit_branch "$name")"
35 base_rev
="$(git rev-parse --short --verify "refs
/top-bases
/$name" 2>/dev/null)" ||
36 die
"not a TopGit-controlled branch"
38 if [ -n "$head_from" ] && [ "$name" != "$head" ]; then
39 die
"$head_from makes only sense for the current branch"
46 # We now collect the rest of the code in this file into a block
47 # so we can redirect the output to the pager.
50 # put out the commit message
51 # and put an empty line out, if the last one in the message was not an empty line
52 # and put out "---" if the commit message does not have one yet
53 cat_file
"$name:.topmsg" $head_from |
72 b_tree
=$
(pretty_tree
"$name" -b)
73 t_tree
=$
(pretty_tree
"$name" $head_from)
75 if [ $b_tree = $t_tree ]; then
78 git diff-tree
-p --stat ${binary:+--binary} $b_tree $t_tree
82 echo "$tgname: ($base_rev..) $name (depends on: $(cat_file "$name:.topdeps
" $head_from 2>/dev/null | paste -s -d ' ' -))"
83 branch_contains
"$name" "$base_rev" ||
84 echo "$tgname: The patch is out-of-date wrt. the base! Run \`$tgdisplay update\`."
87 # ... and then we pipe all the output through the pager