rebase: refactor reading of state
The code reading the state saved in $merge_dir or $rebase_dir is currently spread out in many places, making it harder to read and to introduce additional state. Extract this code into one method that reads the state. Only extract the code associated with the state that is written when the rebase is initiated. Leave the state that changes for each commmit, at least for now. Currently, when resuming a merge-based rebase using --continue or --skip, move_to_original_branch (via finish_rb_merge) will be called without head_name and orig_head set. These variables are then lazily read in move_to_original_branch if head_name is not set (together with onto, which is unnecessarily read again). Change this by always eagerly reading the state, for both am-based and merge-based rebase, in the --continue and --skip cases. Note that this does not change the behavior for am-based rebase, which read the state eagerly even before this commit. Reading the state eagerly means that part of the state will sometimes be read unnecessarily. One example is when the rebase is continued, but stops again at another merge conflict. Another example is when the rebase is aborted. However, since both of these cases involve user interaction, the delay is hopefully not noticeable. The call_merge/continue_merge loop is not affected. Helped-by: Junio C Hamano <gitster@pobox.com> Signed-off-by: Martin von Zweigbergk <martin.von.zweigbergk@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
69a636ad1a
commit
02ac45fa62
@ -57,6 +57,22 @@ rebase_root=
|
||||
force_rebase=
|
||||
allow_rerere_autoupdate=
|
||||
|
||||
read_state () {
|
||||
if test -d "$merge_dir"
|
||||
then
|
||||
state_dir="$merge_dir"
|
||||
prev_head=$(cat "$merge_dir"/prev_head) &&
|
||||
end=$(cat "$merge_dir"/end) &&
|
||||
msgnum=$(cat "$merge_dir"/msgnum)
|
||||
else
|
||||
state_dir="$apply_dir"
|
||||
fi &&
|
||||
head_name=$(cat "$state_dir"/head-name) &&
|
||||
onto=$(cat "$state_dir"/onto) &&
|
||||
orig_head=$(cat "$state_dir"/orig-head) &&
|
||||
GIT_QUIET=$(cat "$state_dir"/quiet)
|
||||
}
|
||||
|
||||
continue_merge () {
|
||||
test -n "$prev_head" || die "prev_head must be defined"
|
||||
test -d "$merge_dir" || die "$merge_dir directory does not exist"
|
||||
@ -138,10 +154,6 @@ call_merge () {
|
||||
}
|
||||
|
||||
move_to_original_branch () {
|
||||
test -z "$head_name" &&
|
||||
head_name="$(cat "$merge_dir"/head-name)" &&
|
||||
onto="$(cat "$merge_dir"/onto)" &&
|
||||
orig_head="$(cat "$merge_dir"/orig-head)"
|
||||
case "$head_name" in
|
||||
refs/*)
|
||||
message="rebase finished: $head_name onto $onto"
|
||||
@ -220,13 +232,9 @@ do
|
||||
echo "mark them as resolved using git add"
|
||||
exit 1
|
||||
}
|
||||
read_state
|
||||
if test -d "$merge_dir"
|
||||
then
|
||||
prev_head=$(cat "$merge_dir/prev_head")
|
||||
end=$(cat "$merge_dir/end")
|
||||
msgnum=$(cat "$merge_dir/msgnum")
|
||||
onto=$(cat "$merge_dir/onto")
|
||||
GIT_QUIET=$(cat "$merge_dir/quiet")
|
||||
continue_merge
|
||||
while test "$msgnum" -le "$end"
|
||||
do
|
||||
@ -236,10 +244,6 @@ do
|
||||
finish_rb_merge
|
||||
exit
|
||||
fi
|
||||
head_name=$(cat "$apply_dir"/head-name) &&
|
||||
onto=$(cat "$apply_dir"/onto) &&
|
||||
orig_head=$(cat "$apply_dir"/orig-head) &&
|
||||
GIT_QUIET=$(cat "$apply_dir"/quiet)
|
||||
git am --resolved --3way --resolvemsg="$RESOLVEMSG" &&
|
||||
move_to_original_branch
|
||||
exit
|
||||
@ -249,15 +253,11 @@ do
|
||||
die "No rebase in progress?"
|
||||
|
||||
git reset --hard HEAD || exit $?
|
||||
read_state
|
||||
if test -d "$merge_dir"
|
||||
then
|
||||
git rerere clear
|
||||
prev_head=$(cat "$merge_dir/prev_head")
|
||||
end=$(cat "$merge_dir/end")
|
||||
msgnum=$(cat "$merge_dir/msgnum")
|
||||
msgnum=$(($msgnum + 1))
|
||||
onto=$(cat "$merge_dir/onto")
|
||||
GIT_QUIET=$(cat "$merge_dir/quiet")
|
||||
while test "$msgnum" -le "$end"
|
||||
do
|
||||
call_merge "$msgnum"
|
||||
@ -266,10 +266,6 @@ do
|
||||
finish_rb_merge
|
||||
exit
|
||||
fi
|
||||
head_name=$(cat "$apply_dir"/head-name) &&
|
||||
onto=$(cat "$apply_dir"/onto) &&
|
||||
orig_head=$(cat "$apply_dir"/orig-head) &&
|
||||
GIT_QUIET=$(cat "$apply_dir"/quiet)
|
||||
git am -3 --skip --resolvemsg="$RESOLVEMSG" &&
|
||||
move_to_original_branch
|
||||
exit
|
||||
@ -279,18 +275,15 @@ do
|
||||
die "No rebase in progress?"
|
||||
|
||||
git rerere clear
|
||||
|
||||
test -d "$merge_dir" || merge_dir="$apply_dir"
|
||||
|
||||
head_name="$(cat "$merge_dir"/head-name)" &&
|
||||
read_state
|
||||
case "$head_name" in
|
||||
refs/*)
|
||||
git symbolic-ref HEAD $head_name ||
|
||||
die "Could not move back to $head_name"
|
||||
;;
|
||||
esac
|
||||
git reset --hard $(cat "$merge_dir/orig-head")
|
||||
rm -r "$merge_dir"
|
||||
git reset --hard $orig_head
|
||||
rm -r "$state_dir"
|
||||
exit
|
||||
;;
|
||||
--onto)
|
||||
@ -574,12 +567,12 @@ fi
|
||||
# this is rename-aware if the recursive (default) strategy is used
|
||||
|
||||
mkdir -p "$merge_dir"
|
||||
echo "$onto" > "$merge_dir/onto"
|
||||
echo "$onto_name" > "$merge_dir/onto_name"
|
||||
prev_head=$orig_head
|
||||
echo "$prev_head" > "$merge_dir/prev_head"
|
||||
echo "$orig_head" > "$merge_dir/orig-head"
|
||||
echo "$head_name" > "$merge_dir/head-name"
|
||||
echo "$onto" > "$merge_dir/onto"
|
||||
echo "$orig_head" > "$merge_dir/orig-head"
|
||||
echo "$GIT_QUIET" > "$merge_dir/quiet"
|
||||
|
||||
msgnum=0
|
||||
|
Loading…
Reference in New Issue
Block a user