shorten some mapping functions in utils.lua
This commit is contained in:
parent
650614d14b
commit
0b83d9cc0c
2 changed files with 52 additions and 50 deletions
2
init.lua
2
init.lua
|
@ -1,9 +1,7 @@
|
||||||
require "core"
|
require "core"
|
||||||
require "core.options"
|
require "core.options"
|
||||||
|
|
||||||
vim.defer_fn(function()
|
|
||||||
require("core.utils").load_mappings()
|
require("core.utils").load_mappings()
|
||||||
end, 0)
|
|
||||||
|
|
||||||
-- setup packer + plugins
|
-- setup packer + plugins
|
||||||
require("core.packer").bootstrap()
|
require("core.packer").bootstrap()
|
||||||
|
|
|
@ -22,8 +22,8 @@ M.load_config = function()
|
||||||
if chadrc_exists then
|
if chadrc_exists then
|
||||||
-- merge user config if it exists and is a table; otherwise display an error
|
-- merge user config if it exists and is a table; otherwise display an error
|
||||||
if type(chadrc) == "table" then
|
if type(chadrc) == "table" then
|
||||||
config.mappings = M.remove_default_keys(chadrc.mappings.disabled or nil, config.mappings)
|
M.remove_default_keys(chadrc.mappings or {})
|
||||||
config = merge_tb("force", config, chadrc) or {}
|
config = merge_tb("force", config, chadrc)
|
||||||
else
|
else
|
||||||
error "chadrc must return a table!"
|
error "chadrc must return a table!"
|
||||||
end
|
end
|
||||||
|
@ -33,38 +33,43 @@ M.load_config = function()
|
||||||
return config
|
return config
|
||||||
end
|
end
|
||||||
|
|
||||||
M.remove_default_keys = function(disabled_mappings, default_mappings)
|
-- store mapping section names which have plugin key = true
|
||||||
if not disabled_mappings then
|
local lazyload_mappings_list = {}
|
||||||
return default_mappings
|
|
||||||
|
M.remove_default_keys = function(user_mappings)
|
||||||
|
local user_keys = {}
|
||||||
|
local user_sections = vim.tbl_keys(user_mappings)
|
||||||
|
|
||||||
|
-- push user_map keys in user_keys table
|
||||||
|
for _, section in ipairs(user_sections) do
|
||||||
|
user_keys = vim.tbl_deep_extend("force", user_keys, user_mappings[section])
|
||||||
end
|
end
|
||||||
|
|
||||||
-- store keys in a array with true value to compare
|
local function disable_key(mode, keybind, mode_mapping)
|
||||||
local keys_to_disable = {}
|
if user_keys[mode] and user_keys[mode][keybind] then
|
||||||
for _, section_keys in pairs(disabled_mappings) do
|
mode_mapping[keybind] = nil
|
||||||
if type(section_keys) == "table" then
|
|
||||||
for k, _ in pairs(section_keys) do
|
|
||||||
keys_to_disable[k] = true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- make a copy as we need to modify default_mappings
|
local default_mappings = require("core.default_config").mappings
|
||||||
|
|
||||||
|
-- remove user_maps from default mapping table
|
||||||
for section_name, section_mappings in pairs(default_mappings) do
|
for section_name, section_mappings in pairs(default_mappings) do
|
||||||
|
-- store mapping section name into a table
|
||||||
|
if section_mappings.plugin then
|
||||||
|
lazyload_mappings_list[section_name] = true
|
||||||
section_mappings.plugin = nil
|
section_mappings.plugin = nil
|
||||||
|
end
|
||||||
|
|
||||||
for mode, mode_mapping in pairs(section_mappings) do
|
for mode, mode_mapping in pairs(section_mappings) do
|
||||||
for k, _ in pairs(mode_mapping) do
|
for keybind, _ in pairs(mode_mapping) do
|
||||||
-- if key if found then remove from default_mappings
|
disable_key(mode, keybind, mode_mapping)
|
||||||
if keys_to_disable[k] then
|
|
||||||
default_mappings[section_name][mode][k] = nil
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return default_mappings
|
M.load_mappings = function(mappings, mapping_opt)
|
||||||
end
|
|
||||||
|
|
||||||
M.load_mappings = function(section, mapping_opt)
|
|
||||||
-- set mapping function with/without whichkey
|
-- set mapping function with/without whichkey
|
||||||
local set_maps
|
local set_maps
|
||||||
local whichkey_exists, wk = pcall(require, "which-key")
|
local whichkey_exists, wk = pcall(require, "which-key")
|
||||||
|
@ -81,9 +86,14 @@ M.load_mappings = function(section, mapping_opt)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local set_section_map = function(section_values)
|
local mappings_tb = M.load_config().mappings
|
||||||
section_values.plugin = nil
|
mappings = vim.deepcopy(type(mappings) == "string" and { mappings_tb[mappings] } or mappings_tb)
|
||||||
for mode, mode_values in pairs(section_values) do
|
|
||||||
|
local function set_mappings()
|
||||||
|
for name, section in pairs(mappings) do
|
||||||
|
-- skip mapping section with plugin=true
|
||||||
|
if not lazyload_mappings_list[name] then
|
||||||
|
for mode, mode_values in pairs(section) do
|
||||||
for keybind, mapping_info in pairs(mode_values) do
|
for keybind, mapping_info in pairs(mode_values) do
|
||||||
-- merge default + user opts
|
-- merge default + user opts
|
||||||
local default_opts = merge_tb("force", { mode = mode }, mapping_opt or {})
|
local default_opts = merge_tb("force", { mode = mode }, mapping_opt or {})
|
||||||
|
@ -97,18 +107,12 @@ M.load_mappings = function(section, mapping_opt)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local mappings = require("core.utils").load_config().mappings
|
vim.defer_fn(function()
|
||||||
|
set_mappings()
|
||||||
if type(section) == "string" then
|
end, 0)
|
||||||
set_section_map(mappings[section])
|
|
||||||
else
|
|
||||||
for _, sect in pairs(mappings) do
|
|
||||||
if sect.plugin == nil or sect.plugin == false then
|
|
||||||
set_section_map(sect)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- remove plugins defined in chadrc
|
-- remove plugins defined in chadrc
|
||||||
|
@ -129,7 +133,7 @@ M.merge_plugins = function(default_plugins)
|
||||||
local user_plugins = M.load_config().plugins.user
|
local user_plugins = M.load_config().plugins.user
|
||||||
|
|
||||||
-- merge default + user plugin table
|
-- merge default + user plugin table
|
||||||
default_plugins = merge_tb("force", default_plugins, user_plugins) or {}
|
default_plugins = merge_tb("force", default_plugins, user_plugins)
|
||||||
|
|
||||||
local final_table = {}
|
local final_table = {}
|
||||||
|
|
||||||
|
@ -143,8 +147,8 @@ end
|
||||||
|
|
||||||
M.load_override = function(default_table, plugin_name)
|
M.load_override = function(default_table, plugin_name)
|
||||||
local user_table = M.load_config().plugins.override[plugin_name] or {}
|
local user_table = M.load_config().plugins.override[plugin_name] or {}
|
||||||
user_table = type(user_table) == "function" and user_table() or user_table
|
user_table = type(user_table) == "table" and user_table or user_table()
|
||||||
return merge_tb("force", default_table, user_table or {}) or {}
|
return merge_tb("force", default_table, user_table)
|
||||||
end
|
end
|
||||||
|
|
||||||
M.packer_sync = function(...)
|
M.packer_sync = function(...)
|
||||||
|
|
Loading…
Reference in a new issue