External editors

Configure your preferred external editor by updating the editor option in your configuration file. If your editor is not in your operating system's PATH environment variable, then you will have to enter the full path of your editor.

Once it's configured, you can create an entry as a new document in your editor using the jrnl command by itself:

jrnl

You can specify the time and title of the entry as usual on the first line of the document.

If you want, you can skip the editor by including a quick entry with the jrnl command:

jrnl yesterday: All my troubles seemed so far away.

If you want to start the entry on the command line and continue writing in your chosen editor, use the --edit flag. For example:

jrnl yesterday: All my troubles seemed so far away. --edit

Note

To save and log any entry edits, save and close the file.

All editors must be blocking processes to work with jrnl. Some editors, such as micro, are blocking by default, though others can be made to block with additional arguments, such as many of those documented below. If jrnl opens your editor but finishes running immediately, then your editor is not a blocking process, and you may be able to correct that with one of the suggestions below.

Please see this section about how your editor might leak sensitive information and how to mitigate that risk.

Sublime Text

To use Sublime Text, install the command line tools for Sublime Text and configure your jrnl.yaml like this:

editor: "subl -w"

Note the -w flag to make sure jrnl waits for Sublime Text to close the file before writing into the journal.

Visual Studio Code

Visual Studio Code also requires a flag that tells the process to wait until the file is closed before exiting:

editor: "code --wait"

On Windows, code is not added to the path by default, so you'll need to enter the full path to your code.exe file, or add it to the PATH variable.

MacVim

Also similar to Sublime Text, MacVim must be started with a flag that tells the the process to wait until the file is closed before passing control back to journal. In the case of MacVim, this is -f:

editor: "mvim -f"

Vim/Neovim

To use any of the Vim derivatives as editor in Linux, simply set the editor to the executable:

editor: "vim"
# or
editor: "nvim"

iA Writer

On OS X, you can use the fabulous iA Writer to write entries. Configure your jrnl.yaml like this:

editor: "open -b pro.writer.mac -Wn"

What does this do? open -b ... opens a file using the application identified by the bundle identifier (a unique string for every app out there). -Wn tells the application to wait until it's closed before passing back control, and to use a new instance of the application.

If the pro.writer.mac bundle identifier is not found on your system, you can find the right string to use by inspecting iA Writer's Info.plist file in your shell:

grep -A 1 CFBundleIdentifier /Applications/iA\ Writer.app/Contents/Info.plist

Notepad++ on Windows

To set Notepad++ as your editor, edit the jrnl config file (jrnl.yaml) like this:

editor: "C:\\Program Files (x86)\\Notepad++\\notepad++.exe -multiInst -nosession"

The double backslashes are needed so jrnl can read the file path correctly. The -multiInst -nosession options will cause jrnl to open its own Notepad++ window.

emacs

To use emacs as your editor, edit the jrnl config file (jrnl.yaml) like this:

editor: emacsclient -a "" -c

When you're done editing the message, save and C-x # to close the buffer and stop the emacsclient process.

Other editors

If you're using another editor and would like to share, feel free to contribute documentation on it.