mirror of
https://github.com/folke/lazy.nvim.git
synced 2025-04-04 06:57:34 +00:00
## Description
As I described in
https://github.com/folke/lazy.nvim/pull/1512#issuecomment-2212474372,
this makes it so that local plugins will only show as needing updates if
the local branch is behind the upstream branch. This is done by checking
the output of the `git log` command, and only setting `plugin._.updates`
if the output is not empty.
This seems to solve my issue where local plugins with unpushed changes
always show as needing updates, but if there's a easier/better way of
doing it then please feel free to edit/close this. Or if you don't agree
that the current behaviour is a bug, then that's also fine - it's not a
big deal and I can easily just ignore the "updates available" notice.
I also came across a minor issue where the plugin diff view (press `d`)
compares the wrong commits for local plugins, because
[lua/lazy/view/init.lua](c771cf4928/lua/lazy/view/init.lua (L268)
)
always uses `get_target`. I fixed this by moving `get_local_target` into
`get_target` - I think this is simpler and more straightforward than the
alternative of adding a ternary everywhere `get_target` is called.
This second bugfix is a very small change, so I've just included it
here, but I'm happy to make a second PR if you'd like.
## Related Issue(s)
Related PR: #1512
97 lines
2.5 KiB
Lua
97 lines
2.5 KiB
Lua
local Config = require("lazy.core.config")
|
|
local Git = require("lazy.manage.git")
|
|
local Manage = require("lazy.manage")
|
|
local Plugin = require("lazy.core.plugin")
|
|
local State = require("lazy.state")
|
|
local Util = require("lazy.util")
|
|
|
|
local M = {}
|
|
|
|
M.running = false
|
|
M.updated = {}
|
|
M.reported = {}
|
|
|
|
function M.start()
|
|
M.fast_check()
|
|
if M.schedule() > 0 and not M.has_errors() then
|
|
Manage.log({
|
|
clear = false,
|
|
show = false,
|
|
check = true,
|
|
concurrency = Config.options.checker.concurrency,
|
|
})
|
|
end
|
|
end
|
|
|
|
function M.schedule()
|
|
State.read() -- update state
|
|
local next_check = State.checker.last_check + Config.options.checker.frequency - os.time()
|
|
next_check = math.max(next_check, 0)
|
|
vim.defer_fn(M.check, next_check * 1000)
|
|
return next_check
|
|
end
|
|
|
|
---@param opts? {report:boolean} report defaults to true
|
|
function M.fast_check(opts)
|
|
opts = opts or {}
|
|
for _, plugin in pairs(Config.plugins) do
|
|
-- don't check local plugins here, since we mark them as needing updates
|
|
-- only if local is behind upstream (if the git log task gives no output)
|
|
if plugin._.installed and not (plugin.pin or plugin._.is_local) then
|
|
plugin._.updates = nil
|
|
local info = Git.info(plugin.dir)
|
|
local ok, target = pcall(Git.get_target, plugin)
|
|
if ok and info and target and not Git.eq(info, target) then
|
|
plugin._.updates = { from = info, to = target }
|
|
end
|
|
end
|
|
end
|
|
M.report(opts.report ~= false)
|
|
end
|
|
|
|
function M.has_errors()
|
|
for _, plugin in pairs(Config.plugins) do
|
|
if Plugin.has_errors(plugin) then
|
|
return true
|
|
end
|
|
end
|
|
return false
|
|
end
|
|
|
|
function M.check()
|
|
State.checker.last_check = os.time()
|
|
State.write() -- update state
|
|
if M.has_errors() then
|
|
M.schedule()
|
|
else
|
|
Manage.check({
|
|
clear = false,
|
|
show = false,
|
|
concurrency = Config.options.checker.concurrency,
|
|
}):wait(function()
|
|
M.report()
|
|
M.schedule()
|
|
end)
|
|
end
|
|
end
|
|
|
|
---@param notify? boolean
|
|
function M.report(notify)
|
|
local lines = {}
|
|
M.updated = {}
|
|
for _, plugin in pairs(Config.plugins) do
|
|
if plugin._.updates then
|
|
table.insert(M.updated, plugin.name)
|
|
if not vim.tbl_contains(M.reported, plugin.name) then
|
|
table.insert(lines, "- **" .. plugin.name .. "**")
|
|
table.insert(M.reported, plugin.name)
|
|
end
|
|
end
|
|
end
|
|
if #lines > 0 and notify and Config.options.checker.notify and not Config.headless() then
|
|
table.insert(lines, 1, "# Plugin Updates")
|
|
Util.info(lines)
|
|
end
|
|
end
|
|
|
|
return M
|