/usr/share/topgit/tg-update is in topgit 0.8-1.1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 | #!/bin/sh
# TopGit - A different patch queue manager
# (c) Petr Baudis <pasky@suse.cz> 2008
# GPLv2
name=
## Parse options
if [ -n "$1" ]; then
echo "Usage: tg [...] update" >&2
exit 1
fi
name="$(git symbolic-ref HEAD | sed 's#^refs/\(heads\|top-bases\)/##')"
base_rev="$(git rev-parse --short --verify "refs/top-bases/$name" 2>/dev/null)" ||
die "not a TopGit-controlled branch"
## First, take care of our base
depcheck="$(mktemp -t tg-depcheck.XXXXXX)"
missing_deps=
needs_update "$name" >"$depcheck" || :
[ -z "$missing_deps" ] || die "some dependencies are missing: $missing_deps"
if [ -s "$depcheck" ]; then
# We need to switch to the base branch
# ...but only if we aren't there yet (from failed previous merge)
HEAD="$(git symbolic-ref HEAD)"
if [ "$HEAD" = "${HEAD#refs/top-bases/}" ]; then
switch_to_base "$name"
fi
cat "$depcheck" |
sed 's/ [^ ]* *$//' | # last is $name
sed 's/.* \([^ ]*\)$/+\1/' | # only immediate dependencies
sed 's/^\([^+]\)/-\1/' | # now each line is +branch or -branch (+ == recurse)
uniq -s 1 | # fold branch lines; + always comes before - and thus wins within uniq
while read depline; do
action="$(echo "$depline" | cut -c 1)"
dep="$(echo "$depline" | cut -c 2-)"
# We do not distinguish between dependencies out-of-date
# and base/remote out-of-date cases for $dep here,
# but thanks to needs_update returning : or %
# for the latter, we do correctly recurse here
# in both cases.
if [ x"$action" = x+ ]; then
info "Recursing to $dep..."
git checkout -q "$dep"
(
export TG_RECURSIVE="[$dep] $TG_RECURSIVE"
export PS1="[$dep] $PS1"
while ! $tg update; do
# The merge got stuck! Let the user fix it up.
info "You are in a subshell. If you abort the merge,"
info "use \`exit 1\` to abort the recursive update altogether."
if ! sh -i </dev/tty; then
info "Ok, you aborted the merge. Now, you just need to"
info "switch back to some sane branch using \`git checkout\`."
exit 3
fi
done
)
switch_to_base "$name"
fi
# This will be either a proper topic branch
# or a remote base. (branch_needs_update() is called
# only on the _dependencies_, not our branch itself!)
info "Updating base with $dep changes..."
if ! git merge "$dep"; then
if [ -z "$TG_RECURSIVE" ]; then
resume="\`git checkout $name && $tg update\` again"
else # subshell
resume='exit'
fi
info "Please commit merge resolution and call $resume."
info "It is also safe to abort this operation using \`git reset --hard\`,"
info "but please remember that you are on the base branch now;"
info "you will want to switch to some normal branch afterwards."
rm "$depcheck"
exit 2
fi
done
else
info "The base is up-to-date."
fi
rm "$depcheck"
# Home, sweet home...
# (We want to always switch back, in case we were on the base from failed
# previous merge.)
git checkout -q "$name"
merge_with="refs/top-bases/$name"
## Second, update our head with the remote branch
if has_remote "$name"; then
rname="refs/remotes/$base_remote/$name"
if branch_contains "$name" "$rname"; then
info "The $name head is up-to-date wrt. its remote branch."
else
info "Reconciling remote branch updates with $name base..."
# *DETACH* our HEAD now!
git checkout -q "refs/top-bases/$name"
if ! git merge "$rname"; then
info "Oops, you will need to help me out here a bit."
info "Please commit merge resolution and call:"
info "git checkout $name && git merge <commitid>"
info "It is also safe to abort this operation using: git reset --hard $name"
exit 3
fi
# Go back but remember we want to merge with this, not base
merge_with="$(git rev-parse HEAD)"
git checkout -q "$name"
fi
fi
## Third, update our head with the base
if branch_contains "$name" "$merge_with"; then
info "The $name head is up-to-date wrt. the base."
exit 0
fi
info "Updating $name against new base..."
if ! git merge "$merge_with"; then
if [ -z "$TG_RECURSIVE" ]; then
info "Please commit merge resolution. No need to do anything else"
info "You can abort this operation using \`git reset --hard\` now"
info "and retry this merge later using \`$tg update\`."
else # subshell
info "Please commit merge resolution and call exit."
info "You can abort this operation using \`git reset --hard\`."
fi
exit 3
fi
# vim:noet
|