+
The commit created by plain `--fixup=<commit>` has a title
composed of "fixup!" followed by the title of _<commit>_,
-and is recognized specially by `git rebase --autosquash`. The `-m`
-or `-F` option may be used to supplement the log message
+and is recognized specially by `git rebase --autosquash`. The `-m`,
+`-F`, `-C`, or `-c` option may be used to supplement the log message
of the created commit, but the additional commentary will be thrown
away once the "fixup!" commit is squashed into _<commit>_ by
`git rebase --autosquash`.
title is instead prefixed with "amend!". The log message of
_<commit>_ is copied into the log message of the "amend!" commit and
opened in an editor so it can be refined. The replacement message may
-also be supplied directly using `-m` or `-F`, bypassing the
-need to open an editor. When `git rebase
+also be supplied directly using `-m`, `-F`, or `-C`, bypassing the
+need to open an editor, or using `-c` to open the editor pre-populated
+with the referenced commit's message. When `git rebase
--autosquash` squashes the "amend!" commit into _<commit>_, the log
message of _<commit>_ is replaced by the refined log message from the
"amend!" commit. It is an error for the "amend!" commit's log message
hook_arg1 = "message";
/*
- * Only `-m` and `-F` are handled here. `-c`/`-C` are
- * incompatible with --fixup and have already errored out
- * during option parsing.
+ * `-m`, `-F`, `-C`, and `-c` provide the message body.
+ * If none was given and this is an amend, use the target
+ * commit's body instead.
*/
if (have_option_m) {
strbuf_addbuf(&sb, &message);
} else if (logfile) {
if (strbuf_read_file(&sb, logfile, 0) < 0)
die_errno(_("could not read log file '%s'"), logfile);
+ } else if (use_message) {
+ struct commit *c = lookup_commit_reference_by_name(use_message);
+ if (!c)
+ die(_("could not lookup commit '%s'"), use_message);
+ prepare_amend_commit(c, &sb, &ctx);
} else if (!strcmp(fixup_prefix, "amend")) {
prepare_amend_commit(commit, &sb, &ctx);
}
die(_("options '%s' and '%s' cannot be used together"), "--squash", "--fixup");
die_for_incompatible_opt3(!!use_message, "-C",
!!edit_message, "-c",
- !!fixup_message, "--fixup");
+ !!logfile, "-F");
die_for_incompatible_opt4(have_option_m, "-m",
!!edit_message, "-c",
!!use_message, "-C",
EOF
'
+test_expect_success 'commit --fixup works with -C' '
+ commit_for_rebase_autosquash_setup &&
+ git commit --fixup HEAD~ -C HEAD &&
+ test_commit_message HEAD <<-EOF
+ fixup! $(git log -1 --format=%s HEAD~2)
+
+ $(get_commit_msg HEAD~)
+ EOF
+'
+
+test_expect_success 'commit --fixup=amend: works with -c' '
+ commit_for_rebase_autosquash_setup &&
+ test_set_editor : &&
+ git commit --fixup=amend:HEAD -c HEAD~ &&
+ test_commit_message HEAD <<-EOF
+ amend! intermediate commit
+
+ target message subject line
+
+ target message body line 1
+ target message body line 2
+ EOF
+'
+
+test_expect_success 'commit --fixup=amend:HEAD with -C HEAD and without have the same message' '
+ commit_for_rebase_autosquash_setup &&
+ start=$(git rev-parse HEAD) &&
+
+ git commit --fixup=amend:HEAD -C HEAD &&
+ git commit --fixup=amend:HEAD -C HEAD &&
+ git log -1 --pretty=%B >with-c &&
+
+ git reset --hard "$start" &&
+ test_set_editor : &&
+ git commit --fixup=amend:HEAD &&
+ git commit --fixup=amend:HEAD &&
+ git log -1 --pretty=%B >without-c &&
+
+ test_cmp with-c without-c
+'
+
+test_expect_success 'commit --fixup=amend: with -C copies full subject + body of squash commit' '
+ commit_for_rebase_autosquash_setup &&
+ git commit --squash HEAD~ -m "inner body" &&
+ echo "extra" >>foo &&
+ git add foo &&
+ git commit --fixup=amend:HEAD -C HEAD &&
+ test_commit_message HEAD <<-EOF
+ amend! squash! $(git log -1 --format=%s HEAD~3)
+
+ squash! $(git log -1 --format=%s HEAD~3)
+
+ inner body
+ EOF
+'
+
test_expect_success 'commit --fixup=reword: works with -F' '
commit_for_rebase_autosquash_setup &&
echo "message from file" >msgfile &&
echo changes >>foo &&
echo "message" >log &&
git add foo &&
- test_must_fail git commit --fixup HEAD~1 --squash HEAD~2 &&
- test_must_fail git commit --fixup HEAD~1 -C HEAD~2 &&
- test_must_fail git commit --fixup HEAD~1 -c HEAD~2
+ test_must_fail git commit --fixup HEAD~1 --squash HEAD~2
'
cat >expected-template <<EOF