diff options
| author | kylo252 <[email protected]> | 2021-11-03 12:32:10 +0100 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2021-11-03 12:32:10 +0100 | 
| commit | 7a813780a1093b89e7b118b185ebd11ab29aa4ce (patch) | |
| tree | 80e1479e1eea84c126013f7f4feb8e408b514a2c /lua | |
| parent | a6845c9cc72133661ab7e2c1a6d59f0e34ca2125 (diff) | |
fix: overloading keymappings now works correctly even after reloading (#1789)
Diffstat (limited to 'lua')
| -rw-r--r-- | lua/lvim/config/init.lua | 18 | ||||
| -rw-r--r-- | lua/lvim/core/builtins/init.lua | 1 | ||||
| -rw-r--r-- | lua/lvim/keymappings.lua | 20 | 
3 files changed, 23 insertions, 16 deletions
| diff --git a/lua/lvim/config/init.lua b/lua/lvim/config/init.lua index 1256e236..6c21efa1 100644 --- a/lua/lvim/config/init.lua +++ b/lua/lvim/config/init.lua @@ -5,6 +5,11 @@ local M = {}  local user_config_dir = get_config_dir()  local user_config_file = utils.join_paths(user_config_dir, "config.lua") +local function apply_defaults(configs, defaults) +  configs = configs or {} +  return vim.tbl_deep_extend("keep", configs, defaults) +end +  ---Get the full path to the user configuration file  ---@return string  function M:get_user_config_path() @@ -27,11 +32,14 @@ function M:init()    local settings = require "lvim.config.settings"    settings.load_options() +  local default_keymaps = require("lvim.keymappings").get_defaults() +  lvim.keys = apply_defaults(lvim.keys, default_keymaps) +    local autocmds = require "lvim.core.autocmds" -  lvim.autocommands = autocmds.load_augroups() +  lvim.autocommands = apply_defaults(lvim.autocommands, autocmds.load_augroups())    local lvim_lsp_config = require "lvim.lsp.config" -  lvim.lsp = vim.deepcopy(lvim_lsp_config) +  lvim.lsp = apply_defaults(lvim.lsp, vim.deepcopy(lvim_lsp_config))    local supported_languages = require "lvim.config.supported_languages"    require("lvim.lsp.manager").init_defaults(supported_languages) @@ -80,6 +88,9 @@ function M:load(config_path)    autocmds.define_augroups(lvim.autocommands) +  vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader +  require("lvim.keymappings").load(lvim.keys) +    local settings = require "lvim.config.settings"    settings.load_commands()  end @@ -89,7 +100,7 @@ end  function M:reload()    local lvim_modules = {}    for module, _ in pairs(package.loaded) do -    if module:match "lvim" then +    if module:match "lvim.core" then        package.loaded.module = nil        table.insert(lvim_modules, module)      end @@ -98,7 +109,6 @@ function M:reload()    M:init()    M:load() -  require("lvim.keymappings").setup() -- this should be done before loading the plugins    local plugins = require "lvim.plugins"    utils.toggle_autoformat()    local plugin_loader = require "lvim.plugin-loader" diff --git a/lua/lvim/core/builtins/init.lua b/lua/lvim/core/builtins/init.lua index 315deed3..cd47b638 100644 --- a/lua/lvim/core/builtins/init.lua +++ b/lua/lvim/core/builtins/init.lua @@ -1,7 +1,6 @@  local M = {}  local builtins = { -  "lvim.keymappings",    "lvim.core.which-key",    "lvim.core.gitsigns",    "lvim.core.cmp", diff --git a/lua/lvim/keymappings.lua b/lua/lvim/keymappings.lua index be8ebe96..a57b2d36 100644 --- a/lua/lvim/keymappings.lua +++ b/lua/lvim/keymappings.lua @@ -57,13 +57,14 @@ end  -- Load key mappings for all provided modes  -- @param keymaps A list of key mappings for each mode  function M.load(keymaps) +  keymaps = keymaps or {}    for mode, mapping in pairs(keymaps) do      M.load_mode(mode, mapping)    end  end -function M.config() -  lvim.keys = { +function M.get_defaults() +  local keys = {      ---@usage change or add keymappings for insert mode      insert_mode = {        -- 'jk' for quitting insert mode @@ -151,12 +152,14 @@ function M.config()    }    if vim.fn.has "mac" == 1 then -    lvim.keys.normal_mode["<A-Up>"] = lvim.keys.normal_mode["<C-Up>"] -    lvim.keys.normal_mode["<A-Down>"] = lvim.keys.normal_mode["<C-Down>"] -    lvim.keys.normal_mode["<A-Left>"] = lvim.keys.normal_mode["<C-Left>"] -    lvim.keys.normal_mode["<A-Right>"] = lvim.keys.normal_mode["<C-Right>"] +    keys.normal_mode["<A-Up>"] = keys.normal_mode["<C-Up>"] +    keys.normal_mode["<A-Down>"] = keys.normal_mode["<C-Down>"] +    keys.normal_mode["<A-Left>"] = keys.normal_mode["<C-Left>"] +    keys.normal_mode["<A-Right>"] = keys.normal_mode["<C-Right>"]      Log:debug "Activated mac keymappings"    end + +  return keys  end  function M.print(mode) @@ -168,9 +171,4 @@ function M.print(mode)    end  end -function M.setup() -  vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader -  M.load(lvim.keys) -end -  return M | 
