From 7a813780a1093b89e7b118b185ebd11ab29aa4ce Mon Sep 17 00:00:00 2001 From: kylo252 <59826753+kylo252@users.noreply.github.com> Date: Wed, 3 Nov 2021 12:32:10 +0100 Subject: fix: overloading keymappings now works correctly even after reloading (#1789) --- lua/lvim/config/init.lua | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'lua/lvim/config/init.lua') 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" -- cgit v1.2.3 From e05ced8ec35b8b8d6862c90b8fc7c10540ed34e2 Mon Sep 17 00:00:00 2001 From: Xavier Young <45989017+younger-1@users.noreply.github.com> Date: Thu, 4 Nov 2021 02:26:56 +0800 Subject: fix(reload): set lvim modules to nil correctly (#1898) --- lua/lvim/config/init.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'lua/lvim/config/init.lua') diff --git a/lua/lvim/config/init.lua b/lua/lvim/config/init.lua index 6c21efa1..1dc83c1e 100644 --- a/lua/lvim/config/init.lua +++ b/lua/lvim/config/init.lua @@ -101,7 +101,7 @@ function M:reload() local lvim_modules = {} for module, _ in pairs(package.loaded) do if module:match "lvim.core" then - package.loaded.module = nil + package.loaded[module] = nil table.insert(lvim_modules, module) end end -- cgit v1.2.3