tl;dr ✨ Use an $EDITOR that you like! ✨
The fix is not to memorize cryptic commands, like in the accepted answer, but configuring Git to use an editor that you like and understand!
The underlying problem is that Git by default uses an editor that is too unintuitive to use for most people: Vim. This is because Vim is present everywhere, not because it is user friendly 😄 Now, don't get me wrong, I ❤️ Vim, and while you could set some time aside to learn Vim and try to understand why some people think Vim is the greatest editor in existence, there is a quicker way of fixing this problem :-)
It's really as simple as configuring either of these options
- the git config setting
core.editor
(per project, or globally)
- the
VISUAL
or EDITOR
environment variable (this works for other programs as well). Typically stuffing export VISUAL="vscode --wait"
into your .bashrc
or similar config.
I'll cover the first option for a couple of popular editors, but GitHub has an excellent guide on this for many editors as well.
🔥 To use Atom
Straight from its docs, enter this in a terminal:
git config --global core.editor "atom --wait"
Git normally wait for the editor command to finish before progressing, but since Atom forks to a background process immediately, this won't work, unless you give it the --wait
option. This makes it stay as a foreground process, just as we want.
🦄 To use Sublime Text
For the same reasons as in the Atom case, you need a special flag to signal to the process that it shouldn't fork to the background:
git config --global core.editor "subl -n -w"
🤓 To use Visual Studio Code
git config --global core.editor "code --wait"