RubyMine 2019.2 Help

Using Vim Editor Emulation in RubyMine (IdeaVim)

Before you start

Make sure that:

  • You are working with RubyMine version 8.0.0 or later. If you still do not have RubyMine, download it from this page. To install RubyMine, follow the instructions, depending on your platform.

  • You have at least one Ruby interpreter properly installed on your computer. You can download an interpreter from this page.

Downloading and installing IdeaVim plugin

On the toolbar of the RubyMine main window, press Ctrl+Alt+S to open the Settings/Preferences dialog, and then click Plugins.

You see the list of plugins currently installed on you computer. However, the IdeaVim plugin is not among them. Click the Marketplace tab, type the word "vim" in the search field to narrow down the list, and select IdeaVim plugin:

install vim

After installing the plugin, it actually becomes available after RubyMine restart.

What happens to RubyMine's UI after restart?

First, on the Tools menu, a check command Vim Emulator appears:

Vim Emulator in the Tools menu

After RubyMine restart, this check command is selected. You can disable Vim by deselecting this check command.

Second, in Settings/Preferences dialog, an additional page is added under Editor | Vim Emulation.

Configuring shortcuts

Both Vim and RubyMine are keyboard-centric. With IdeaVim plugin, it is quite possible that RubyMine's keymap runs into a conflict with the Vim keymap. That's why RubyMine allows you choosing which keyboard shortcut you prefer for a certain action. This is how it's done.

In the Settings/Preferences dialog (Ctrl+Alt+S), select Editor | Vim Emulation.

In the Shortcut column, select the shortcut you want to configure. Next, in the Handler column, click the corresponding cell, and see the drop-down list of three possible options (Undefined, IDE, Vim):

vim emulation shortcut

If you choose IDE, it means that the RubyMine's shortcut for this particular action is enabled. When you press, say, Ctrl+C, RubyMine silently performs its action.

If you leave the handler undefined, then, on pressing the shortcut, say, Ctrl+C, RubyMine shows the banner.

Shortcut notification

To redefine this shortcut as an IDE shortcut and thus accept the RubyMine's keymap, click the IDE shortcut link. If you click the Vim Emulation link, then RubyMine will show the Editor | Vim Emulation page of the Settings/Preferences dialog.

Editing modes

When you have Vim enabled, you see that the cursor has changed its shape - now it is a block, which means that you are in the Normal mode :

rm vim normal

If you want to enter the Insert mode, press i, and the cursor will turn into a line:

rm vim insert

In this mode you can type new or change the existing code. Same way, you can enter the various Vim modes: for example, press r for the Replace mode.

By the way, as soon as you enter Vim emulation, it is also reported in the Status bar.

ps vim status bar

To return to the Normal mode, press Escape.

Last modified: 5 September 2019

See Also