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 | |
| parent | 375232c95a45d917b201b4398ac173202e59e87f (diff) | |
refactor(theme)!: decouple tokyonight options (#3384)
Diffstat (limited to 'lua')
| -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 | 
