lazy.nvim/lua/lazy/core/config.lua

97 lines
2.8 KiB
Lua
Raw Normal View History

local Util = require("lazy.core.util")
2022-11-21 05:33:47 +08:00
local M = {}
---@class LazyConfig
M.defaults = {
plugins = "config.plugins",
defaults = {
lazy = false, -- should plugins be loaded at startup?
version = nil,
-- version = "*", -- enable this to try installing the latest stable versions of plugins
},
2022-12-01 06:14:16 +08:00
lockfile = vim.fn.stdpath("config") .. "/lazy-lock.json", -- lockfile generated after running update.
install_missing = true, -- install missing plugins on startup. This doesn't increase startup time.
concurrency = nil, -- set to a number to limit the maximum amount of concurrent tasks
2022-12-01 06:14:16 +08:00
git = {
-- defaults for `Lazy log`
-- log = { "-10" }, -- last 10 commits
log = { "--since=1 days ago" }, -- commits from the last 3 days
timeout = 120, -- processes taking over 2 minutes will be killed
2022-12-01 06:14:16 +08:00
},
package = {
path = vim.fn.stdpath("data") .. "/site",
name = "lazy", -- plugins will be installed under package.path/pack/{name}/opt
reset = true, -- packpath will be reset to only include lazy. This makes packadd a lot faster
},
2022-12-01 06:14:16 +08:00
-- Any plugin spec that contains one of the patterns will use your
-- local repo in the projects folder instead of fetchig it from github
-- Mostly useful for plugin developers.
2022-12-01 06:08:00 +08:00
dev = {
path = vim.fn.expand("~/projects"), -- the path where you store your projects
---@type string[]
2022-12-01 06:08:00 +08:00
patterns = {}, -- For example {"folke"}
2022-11-21 05:34:55 +08:00
},
2022-12-01 06:13:08 +08:00
ui = {
-- The border to use for the UI window. Accepts same border values as |nvim_open_win()|.
border = "none",
2022-11-24 02:06:04 +08:00
icons = {
start = "",
2022-11-29 19:02:25 +08:00
plugin = "",
2022-11-24 02:06:04 +08:00
source = "",
config = "",
event = "",
keys = "",
cmd = "",
2022-12-01 06:13:08 +08:00
ft = "",
2022-11-29 07:15:13 +08:00
task = "",
2022-11-24 02:06:04 +08:00
},
2022-12-01 06:13:35 +08:00
throttle = 20, -- how frequently should the ui process render events
2022-11-29 22:25:09 +08:00
},
2022-11-21 05:33:47 +08:00
}
M.ns = vim.api.nvim_create_namespace("lazy")
M.paths = {
---@type string
opt = nil,
---@type string
main = nil,
---@type string
plugins = nil,
}
2022-11-21 05:33:47 +08:00
---@type table<string, LazyPlugin>
M.plugins = {}
---@type LazyPlugin[]
M.to_clean = {}
2022-11-21 05:33:47 +08:00
---@type LazyConfig
M.options = {}
---@param opts? LazyConfig
function M.setup(opts)
2022-11-21 05:34:55 +08:00
M.options = vim.tbl_deep_extend("force", M.defaults, opts or {})
M.paths.plugins = vim.fn.stdpath("config") .. "/lua/" .. M.options.plugins:gsub("%.", "/")
M.paths.main = M.paths.plugins .. (vim.loop.fs_stat(M.paths.plugins .. ".lua") and ".lua" or "/init.lua")
M.paths.opt = M.options.package.path .. "/pack/" .. M.options.package.name .. "/opt"
if M.options.package.reset then
vim.go.packpath = M.options.package.path
end
2022-11-21 05:33:47 +08:00
2022-11-21 05:34:55 +08:00
vim.api.nvim_create_autocmd("User", {
pattern = "VeryLazy",
once = true,
callback = function()
require("lazy.core.module").autosave()
2022-11-21 06:25:56 +08:00
require("lazy.view").setup()
2022-11-21 05:34:55 +08:00
end,
})
2022-11-21 05:33:47 +08:00
2022-11-21 05:34:55 +08:00
Util.very_lazy()
2022-11-21 05:33:47 +08:00
end
return M