Skip to content

Commit

Permalink
commit: restore --edit when combined with --fixup
Browse files Browse the repository at this point in the history
Recent changes to --fixup, adding amend suboption, caused the
--edit flag to be ignored as use_editor was always set to zero.

Restore edit_flag having higher priority than fixup_message when
deciding the value of use_editor by moving the edit flag condition
later in the method.

Signed-off-by: Joel Klinghed <the_jk@spawned.biz>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
thejk authored and gitster committed Aug 15, 2021
1 parent 5d213e4 commit 8ef6aad
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
5 changes: 3 additions & 2 deletions builtin/commit.c
Original file line number Diff line number Diff line change
Expand Up @@ -1253,8 +1253,6 @@ static int parse_and_validate_options(int argc, const char *argv[],

if (logfile || have_option_m || use_message)
use_editor = 0;
if (0 <= edit_flag)
use_editor = edit_flag;

/* Sanity check options */
if (amend && !current_head)
Expand Down Expand Up @@ -1344,6 +1342,9 @@ static int parse_and_validate_options(int argc, const char *argv[],
}
}

if (0 <= edit_flag)
use_editor = edit_flag;

cleanup_mode = get_cleanup_mode(cleanup_arg, use_editor);

handle_untracked_files_arg(s);
Expand Down
9 changes: 8 additions & 1 deletion t/t7500-commit-template-squash-signoff.sh
Original file line number Diff line number Diff line change
Expand Up @@ -270,7 +270,7 @@ EOF

test_expect_success 'commit --fixup provides correct one-line commit message' '
commit_for_rebase_autosquash_setup &&
git commit --fixup HEAD~1 &&
EDITOR="echo ignored >>" git commit --fixup HEAD~1 &&
commit_msg_is "fixup! target message subject line"
'

Expand All @@ -281,6 +281,13 @@ test_expect_success 'commit --fixup -m"something" -m"extra"' '
extra"
'
test_expect_success 'commit --fixup --edit' '
commit_for_rebase_autosquash_setup &&
EDITOR="printf \"something\nextra\" >>" git commit --fixup HEAD~1 --edit &&
commit_msg_is "fixup! target message subject linesomething
extra"
'

get_commit_msg () {
rev="$1" &&
git log -1 --pretty=format:"%B" "$rev"
Expand Down

0 comments on commit 8ef6aad

Please sign in to comment.