前回の続き

NeoVim kickstartの設定説明メモ(オプション編)

設定内容(KeyMap)

検索結果のハイライト削除

検索結果のハイライトをESCキーで解除する。
デフォルトでは/で検索を確定した後、別の検索をしないとそのハイライトが残り続ける。結構邪魔。

-- Clear highlights on search when pressing <Esc> in normal mode
--  See `:help hlsearch`
vim.keymap.set('n', '<Esc>', '<cmd>nohlsearch<CR>')

診断ツールを表示する

<Space> + q で診断ツールを分割ウインドウとして表示する。
診断ツールはLSPのアラートなどの表示のこと。VSCodeでいう「問題」タブ。

-- Diagnostic keymaps
vim.keymap.set('n', '<leader>q', vim.diagnostic.setloclist, { desc = 'Open diagnostic [Q]uickfix list' })

ターミナルモードからノーマルモードに戻る

ターミナルモードからノーマルモードに戻るためのショートカット。
通常のノーマルモードに戻るコマンドはCtrl \ Ctrl n になっている。

-- Exit terminal mode in the builtin terminal with a shortcut that is a bit easier
-- for people to discover. Otherwise, you normally need to press <C-\><C-n>, which
-- is not what someone will guess without a bit more experience.
--
-- NOTE: This won't work in all terminal emulators/tmux/etc. Try your own mapping
-- or just use <C-\><C-n> to exit terminal mode
vim.keymap.set('t', '<Esc><Esc>', '<C-\\><C-n>', { desc = 'Exit terminal mode' })

矢印キーの無効化

ノーマルモードでの矢印キーを無効化する。矢印キーを無効化したい場合はコメントアウトを外す。
矢印キーでの移動を絶対に許さないマン向け設定。

-- TIP: Disable arrow keys in normal mode
vim.keymap.set('n', '<left>', '<cmd>echo "Use h to move!!"<CR>')
vim.keymap.set('n', '<right>', '<cmd>echo "Use l to move!!"<CR>')
vim.keymap.set('n', '<up>', '<cmd>echo "Use k to move!!"<CR>')
vim.keymap.set('n', '<down>', '<cmd>echo "Use j to move!!"<CR>')

分割ウインドウ移動

分割ウインドウをCtrl h, Ctrl l, Ctrl j, Ctrl k で移動できるようにする。
ちなみにウインドウ分割は以下の方法でできる。

  • Ctrl w + v 垂直分割
  • Ctrl w + s 水平分割
-- Keybinds to make split navigation easier.
--  Use CTRL+<hjkl> to switch between windows
--
--  See `:help wincmd` for a list of all window commands
vim.keymap.set('n', '<C-h>', '<C-w><C-h>', { desc = 'Move focus to the left window' })
vim.keymap.set('n', '<C-l>', '<C-w><C-l>', { desc = 'Move focus to the right window' })
vim.keymap.set('n', '<C-j>', '<C-w><C-j>', { desc = 'Move focus to the lower window' })
vim.keymap.set('n', '<C-k>', '<C-w><C-k>', { desc = 'Move focus to the upper window' })

設定内容(Basic Autocommands)

ヤンク部分のハイライト

NeovimのAutocommandは、特定のイベントが発生したときに自動的にコマンドを実行する機能のこと。

以下の設定ではTextYankPostというイベントで発火し、ヤンク時にヤンクした文字範囲をハイライトする。
TextYankPostはテキストをヤンクした後に実行されるイベントのこと。

-- Highlight when yanking (copying) text
--  Try it with `yap` in normal mode
--  See `:help vim.highlight.on_yank()`
vim.api.nvim_create_autocmd('TextYankPost', {
  desc = 'Highlight when yanking (copying) text',
  group = vim.api.nvim_create_augroup('kickstart-highlight-yank', { clear = true }),
  callback = function()
    vim.highlight.on_yank()
  end,
})

basic-autocmd-yank-highlight.gif

終わりに

次回は長大なpluginなので投稿できるかな…?

参考

https://neovim.io/doc/user/autocmd.html