Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do I customize the format of git rebase --interactive commit messages?

Tags:

git

msysgit

I use git for my local work (and love it ever so much), and I follow a workflow similar to the one described in this article. So basically, when starting on a new feature, I create a branch for it, go through the usual hack then commit cycle, and when I think I'm done with it, I squash it into a single commit using git rebase --interactive master, and I always end up editing the multitude of commit messages into something looking like the example in the article, reproduced here:

[#3275] User Can Add A Comment To a Post

* Adding Comment model, migrations, spec
* Adding Comment controller, helper, spec
* Adding Comment relationship with Post
* Comment belongs to a User
* Comment form on Post show page

Of course, that's after a bunch of removing # This is the xth commit message lines and copy/pasting * in front of each commit message.

Now, what I was wondering, is there any way to customize how git rebase -i outputs the squashed commit messages so I don't have to do all that hacking?

(I use msysgit, if that matters. My editor is Notepad++.)

Thanks!

like image 366
adamjford Avatar asked Mar 19 '10 22:03

adamjford


People also ask

How do you edit an interactive rebase?

Right-click on commit message Fix app crash and start interactive rebase. Set the commit you want to edit as edit . Click Start Rebasing. Whenever you found a conflict, fix it, run git add . , then run git rebase --continue again.

How do I change a commit message in rebase?

On the command line, navigate to the repository that contains the commit you want to amend. Use the git rebase -i HEAD~n command to display a list of the last n commits in your default text editor. Replace pick with reword before each commit message you want to change.

How do I rebase interactive mode in git?

You can run rebase interactively by adding the -i option to git rebase . You must indicate how far back you want to rewrite commits by telling the command which commit to rebase onto. Remember again that this is a rebasing command — every commit in the range HEAD~3..


2 Answers

Starting Git 2.6+ (Q3 2015), there will actually be a way to configure git rebase -i commit message.

See commit 16cf51c (13 Jun 2015) by Michael Rappazzo (rappazzo).
(Merged by Junio C Hamano -- gitster -- in commit 9f56db7, 03 Aug 2015)

git-rebase--interactive.sh: add config option for custom instruction format

A config option 'rebase.instructionFormat' can override the default 'oneline' format of the rebase instruction list.

Since the list is parsed using the left, right or boundary mark plus the sha1, they are prepended to the instruction format.

You will soon have a new config:

rebase.instructionFormat

A format string, as specified in git log, to be used for the instruction list during an interactive rebase.
The format will automatically have the long commit hash prepended to the format.

For example:

git config --add rebase.instructionFormat "[%an @ %ar] %s"

Note there is a bug/regression after the release of that feature:
See "Comment in rebase instruction has become too rigid"

I noticed that the format of the comment lines in a rebase instruction sheet has become stricter - it could no longer begin with spaces or tabs. The comment char ("#" for example) has to appear on the first column.


Jefromi comments below:

it appears it's only meant to affect the display within interactive rebase, not the resulting commit messages.

I gave it a try with your example format string and I indeed saw the author information in my editor, but once I told it to squash, the resulting template commit message was still the usual one.

So this isn't a perfect fit for the OP.

like image 75
VonC Avatar answered Sep 27 '22 23:09

VonC


There's no way (short of hacking the source) to modify the squash message template, I don't think. However, you have a couple options:

  • Use a git log command to get the shortlist, something like `git log --pretty="* %s" commit-1..commit-2 to get you your bullets. In linux it's very possible to do this from within your editor - don't know how that works with msysgit.

  • Have your editor do the work for you! I don't know what your editor is, so I can't really tell you what to do, but it'd certainly be very possible in vim. (The idea being: search for /# This is the .* commit message/, delete a couple lines, keep one, delete up to the next comment)

Also, it's not what you want in this case, probably, but in fairly recent versions of git, there's a fixup identifier that you can use instead of squash - it does the same thing, but it discards the commit message, so if you have one commit with the real message then ten fixes, you can just mark them all fixup and not have to delete their throwaway messages.

like image 40
Cascabel Avatar answered Sep 27 '22 23:09

Cascabel