-
Notifications
You must be signed in to change notification settings - Fork 202
mini.jump2d
Evgeni Chasnovski edited this page May 7, 2022
·
1 revision
The 'mini.jump2d' module can be used to replace builtin f
, F
, t
, T
motions (if, for some reason, mini.jump is not a suitable solution). Here is a config which creates mappings for Normal, Visual and Operator-pending modes (with a rudimentary dot-repeat) to achieve that:
require('mini.jump2d').setup()
local function make_fFtT_keymap(key, extra_opts)
local opts = vim.tbl_deep_extend('force', { allowed_lines = { blank = false, fold = false } }, extra_opts)
opts.hooks = opts.hooks or {}
opts.hooks.before_start = function()
local input = vim.fn.getcharstr()
--stylua: ignore
if input == nil then
opts.spotter = function() return {} end
else
local pattern = vim.pesc(input)
opts.spotter = MiniJump2d.gen_pattern_spotter(pattern)
end
end
-- Using `<Cmd>...<CR>` enables dot-repeat in Operator-pending mode
_G.jump2dfFtT_opts = _G.jump2dfFtT_opts or {}
_G.jump2dfFtT_opts[key] = opts
local command = string.format('<Cmd>lua MiniJump2d.start(_G.jump2dfFtT_opts.%s)<CR>', key)
vim.api.nvim_set_keymap('n', key, command, {})
vim.api.nvim_set_keymap('v', key, command, {})
vim.api.nvim_set_keymap('o', key, command, {})
end
make_fFtT_keymap('f', { allowed_lines = { cursor_before = false } })
make_fFtT_keymap('F', { allowed_lines = { cursor_after = false } })
make_fFtT_keymap('t', {
allowed_lines = { cursor_before = false },
hooks = { after_jump = function() vim.api.nvim_input('<Left>') end },
})
make_fFtT_keymap('T', {
allowed_lines = { cursor_after = false },
hooks = { after_jump = function() vim.api.nvim_input('<Right>') end },
})