diff options
author | kylo252 <[email protected]> | 2022-11-02 11:29:07 +0100 |
---|---|---|
committer | GitHub <[email protected]> | 2022-11-02 11:29:07 +0100 |
commit | 8d3f9b8bf7f5fddca2e8046a84ecbd7c3945dcba (patch) | |
tree | 4d6063d12004ae737347368deb08d3873d74b618 /lua/lvim | |
parent | 375232c95a45d917b201b4398ac173202e59e87f (diff) |
refactor(theme)!: decouple tokyonight options (#3384)
Diffstat (limited to 'lua/lvim')
-rw-r--r-- | lua/lvim/config/_deprecated.lua | 84 | ||||
-rw-r--r-- | lua/lvim/config/init.lua | 94 | ||||
-rw-r--r-- | lua/lvim/core/theme.lua | 126 | ||||
-rw-r--r-- | lua/lvim/keymappings.lua | 15 |
4 files changed, 139 insertions, 180 deletions
diff --git a/lua/lvim/config/_deprecated.lua b/lua/lvim/config/_deprecated.lua new file mode 100644 index 00000000..4cf4381e --- /dev/null +++ b/lua/lvim/config/_deprecated.lua @@ -0,0 +1,84 @@ +---@diagnostic disable: deprecated +local M = {} + +local function deprecate(name, alternative) + local in_headless = #vim.api.nvim_list_uis() == 0 + if in_headless then + return + end + + alternative = alternative or "See https://github.com/LunarVim/LunarVim#breaking-changes" + + local trace = debug.getinfo(3, "Sl") + local shorter_src = trace.short_src + local t = shorter_src .. ":" .. (trace.currentline or trace.lastlinedefined) + vim.schedule(function() + vim.notify_once(string.format("%s: `%s` is deprecated.\n %s.", t, name, alternative), vim.log.levels.WARN) + end) +end + +function M.handle() + local mt = { + __newindex = function(_, k, _) + deprecate(k) + end, + } + + ---@deprecated + lvim.builtin.theme.options = {} + setmetatable(lvim.builtin.theme.options, { + __newindex = function(_, k, v) + deprecate("lvim.builtin.theme.options." .. k, "Use `lvim.builtin.theme.<theme>.options` instead") + lvim.builtin.theme.tokyonight.options[k] = v + end, + }) + + ---@deprecated + lvim.builtin.notify = {} + setmetatable(lvim.builtin.notify, { + __newindex = function(_, k, _) + deprecate("lvim.builtin.notify." .. k, "See LunarVim#3294") + end, + }) + + if lvim.lsp.override and not vim.tbl_isempty(lvim.lsp.override) then + deprecate("lvim.lsp.override", "Use `lvim.lsp.automatic_configuration.skipped_servers` instead") + vim.tbl_map(function(c) + if not vim.tbl_contains(lvim.lsp.automatic_configuration.skipped_servers, c) then + table.insert(lvim.lsp.automatic_configuration.skipped_servers, c) + end + end, lvim.lsp.override) + end + + if lvim.autocommands.custom_groups then + deprecate( + "lvim.autocommands.custom_groups", + "Use vim.api.nvim_create_autocmd instead or check LunarVim#2592 to learn about the new syntax" + ) + end + + if lvim.lsp.automatic_servers_installation then + deprecate( + "lvim.lsp.automatic_servers_installation", + "Use `lvim.lsp.installer.setup.automatic_installation` instead" + ) + end + + ---@deprecated + lvim.builtin.dashboard = {} + setmetatable(lvim.builtin.dashboard, { + __newindex = function(_, k, _) + deprecate("lvim.builtin.dashboard." .. k, "Use `lvim.builtin.alpha` instead. See LunarVim#1906") + end, + }) + + ---@deprecated + lvim.lsp.popup_border = {} + setmetatable(lvim.lsp.popup_border, mt) + + ---@deprecated + lvim.lang = {} + setmetatable(lvim.lang, mt) +end + +return M diff --git a/lua/lvim/config/init.lua b/lua/lvim/config/init.lua index 4f950beb..b201b408 100644 --- a/lua/lvim/config/init.lua +++ b/lua/lvim/config/init.lua @@ -7,12 +7,12 @@ local user_config_file = utils.join_paths(user_config_dir, "config.lua") ---Get the full path to the user configuration file ---@return string -function M:get_user_config_path() +function M.get_user_config_path() return user_config_file end --- Initialize lvim default configuration and variables -function M:init() +function M.init() lvim = vim.deepcopy(require "lvim.config.defaults") require("lvim.keymappings").load_defaults() @@ -29,100 +29,20 @@ function M:init() local lvim_lsp_config = require "lvim.lsp.config" lvim.lsp = vim.deepcopy(lvim_lsp_config) - ---@deprecated replaced with lvim.builtin.alpha - lvim.builtin.dashboard = { - active = false, - on_config_done = nil, - search_handler = "", - disable_at_vim_enter = 0, - session_directory = "", - custom_header = {}, - custom_section = {}, - footer = {}, - } - lvim.builtin.luasnip = { sources = { friendly_snippets = true, }, } - ---@deprecated - lvim.builtin.notify = { - active = false, - } -end - -local function handle_deprecated_settings() - local function deprecation_notice(setting, new_setting) - local in_headless = #vim.api.nvim_list_uis() == 0 - if in_headless then - return - end - - local msg = string.format( - "Deprecation notice: [%s] setting is no longer supported. %s", - setting, - new_setting or "See https://github.com/LunarVim/LunarVim#breaking-changes" - ) - vim.schedule(function() - vim.notify_once(msg, vim.log.levels.WARN) - end) - end - - ---lvim.lang.FOO.lsp - for lang, entry in pairs(lvim.lang) do - local deprecated_config = entry.formatters or entry.linters or {} - if not vim.tbl_isempty(deprecated_config) then - deprecation_notice(string.format("lvim.lang.%s", lang)) - end - end - - -- lvim.lsp.override - if lvim.lsp.override and not vim.tbl_isempty(lvim.lsp.override) then - deprecation_notice("lvim.lsp.override", "Use `lvim.lsp.automatic_configuration.skipped_servers` instead") - vim.tbl_map(function(c) - if not vim.tbl_contains(lvim.lsp.automatic_configuration.skipped_servers, c) then - table.insert(lvim.lsp.automatic_configuration.skipped_servers, c) - end - end, lvim.lsp.override) - end - - -- lvim.lsp.popup_border - if vim.tbl_contains(vim.tbl_keys(lvim.lsp), "popup_border") then - deprecation_notice "lvim.lsp.popup_border" - end - - -- dashboard.nvim - if lvim.builtin.dashboard.active then - deprecation_notice("lvim.builtin.dashboard", "Use `lvim.builtin.alpha` instead. See LunarVim#1906") - end - - -- notify.nvim - if lvim.builtin.notify.active then - deprecation_notice("lvim.builtin.notify", "See LunarVim#3294") - end - - if lvim.autocommands.custom_groups then - deprecation_notice( - "lvim.autocommands.custom_groups", - "Use vim.api.nvim_create_autocmd instead or check LunarVim#2592 to learn about the new syntax" - ) - end - - if lvim.lsp.automatic_servers_installation then - deprecation_notice( - "lvim.lsp.automatic_servers_installation", - "Use `lvim.lsp.installer.setup.automatic_installation` instead" - ) - end + require("lvim.config._deprecated").handle() end --- Override the configuration with a user provided one -- @param config_path The path to the configuration overrides -function M:load(config_path) +function M.load(config_path) local autocmds = reload "lvim.core.autocmds" - config_path = config_path or self:get_user_config_path() + config_path = config_path or M.get_user_config_path() local ok, err = pcall(dofile, config_path) if not ok then if utils.is_file(user_config_file) then @@ -138,8 +58,6 @@ function M:load(config_path) Log:set_level(lvim.log.level) - handle_deprecated_settings() - autocmds.define_autocmds(lvim.autocommands) vim.g.mapleader = (lvim.leader == "space" and " ") or lvim.leader @@ -157,7 +75,7 @@ end --- Override the configuration with a user provided one -- @param config_path The path to the configuration overrides -function M:reload() +function M.reload() vim.schedule(function() reload("lvim.utils.hooks").run_pre_reload() diff --git a/lua/lvim/core/theme.lua b/lua/lvim/core/theme.lua index efe2b404..04186b0b 100644 --- a/lua/lvim/core/theme.lua +++ b/lua/lvim/core/theme.lua @@ -5,83 +5,51 @@ local M = {} M.config = function() lvim.builtin.theme = { name = "tokyonight", - options = { - on_highlights = function(hl, c) - hl.IndentBlanklineContextChar = { - fg = c.dark5, - } - hl.TSConstructor = { - fg = c.blue1, - } - hl.TSTagDelimiter = { - fg = c.dark5, - } - -- local prompt = "#2d3149" - -- hl.TelescopeNormal = { - -- bg = c.bg_dark, - -- fg = c.fg_dark, - -- } - -- hl.TelescopeBorder = { - -- bg = c.bg_dark, - -- fg = c.bg_dark, - -- } - -- hl.TelescopePromptNormal = { - -- bg = prompt, - -- } - -- hl.TelescopePromptBorder = { - -- bg = prompt, - -- fg = prompt, - -- } - -- hl.TelescopePromptTitle = { - -- bg = prompt, - -- fg = prompt, - -- } - -- hl.TelescopePreviewTitle = { - -- bg = c.bg_dark, - -- fg = c.bg_dark, - -- } - -- hl.TelescopeResultsTitle = { - -- bg = c.bg_dark, - -- fg = c.bg_dark, - -- } - end, - style = "night", -- The theme comes in three styles, `storm`, a darker variant `night` and `day` - transparent = lvim.transparent_window, -- Enable this to disable setting the background color - terminal_colors = true, -- Configure the colors used when opening a `:terminal` in Neovim - styles = { - -- Style to be applied to different syntax groups - -- Value is any valid attr-list value for `:help nvim_set_hl` - comments = { italic = true }, - keywords = { italic = true }, - functions = {}, - variables = {}, - -- Background styles. Can be "dark", "transparent" or "normal" - sidebars = "dark", -- style for sidebars, see below - floats = "dark", -- style for floating windows + tokyonight = { + options = { + on_highlights = function(hl, c) + hl.IndentBlanklineContextChar = { + fg = c.dark5, + } + hl.TSConstructor = { + fg = c.blue1, + } + hl.TSTagDelimiter = { + fg = c.dark5, + } + end, + style = "night", -- The theme comes in three styles, `storm`, a darker variant `night` and `day` + transparent = lvim.transparent_window, -- Enable this to disable setting the background color + terminal_colors = true, -- Configure the colors used when opening a `:terminal` in Neovim + styles = { + -- Style to be applied to different syntax groups + -- Value is any valid attr-list value for `:help nvim_set_hl` + comments = { italic = true }, + keywords = { italic = true }, + functions = {}, + variables = {}, + -- Background styles. Can be "dark", "transparent" or "normal" + sidebars = "dark", -- style for sidebars, see below + floats = "dark", -- style for floating windows + }, + -- Set a darker background on sidebar-like windows. For example: `["qf", "vista_kind", "terminal", "packer"]` + sidebars = { + "qf", + "vista_kind", + "terminal", + "packer", + "spectre_panel", + "NeogitStatus", + "help", + }, + day_brightness = 0.3, -- Adjusts the brightness of the colors of the **Day** style. Number between 0 and 1, from dull to vibrant colors + hide_inactive_statusline = false, -- Enabling this option, will hide inactive statuslines and replace them with a thin border instead. Should work with the standard **StatusLine** and **LuaLine**. + dim_inactive = false, -- dims inactive windows + lualine_bold = false, -- When `true`, section headers in the lualine theme will be bold + use_background = true, -- can be light/dark/auto. When auto, background will be set to vim.o.background }, - -- Set a darker background on sidebar-like windows. For example: `["qf", "vista_kind", "terminal", "packer"]` - sidebars = { - "qf", - "vista_kind", - "terminal", - "packer", - "spectre_panel", - "NeogitStatus", - "help", - }, - day_brightness = 0.3, -- Adjusts the brightness of the colors of the **Day** style. Number between 0 and 1, from dull to vibrant colors - hide_inactive_statusline = false, -- Enabling this option, will hide inactive statuslines and replace them with a thin border instead. Should work with the standard **StatusLine** and **LuaLine**. - dim_inactive = false, -- dims inactive windows - lualine_bold = false, -- When `true`, section headers in the lualine theme will be bold - use_background = true, -- can be light/dark/auto. When auto, background will be set to vim.o.background }, } - local status_ok, theme = pcall(require, "tokyonight") - if not status_ok then - return - end - - theme.setup(lvim.builtin.theme.options) end M.setup = function() @@ -91,10 +59,14 @@ M.setup = function() return end - local status_ok, theme = pcall(require, "tokyonight") - if status_ok and theme then - theme.setup(lvim.builtin.theme.options) + local selected_theme = lvim.builtin.theme.name + local status_ok, plugin = pcall(require, selected_theme) + if not status_ok then + return end + pcall(function() + plugin.setup(lvim.builtin.theme[selected_theme].options) + end) -- ref: https://github.com/neovim/neovim/issues/18201#issuecomment-1104754564 local colors = vim.api.nvim_get_runtime_file(("colors/%s.*"):format(lvim.colorscheme), false) diff --git a/lua/lvim/keymappings.lua b/lua/lvim/keymappings.lua index d0d46fd7..d5a6df1d 100644 --- a/lua/lvim/keymappings.lua +++ b/lua/lvim/keymappings.lua @@ -109,21 +109,6 @@ end function M.clear(keymaps) local default = M.get_defaults() for mode, mappings in pairs(keymaps) do - local translated_mode = mode_adapters[mode] or mode - for key, _ in pairs(mappings) do - -- some plugins may override default bindings that the user hasn't manually overridden - if default[mode][key] ~= nil or (default[translated_mode] ~= nil and default[translated_mode][key] ~= nil) then - pcall(vim.keymap.del, translated_mode, key) - end - end - end -end - --- Unsets all keybindings defined in keymaps --- @param keymaps The table of key mappings containing a list per mode (normal_mode, insert_mode, ..) -function M.clear(keymaps) - local default = M.get_defaults() - for mode, mappings in pairs(keymaps) do local translated_mode = mode_adapters[mode] and mode_adapters[mode] or mode for key, _ in pairs(mappings) do -- some plugins may override default bindings that the user hasn't manually overriden |