This patch series teaches `git commit --fixup` to create "amend!" commit as an alternative that works with `git rebase --autosquash`. It allows to fixup both the content and the commit message of the specified commit. Here we add two suboptions to the `--fixup`, first `amend` suboption that creates an "amend!" commit. It takes the staged changes and also allows to edit the commit message of the commit we are fixing. Example usuage: git commit --fixup=amend:<commit> Secondly, `reword` suboption that creates an empty "amend!" commit i.e it ignores the staged changes and only allows to reword/edit the commit message of the commit we are fixing. Example usuage: git commit --fixup=reword:<commit> ** This work is rebased on the top of cm/rebase-i-updates. Link to the related discussions: https://lore.kernel.org/git/CAPSFM5f+cm87N5TO3V+rJvWyrcazybNb_Zu_bJZ+sBH4N4iyow@xxxxxxxxxxxxxx/ Charvi Mendiratta (6): sequencer: export subject_length() commit: add amend suboption to --fixup to create amend! commit commit: add a reword suboption to --fixup t7500: add tests for --fixup[amend|reword] options t3437: use --fixup with options to create amend! commit doc/git-commit: add documentation for fixup[amend|reword] options Documentation/git-commit.txt | 39 +++++-- Documentation/git-rebase.txt | 21 ++-- builtin/commit.c | 97 ++++++++++++++++-- commit.c | 14 +++ commit.h | 3 + sequencer.c | 14 --- t/t3437-rebase-fixup-options.sh | 30 +----- t/t7500-commit-template-squash-signoff.sh | 118 ++++++++++++++++++++++ 8 files changed, 271 insertions(+), 65 deletions(-) -- 2.29.0.rc1