Skip to content

Latest commit

 

History

History
189 lines (158 loc) · 5.97 KB

EXTENSIONS.md

File metadata and controls

189 lines (158 loc) · 5.97 KB

Extensions

Note The internal extension API is considered unstable, as it will likely need to evolve as we add extensions for additional plugins with different setups. This mostly affects plugin developers, not users.

legendary.nvim extensions can automatically load keymaps and commands from other plugins with very little configuration.

To enable a plugin, specify it in your legendary.nvim config, under extensions, where the key is the extension name and the value is the extension config (or false to disable an extension).

require('legendary').setup({
  extensions = {
    -- nvim-tree.lua extension takes no config,
    -- just use `true`
    nvim_tree = true,
    -- this table will be passed as extension config
    some_extension = {
      some_extension_config = some_value,
    },
  },
})

Extension API

To create a new extension, create a Lua module under the legendary.extensions.* namespace; for example, to create an extension called my_extension, create a Lua module legendary.extensions.my_extension. The module should return a single function, which may take a single argument which can be used as configuration. The configuration can be any value you need, such as a table of configuration, as it will be passed via the user's config.

The function returned from an extension is responsible for initializing and setting up anything the extension needs. You should do as little work as possible up front, as extensions are loaded on startup. Sometimes, you can use autocmds provided by the plugin you're writing an extension for (see legendary.extensions.nvim_tree.lua), or alternatively, you may use the require('legendary.extensions').pre_ui_hook(callback) utility function. This sets up callback to be called immediately before the legendary.nvim UI is launched, and when the function returns true, it will remove itself. You can use this to try to load keymaps/commands/etc. right before the UI is launched, but if you successfully load them, you should return true so they don't get loaded multiple times.

If you need more fine-grained control over this, you can use the User LegendaryUiPre autocmd pattern directly, which is how require('legendary.extensions').pre_ui_hook(callback) works internally.

Loading keymaps/commands/etc. from an extension can use the same APIs a user would use to do so, e.g. require('legendary').keymaps(my_keymaps).

Built-in Extensions

Lazy.nvim

Automatically load key mappings defined in lazy.nvim plugin specs into legendary.nvim.

require('legendary').setup({
  extensions = {
    lazy_nvim = true,
  },
})

Which-Key.nvim

Automatically load key mappings defined by which-key.nvim into legendary.nvim. For auto_register to work, which-key.nvim must be loaded on runtimepath before legendary.nvim initializes, but legendary.nvim must initialize the extension before require('which-key').register() is called. Alternatively, you can just pass your which-key tables to legendary directly.

require('legendary').setup({
  extensions = {
    which_key = {
      -- Automatically add which-key tables to legendary
      -- see WHICH_KEY.md for more details
      auto_register = false,
      -- you can put which-key.nvim tables here,
      -- or alternatively have them auto-register,
      -- see WHICH_KEY.md
      mappings = {},
      opts = {},
      -- controls whether legendary.nvim actually binds they keymaps,
      -- or if you want to let which-key.nvim handle the bindings.
      -- if not passed, true by default
      do_binding = true,
      -- controls whether to use legendary.nvim item groups
      -- matching your which-key.nvim groups; if false, all keymaps
      -- are added at toplevel instead of in a group.
      use_groups = true,
    },
  },
})

nvim-tree.lua

Automatically load keymaps and commands for the NvimTree buffer into legendary.nvim.

require('legendary').setup({
  extensions = {
    nvim_tree = true,
  },
})

smart-splits.nvim

Automatically load commands from smart-splits.nvim. This extension can also create the keymaps for you automatically by passing an opts table to the extension.

require('legendary').setup({
  extensions = {
    smart_splits = true, -- do not create keymaps
    -- or, default settings shown below
    smart_splits = {
      directions = { 'h', 'j', 'k', 'l' },
      mods = {
        -- for moving cursor between windows
        move = '<C>',
        -- for resizing windows
        resize = '<M>',
        -- for swapping window buffers
        swap = false, -- false disables creating a binding
      },
    },
    -- or, customize
    smart_splits = {
      directions = { 'h', 'j', 'k', 'l' },
      mods = {
        move = '<C>',
        resize = '<M>',
        -- any of these can also be a table of the following form
        swap = {
          -- this will create the mapping like
          -- <leader><C-h>
          -- <leader><C-j>
          -- <leader><C-k>
          -- <leader><C-l>
          mod = '<C>',
          prefix = '<leader>',
        },
      },
    },
  },
})

op.nvim

Automatically load commands from op.nvim.

require('legendary').setup({
  extensions = {
    op_nvim = true,
  },
})

diffview.nvim

Automatically load commands and keymaps from diffview.nvim. The keymaps will only appear in the legendary.nvim UI for the currently active diffview.nvim view to which they apply.

require('legendary').setup({
  extensions = {
    diffview = true,
  },
})