git-rebase--common.shon commit dir-iterator: refactor state machine model (3012397)
   1
   2resolvemsg="
   3$(gettext 'Resolve all conflicts manually, mark them as resolved with
   4"git add/rm <conflicted_files>", then run "git rebase --continue".
   5You can instead skip this commit: run "git rebase --skip".
   6To abort and get back to the state before "git rebase", run "git rebase --abort".')
   7"
   8
   9write_basic_state () {
  10        echo "$head_name" > "$state_dir"/head-name &&
  11        echo "$onto" > "$state_dir"/onto &&
  12        echo "$orig_head" > "$state_dir"/orig-head &&
  13        test t = "$GIT_QUIET" && : > "$state_dir"/quiet
  14        test t = "$verbose" && : > "$state_dir"/verbose
  15        test -n "$strategy" && echo "$strategy" > "$state_dir"/strategy
  16        test -n "$strategy_opts" && echo "$strategy_opts" > \
  17                "$state_dir"/strategy_opts
  18        test -n "$allow_rerere_autoupdate" && echo "$allow_rerere_autoupdate" > \
  19                "$state_dir"/allow_rerere_autoupdate
  20        test -n "$gpg_sign_opt" && echo "$gpg_sign_opt" > "$state_dir"/gpg_sign_opt
  21        test -n "$signoff" && echo "$signoff" >"$state_dir"/signoff
  22        test -n "$reschedule_failed_exec" && : > "$state_dir"/reschedule-failed-exec
  23}
  24
  25apply_autostash () {
  26        if test -f "$state_dir/autostash"
  27        then
  28                stash_sha1=$(cat "$state_dir/autostash")
  29                if git stash apply $stash_sha1 >/dev/null 2>&1
  30                then
  31                        echo "$(gettext 'Applied autostash.')" >&2
  32                else
  33                        git stash store -m "autostash" -q $stash_sha1 ||
  34                        die "$(eval_gettext "Cannot store \$stash_sha1")"
  35                        gettext 'Applying autostash resulted in conflicts.
  36Your changes are safe in the stash.
  37You can run "git stash pop" or "git stash drop" at any time.
  38' >&2
  39                fi
  40        fi
  41}
  42
  43move_to_original_branch () {
  44        case "$head_name" in
  45        refs/*)
  46                message="rebase finished: $head_name onto $onto"
  47                git update-ref -m "$message" \
  48                        $head_name $(git rev-parse HEAD) $orig_head &&
  49                git symbolic-ref \
  50                        -m "rebase finished: returning to $head_name" \
  51                        HEAD $head_name ||
  52                die "$(eval_gettext "Could not move back to \$head_name")"
  53                ;;
  54        esac
  55}
  56
  57output () {
  58        case "$verbose" in
  59        '')
  60                output=$("$@" 2>&1 )
  61                status=$?
  62                test $status != 0 && printf "%s\n" "$output"
  63                return $status
  64                ;;
  65        *)
  66                "$@"
  67                ;;
  68        esac
  69}