Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dkendal/nvim-minor-mode
Emacs like minor modes for Neovim
https://github.com/dkendal/nvim-minor-mode
fennel lisp nvim nvim-lua nvim-plugin
Last synced: 8 days ago
JSON representation
Emacs like minor modes for Neovim
- Host: GitHub
- URL: https://github.com/dkendal/nvim-minor-mode
- Owner: Dkendal
- License: mpl-2.0
- Created: 2021-08-14T22:33:53.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-08-20T16:47:35.000Z (over 3 years ago)
- Last Synced: 2025-01-17T00:53:08.349Z (11 days ago)
- Topics: fennel, lisp, nvim, nvim-lua, nvim-plugin
- Language: Fennel
- Homepage:
- Size: 28.3 KB
- Stars: 21
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.org
- Changelog: CHANGELOG.org
- License: LICENSE
Awesome Lists containing this project
README
* Nvim-minor-mode
This package adds similar functionality as Emacs's minor modes.
** Minor modes
Within the definition of this package a minor mode is a set of keymaps that
are enabled with some command, and can be disabled using the same command.They're useful for functionality that you don't necessarily always want to be
active.** Installation
Use whatever package manager you like:
#+begin_src vim
Plug 'Dkendal/nvim-minor-mode'
#+end_src#+begin_src lua
use { 'Dkendal/nvim-minor-mode' }
#+end_src** Usage
Minor modes can be defined using the =define_minor_mode= function.
Say I wanted to defined a "lisp" minor mode. While I could write a new plugin
and define it for all filetypes that are a lisp, I could instead define a
minor mode and enable it as desired while editing files.#+begin_src lua
local define_minor_mode = require('minor-mode').define_minor_modedefine_minor_mode('lisp', [[
Minor modes for lisps to navigate sexps. Replaces some normal movement
keybindings.
]], {
command = 'LispMode',
keymap = {
{
'n',
'j',
function()
vim.fn.search('(')
end,
{ silent = true }
},{
'n',
'k',
function()
vim.fn.search('(', 'b')
end,
{ silent = true }
}
}
})
#+end_srcThe second argument, =LispMode=, will be used to define a new command.
#+begin_src vim
:LispMode
#+end_srcCalling it again will remove all the keymaps.
** Types
#+begin_example
vim-expr :: stringcommand-name :: string
A valid vim command name.
mode :: "n" | "v" | "x" | ... | "!" ""
See [map-overview] or [nvim_set_keymap]
minor-mode-name :: string
lhs :: string
rhs :: vim-expr | function
Standard right hand side of a keybinding, but can also be a lua function.
mapping-opts :: {
nowait = boolean,
silent = boolean,
script = boolean,
expr = boolean,
unique = boolean,
noremap = boolean,
}See the definition of {opts} for [nvim_set_keymap].
mapping :: { mode lhs, rhs, mapping-opts || null }
Same arguments as [nvim_set_keymap], except rhs may also be a lua function.
keymap :: { mapping }
#+end_example** API
All top level API functions should treat kebab-case methods and
underscore_case functions interchangeably for fennel and lua use,
respectively.*** =define_minor_mode(mode :: minor-mode-name, doc :: string, minor-mode-opts)=
Defines a new minor mode whose name is =mode= (a string). It defines a Vim
command named after =opts.command= to toggle the minor mode, standard Vim
command naming rules apply (:h :user-cmd-ambiguous). Provide a short
explanation of what the minor mode is in =doc-string= - this value isn't
exposed anywhere at the moment.=minor-mode-opts= is a map, key values are defined below:
**** =:command= =command-name=
**** =:keymap= =keymap=
An array of key bindings that will be activated with the minor mode. Key
bindings are the same as arguments to =nvim_set_keymap= (:h nvim_set_keymap())Here's an example keymap:
#+begin_src lua
{
keymap = {
{ 'n', '', ':echo \"down\"', { silent = true } },
{ 'n', '', ':echo \"up\"', { silent = true } } }
}
}
#+end_src** Caveats
This plugin uses buffer local keymaps, if you already have a buffer local
keymap present, or overwrite it with another while a minor mode is active and
then disable said minor mode, the keymap will be removed.** Related
- https://github.com/kana/vim-submode
- https://www.gnu.org/software/emacs/manual/html_node/elisp/Defining-Minor-Modes.html** Liscence
MPL-2.0