зеркало из https://github.com/microsoft/git.git
Merge branch 'en/rebase-i-microfixes'
* en/rebase-i-microfixes: git-rebase--merge: modernize "git-$cmd" to "git $cmd" Fix use of strategy options with interactive rebases t3418: add testcase showing problems with rebase -i and strategy options
This commit is contained in:
Коммит
b345b77b3a
|
@ -71,7 +71,7 @@ call_merge () {
|
||||||
test -z "$strategy" && strategy=recursive
|
test -z "$strategy" && strategy=recursive
|
||||||
# If cmt doesn't have a parent, don't include it as a base
|
# If cmt doesn't have a parent, don't include it as a base
|
||||||
base=$(git rev-parse --verify --quiet $cmt^)
|
base=$(git rev-parse --verify --quiet $cmt^)
|
||||||
eval 'git-merge-$strategy' $strategy_opts $base ' -- "$hd" "$cmt"'
|
eval 'git merge-$strategy' $strategy_opts $base ' -- "$hd" "$cmt"'
|
||||||
rv=$?
|
rv=$?
|
||||||
case "$rv" in
|
case "$rv" in
|
||||||
0)
|
0)
|
||||||
|
@ -88,7 +88,7 @@ call_merge () {
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
die "Unknown exit code ($rv) from command:" \
|
die "Unknown exit code ($rv) from command:" \
|
||||||
"git-merge-$strategy $cmt^ -- HEAD $cmt"
|
"git merge-$strategy $cmt^ -- HEAD $cmt"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
|
@ -328,7 +328,7 @@ do
|
||||||
do_merge=t
|
do_merge=t
|
||||||
;;
|
;;
|
||||||
--strategy-option=*)
|
--strategy-option=*)
|
||||||
strategy_opts="$strategy_opts $(git rev-parse --sq-quote "--${1#--strategy-option=}")"
|
strategy_opts="$strategy_opts $(git rev-parse --sq-quote "--${1#--strategy-option=}" | sed -e s/^.//)"
|
||||||
do_merge=t
|
do_merge=t
|
||||||
test -z "$strategy" && strategy=recursive
|
test -z "$strategy" && strategy=recursive
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -2207,6 +2207,7 @@ static int populate_opts_cb(const char *key, const char *value, void *data)
|
||||||
static void read_strategy_opts(struct replay_opts *opts, struct strbuf *buf)
|
static void read_strategy_opts(struct replay_opts *opts, struct strbuf *buf)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
char *strategy_opts_string;
|
||||||
|
|
||||||
strbuf_reset(buf);
|
strbuf_reset(buf);
|
||||||
if (!read_oneliner(buf, rebase_path_strategy(), 0))
|
if (!read_oneliner(buf, rebase_path_strategy(), 0))
|
||||||
|
@ -2215,7 +2216,11 @@ static void read_strategy_opts(struct replay_opts *opts, struct strbuf *buf)
|
||||||
if (!read_oneliner(buf, rebase_path_strategy_opts(), 0))
|
if (!read_oneliner(buf, rebase_path_strategy_opts(), 0))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
opts->xopts_nr = split_cmdline(buf->buf, (const char ***)&opts->xopts);
|
strategy_opts_string = buf->buf;
|
||||||
|
if (*strategy_opts_string == ' ')
|
||||||
|
strategy_opts_string++;
|
||||||
|
opts->xopts_nr = split_cmdline(strategy_opts_string,
|
||||||
|
(const char ***)&opts->xopts);
|
||||||
for (i = 0; i < opts->xopts_nr; i++) {
|
for (i = 0; i < opts->xopts_nr; i++) {
|
||||||
const char *arg = opts->xopts[i];
|
const char *arg = opts->xopts[i];
|
||||||
|
|
||||||
|
|
|
@ -74,6 +74,38 @@ test_expect_success 'rebase --continue remembers merge strategy and options' '
|
||||||
test -f funny.was.run
|
test -f funny.was.run
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success 'rebase -i --continue handles merge strategy and options' '
|
||||||
|
rm -fr .git/rebase-* &&
|
||||||
|
git reset --hard commit-new-file-F2-on-topic-branch &&
|
||||||
|
test_commit "commit-new-file-F3-on-topic-branch-for-dash-i" F3 32 &&
|
||||||
|
test_when_finished "rm -fr test-bin funny.was.run funny.args" &&
|
||||||
|
mkdir test-bin &&
|
||||||
|
cat >test-bin/git-merge-funny <<-EOF &&
|
||||||
|
#!$SHELL_PATH
|
||||||
|
echo "\$@" >>funny.args
|
||||||
|
case "\$1" in --opt) ;; *) exit 2 ;; esac
|
||||||
|
case "\$2" in --foo) ;; *) exit 2 ;; esac
|
||||||
|
case "\$4" in --) ;; *) exit 2 ;; esac
|
||||||
|
shift 2 &&
|
||||||
|
>funny.was.run &&
|
||||||
|
exec git merge-recursive "\$@"
|
||||||
|
EOF
|
||||||
|
chmod +x test-bin/git-merge-funny &&
|
||||||
|
(
|
||||||
|
PATH=./test-bin:$PATH &&
|
||||||
|
test_must_fail git rebase -i -s funny -Xopt -Xfoo master topic
|
||||||
|
) &&
|
||||||
|
test -f funny.was.run &&
|
||||||
|
rm funny.was.run &&
|
||||||
|
echo "Resolved" >F2 &&
|
||||||
|
git add F2 &&
|
||||||
|
(
|
||||||
|
PATH=./test-bin:$PATH &&
|
||||||
|
git rebase --continue
|
||||||
|
) &&
|
||||||
|
test -f funny.was.run
|
||||||
|
'
|
||||||
|
|
||||||
test_expect_success 'rebase passes merge strategy options correctly' '
|
test_expect_success 'rebase passes merge strategy options correctly' '
|
||||||
rm -fr .git/rebase-* &&
|
rm -fr .git/rebase-* &&
|
||||||
git reset --hard commit-new-file-F3-on-topic-branch &&
|
git reset --hard commit-new-file-F3-on-topic-branch &&
|
||||||
|
|
Загрузка…
Ссылка в новой задаче