1
0
mirror of https://github.com/chylex/IntelliJ-IdeaVim.git synced 2024-11-24 05:42:45 +01:00
IntelliJ platform plugin for Vim emulation. http://plugins.jetbrains.com/plugin/164
Go to file
2020-04-28 11:18:56 +03:00
.idea Include copyright into repository 2020-04-17 11:17:34 +03:00
doc Update README 2020-04-17 11:31:17 +03:00
gradle/wrapper Update dependencies 2020-04-10 11:00:47 +03:00
resources Prepare for 0.57 release 2020-04-28 11:18:56 +03:00
src Small refactoring of handlers 2020-04-18 17:43:50 +03:00
test Prepare for 0.57 release 2020-04-28 11:18:56 +03:00
.editorconfig Use 2 spaces for Kotlin files as per the IntelliJ platform coding style 2019-05-14 14:13:11 +03:00
.gitignore Include copyright into repository 2020-04-17 11:17:34 +03:00
AUTHORS.md Add runforprogram to contributors list 2020-04-17 10:27:11 +03:00
build.gradle Fix regex for slack notification 2020-04-22 09:56:39 +03:00
CHANGES.md Prepare for 0.57 release 2020-04-28 11:18:56 +03:00
CODE_OF_CONDUCT.md Add Code of Conduct to project 2019-04-10 15:59:48 +03:00
CONTRIBUTING.md Include copyright into repository 2020-04-17 11:17:34 +03:00
gradle.properties Update dependencies 2020-04-10 11:00:47 +03:00
gradlew Update gradle version 2020-02-28 17:35:46 +03:00
gradlew.bat Update gradle version 2020-02-28 17:35:46 +03:00
LICENSE.txt Update license formatting 2019-07-10 12:51:10 +03:00
README.md Move IdeaVim icon in the README 2020-04-17 11:34:28 +03:00
settings.gradle Update copyright 2020-01-27 11:35:00 +03:00

icon

IdeaVim

IdeaVim is a Vim emulation plugin for IDEs based on the IntelliJ Platform. IdeaVim can be used with IntelliJ IDEA, PyCharm, CLion, PhpStorm, WebStorm, RubyMine, AppCode, DataGrip, GoLand, Rider, Cursive, and Android Studio.

Resources:

Setup

  • IdeaVim can be installed via Settings | Plugins. See detailed instructions.

  • Use Tools | Vim Emulator to enable or disable emulation.

  • Use ~/.ideavimrc file as an analog of ~/.vimrc (details). XGD standard is supported as well.

  • Shortcut conflicts can be resolved using:

    • Linux & Windows: File | Settings | Editor | Vim Emulation & File | Settings | Keymap,
    • macOS: Preferences | Editor | Vim Emulation & Preferences | Keymap,
    • regular vim mappings in the ~/.ideavimrc file.

Get Early Access

Would you like to try new features and fixes? Join the Early Access Program and receive EAP builds as updates!

  1. Click the IdeaVim icon icon in the status bar | EAP | Get Early Access...

Or subscribe to EAP updates manually:

  1. Open Settings | Plugins
  2. Click the gear icon ⚙️, select Manage Plugin Repositories, and add the following url: https://plugins.jetbrains.com/plugins/eap/ideavim

See the changelog for the list of unreleased features.

It is important to distinguish EAP builds from traditional pre-release software. Please note that the quality of EAP versions may at times be way below even usual beta standards.

You can always leave your feedback with:

Summary of Supported Vim Features

Supported:

  • Motion keys
  • Deletion/changing
  • Insert mode commands
  • Marks
  • Registers
  • Undo/redo
  • Visual mode commands
  • Some Ex commands
  • Some :set options
  • Full Vim regexps for search and search/replace
  • Key mappings
  • Macros
  • Digraphs
  • Command line and search history
  • Window commands
  • Vim web help
  • Select mode

Emulated Vim plugins:

  • vim-easymotion
  • vim-surround
  • vim-multiple-cursors
  • vim-commentary
  • argtextobj.vim
  • vim-textobj-entire
  • ReplaceWithRegister

Not supported (yet):

  • Jump lists
  • Various less-used commands

See also:

Files

  • ~/.ideavimrc
    • Your IdeaVim-specific Vim initialization commands

You can read your ~/.vimrc file from ~/.ideavimrc with this command:

source ~/.vimrc

Note, that IdeaVim currently parses ~/.ideavimrc file via simple pattern matching. See VIM-669 for proper parsing of VimL files.

Also note that if you have overridden the user.home JVM option, this will affect where IdeaVim looks for your .ideavimrc file. For example, if you have -Duser.home=/my/alternate/home then IdeaVim will source /my/alternate/home/.ideavimrc instead of ~/.ideavimrc.

Alternatively, you can set up initialization commands using XDG standard. Put your settings to $XDG_CONFIG_HOME$/ideavim/ideavimrc file.

Emulated Vim Plugins

See doc/emulated-plugins.md

Changes to the IDE

Executing IDE Actions

IdeaVim adds two commands for listing and executing arbitrary IDE actions as Ex commands or via :map command mappings:

  • :actionlist [pattern]
    • Find IDE actions by name or keymap pattern (E.g. :actionlist extract, :actionlist <C-D)
  • :action {name}
    • Execute an action named NAME

For example, here \r is mapped to the Reformat Code action:

:map \r :action ReformatCode<CR>

Undo/Redo

The IdeaVim plugin uses the undo/redo functionality of the IntelliJ Platform, so the behavior of the u and <C-R> commands may differ from the original Vim. Vim compatibility of undo/redo may be improved in future releases.

See also unresolved undo issues.

Escape

Using <Esc> in dialog windows remains problematic. For most dialog windows, the Vim emulator is put into insert mode with <Esc> not working. You should use <C-c> or <C-[> instead. In some dialog windows, the normal mode is switched by default. The usage of the Vim emulator in dialog windows is an area for improvement.

See also unresolved escape issues.

Contributing

See CONTRIBUTING.md

Authors

See AUTHORS.md for a list of authors and contributors.

License

IdeaVim is licensed under the terms of the GNU Public License version 2 or any later version.