set options

모든 set 옵션은 set-commands에서 볼 수 있다.

action 명령

:action은 IntelliJ의 내장 기능을 실행해주는 편리한 명령이며, IntelliJ의 대부분의 기능은 :action으로 호출할 수 있는 아이디를 갖고 있다.

(IntelliJ 전용이기 때문에 당연히 vim 에서는 쓸 수 없다.)

모든 action은 :actionlist로 볼 수 있다. 3000개가 넘으므로 command + a로 복사해서 다른 곳에 붙여넣고 쓸만한 것이 있는지 찾아보면 된다.

:action 명령을 쓰는 기본적인 방법은 vim 명령행에서 입력하는 것이다.

예를 들어 :action ManageRecentProjects를 입력하고 엔터를 치면 프로젝트 선택 화면이 나온다.

하지만 :action의 진정한 활용은 역시 nmap, map에 있다.

map을 사용해 매핑할 때에는 두 가지 문법을 사용할 수 있다.

다음은 <tab>fQuickFixes를 매핑한 예제이다.

nnoremap <Tab>f :action QuickFixes<CR>

<Action>을 사용해도 된다. 이렇게 하면 <CR>을 마지막에 넣지 않아도 되므로 편리하다. 단, 재귀적 사용을 금지하는 noremap 옵션을 쓸 수 없으므로 nnoremap은 못 쓰고 nmap이나 map 만 쓸 수 있다. 어차피 <Action>으로는 IntelliJ의 기능만 호출하므로 당연히 재귀적 사용이 기본적으로 제한되어 있어서 그런 것 같다.

nmap <Tab>f <Action>(QuickFixes)

좀 더 pure vim 스럽게 쓰고 싶다면 그냥 nnoremap<CR>을 쓰면 되겠다.

" tabbar와 비슷한 느낌으로 사용할 수 있다
nnoremap \t :action ActivateStructureToolWindow<CR>

" startify와 비슷한 느낌으로 최근 프로젝트 이동을 할 수 있다
nnoremap \s :action ManageRecentProjects<CR>

set trackactionids 을 통해 특정 기능의 action 아이디 알아내기

참고: marketplace plugin example

set trackactionids 또는 set tai를 입력하면 IntelliJ의 기능을 사용할 때마다 화면 오른쪽 아래에 해당 기능의 action id를 팝업으로 보여준다.

이 아이디를 사용해서 :action 아이디로 호출하면 해당 기능을 사용할 수 있으므로, nmap 등에 매핑해서 사용하면 된다.

IntelliJ 빌트인 기능 뿐 아니라 marketplace에서 다운로드한 플러그인의 다양한 기능들도 아이디를 알아낼 수 있기 때문에 매우 유용하다.

플러그인

ideavim은 유명한 vim 플러그인의 에뮬레이션을 제공한다.

물론 vim 플러그인을 그대로 쓸 수 있는 것은 아니고, ideavim에서 사용할 수 있도록 만들어진 것이다.

2020년 3월 28일 기준으로 ideavim에서 지원되는 유명 플러그인은 다음과 같다.

Emulated Vim plugins:

  • vim-easymotion
  • vim-surround
  • vim-multiple-cursors
  • vim-commentary

vim-surround

vim-surround 는 vim의 vim-surround와 똑같은 느낌으로 사용할 수 있었다.

vim-surround를 사용하려면 .ideavimrc에 다음과 같이 추가해주면 된다.

set surround

vim-easymotion

이제 ideavim에도 easymotion이 들어와서 easymotion 스타일로 커서를 이동시킬 수 있게 되었다.

그런데 ideavim 만으로는 작동이 안 된다는 문제가 있다. easymotion을 사용하려면 다음 절차를 거쳐야 한다.

  • IntelliJ에서 AceJump 플러그인을 설치한다.
  • IntelliJ에서 IdeaVim-EasyMotion 플러그인을 설치한다.
  • .ideavimrc에 다음 내용을 추가한다.
set easymotion

키 매핑은 다음과 같이 할 수 있다. 나는 spacemapleader로 쓰기 때문에 다음과 같이 설정했다.

let mapleader=" "
nmap <Leader>l <Plug>(easymotion-lineforward)
nmap <Leader>j <Plug>(easymotion-j)
nmap <Leader>k <Plug>(easymotion-k)
nmap <Leader>h <Plug>(easymotion-linebackward)
nmap <Leader>a <Plug>(easymotion-jumptoanywhere)

NERDTree

https://github.com/JetBrains/ideavim/wiki/NERDTree-support

vim에서의 NERDTree는 아쉬운 점이 많아서 잘 안 쓰는데, Ideavim에서는 Project Explorer 제어 기능으로 포팅이 되면서 엄청 편리한 기능이 되었다.

Ideavim을 쓴다면 NERDTree는 필수 기능이라 생각한다. command + 1로 커서가 프로젝트 익스플로러로 이동한 이후에 j, k로 커서를 이동할 수 있고, 검색도 된다.

Plug 'preservim/nerdtree'
  • j, k - 커서 위/아래 이동.
  • C-j, C-k - 위/아래 sibling 이동.
  • S-j, S-k - sibling 중 마지막, 첫번째로 이동.
  • m - 컨텍스트 메뉴(우클릭).
  • o - 파일 열기.
  • go - 파일은 열지만 커서는 프로젝트 익스플로러에 남아 있음.
  • / - 파일 이름 검색.
  • p - 현재 커서가 위치한 노드의 직계 부모 노드로 이동.
  • P - 최상위 노드로 이동. 즉 프로젝트 루트 디렉토리로 이동.

제공하는 명령은 여러가지가 있지만 굳이 다 알 거 없고 :NERDTreeFind 하나면 알아도 충분한 것 같다.

Project Explorer를 활성화 시키면서 현재 편집중인 파일을 하이라이트시켜준다. IntelliJ의 기본 키 제어로는 option - F1, 1을 써야 했는데, 이제는 이렇게 설정해서 쓴다.

nmap \f :NERDTreeFind<CR>

경험

2017-01-30 빌드 오류 해결

오래간만에 IdeaVIM Github에 가보니 Commit이 꽤 많아졌길래 별 생각 없이 pull을 했다.

git pull --rebase upstrem master

다음과 같이 빌드도 해 주었다.

./gradlew clean buildPlugin

그리고 IntelliJ에 들어가서 Install plugin from disk를 통해 빌드한 jar파일을 설치하려 했는데…

Error : Plugin 'IdeaVim' is incompatible with this installation라는 에러가 발생했다.

앗 뭐지. 온갖 삽질을 거친 끝에 @ideavim 트위터 계정에 물어보니 다음과 같은 응답을 받을 수 있었다.

@JohnGrib Current master branch is 2017.1+ due to platform API changes, check out branch platform-143 for 2016.1+.

대충 현재 master브랜치는 IntelliJ IDEA 2017.1+ 빌드를 위한 것이니까, 2016.1+ 빌드를 위한 platform-143브랜치로 체크아웃하면 된다는 것. 해보니 잘 된다. 역시 삽질부터 하지 말고 진작 공식 계정에 물어볼 걸 그랬다.

함께 읽기

  • [[/tool/jetbrains]]

주석