This reverts commit 517dee64c1.
This commit is contained in:
@@ -4,7 +4,11 @@ local Watcher = require("nvim-tree.watcher").Watcher
|
|||||||
|
|
||||||
local M = {}
|
local M = {}
|
||||||
|
|
||||||
M.ignore_dirs = {
|
local function is_git(path)
|
||||||
|
return vim.fn.fnamemodify(path, ":t") == ".git"
|
||||||
|
end
|
||||||
|
|
||||||
|
local IGNORED_PATHS = {
|
||||||
-- disable watchers on kernel filesystems
|
-- disable watchers on kernel filesystems
|
||||||
-- which have a lot of unwanted events
|
-- which have a lot of unwanted events
|
||||||
"/sys",
|
"/sys",
|
||||||
@@ -12,11 +16,13 @@ M.ignore_dirs = {
|
|||||||
"/dev",
|
"/dev",
|
||||||
}
|
}
|
||||||
|
|
||||||
function M.ignore_dir(path)
|
|
||||||
table.insert(M.ignore_dirs, path)
|
|
||||||
end
|
|
||||||
|
|
||||||
local function is_folder_ignored(path)
|
local function is_folder_ignored(path)
|
||||||
|
for _, folder in ipairs(IGNORED_PATHS) do
|
||||||
|
if vim.startswith(path, folder) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
for _, ignore_dir in ipairs(M.ignore_dirs) do
|
for _, ignore_dir in ipairs(M.ignore_dirs) do
|
||||||
if vim.fn.match(path, ignore_dir) ~= -1 then
|
if vim.fn.match(path, ignore_dir) ~= -1 then
|
||||||
return true
|
return true
|
||||||
@@ -38,7 +44,7 @@ function M.create_watcher(node)
|
|||||||
path = node.absolute_path
|
path = node.absolute_path
|
||||||
end
|
end
|
||||||
|
|
||||||
if is_folder_ignored(path) then
|
if is_git(path) or is_folder_ignored(path) then
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -68,7 +74,7 @@ end
|
|||||||
function M.setup(opts)
|
function M.setup(opts)
|
||||||
M.enabled = opts.filesystem_watchers.enable
|
M.enabled = opts.filesystem_watchers.enable
|
||||||
M.debounce_delay = opts.filesystem_watchers.debounce_delay
|
M.debounce_delay = opts.filesystem_watchers.debounce_delay
|
||||||
M.ignore_dirs = vim.tbl_extend("force", M.ignore_dirs, opts.filesystem_watchers.ignore_dirs)
|
M.ignore_dirs = opts.filesystem_watchers.ignore_dirs
|
||||||
M.uid = 0
|
M.uid = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ local log = require "nvim-tree.log"
|
|||||||
local utils = require "nvim-tree.utils"
|
local utils = require "nvim-tree.utils"
|
||||||
local git_utils = require "nvim-tree.git.utils"
|
local git_utils = require "nvim-tree.git.utils"
|
||||||
local Runner = require "nvim-tree.git.runner"
|
local Runner = require "nvim-tree.git.runner"
|
||||||
local Watch = require "nvim-tree.explorer.watch"
|
|
||||||
local Watcher = require("nvim-tree.watcher").Watcher
|
local Watcher = require("nvim-tree.watcher").Watcher
|
||||||
local Iterator = require "nvim-tree.iterators.node-iterator"
|
local Iterator = require "nvim-tree.iterators.node-iterator"
|
||||||
local explorer_node = require "nvim-tree.explorer.node"
|
local explorer_node = require "nvim-tree.explorer.node"
|
||||||
@@ -165,34 +164,22 @@ function M.load_project_status(cwd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
local watcher = nil
|
local watcher = nil
|
||||||
|
|
||||||
if M.config.filesystem_watchers.enable then
|
if M.config.filesystem_watchers.enable then
|
||||||
log.line("watcher", "git start")
|
log.line("watcher", "git start")
|
||||||
|
|
||||||
local git_directory = git_utils.get_git_directory(project_root)
|
local callback = function(w)
|
||||||
|
log.line("watcher", "git event scheduled '%s'", w.project_root)
|
||||||
if git_directory == nil then
|
utils.debounce("git:watcher:" .. w.project_root, M.config.filesystem_watchers.debounce_delay, function()
|
||||||
log.line("watcher", "could not found the location of .git folder")
|
if w.destroyed then
|
||||||
else
|
return
|
||||||
local callback = function(w)
|
end
|
||||||
log.line("watcher", "git event scheduled '%s'", w.project_root)
|
reload_tree_at(w.project_root)
|
||||||
utils.debounce("git:watcher:" .. w.project_root, M.config.filesystem_watchers.debounce_delay, function()
|
end)
|
||||||
if w.destroyed then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
reload_tree_at(w.project_root)
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Add GIT_DIR to the list of directory to ignore
|
|
||||||
-- local base_gitdir = utils.path_basename(git_directory)
|
|
||||||
-- Watch.ignore_dir(base_gitdir)
|
|
||||||
Watch.ignore_dir(git_directory)
|
|
||||||
|
|
||||||
watcher = Watcher:new(git_directory, WATCHED_FILES, callback, {
|
|
||||||
project_root = project_root,
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
watcher = Watcher:new(utils.path_join { project_root, ".git" }, WATCHED_FILES, callback, {
|
||||||
|
project_root = project_root,
|
||||||
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
M.projects[project_root] = {
|
M.projects[project_root] = {
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
local M = {}
|
local M = {}
|
||||||
local log = require "nvim-tree.log"
|
local log = require "nvim-tree.log"
|
||||||
local utils = require "nvim-tree.utils"
|
|
||||||
|
local has_cygpath = vim.fn.executable "cygpath" == 1
|
||||||
|
|
||||||
function M.get_toplevel(cwd)
|
function M.get_toplevel(cwd)
|
||||||
local profile = log.profile_start("git toplevel %s", cwd)
|
local profile = log.profile_start("git toplevel %s", cwd)
|
||||||
@@ -17,9 +18,16 @@ function M.get_toplevel(cwd)
|
|||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
toplevel = utils.norm_path(toplevel)
|
-- git always returns path with forward slashes
|
||||||
if toplevel == nil then
|
if vim.fn.has "win32" == 1 then
|
||||||
return nil
|
-- msys2 git support
|
||||||
|
if has_cygpath then
|
||||||
|
toplevel = vim.fn.system("cygpath -w " .. vim.fn.shellescape(toplevel))
|
||||||
|
if vim.v.shell_error ~= 0 then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
toplevel = toplevel:gsub("/", "\\")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- remove newline
|
-- remove newline
|
||||||
@@ -86,28 +94,4 @@ function M.file_status_to_dir_status(status, cwd)
|
|||||||
return r
|
return r
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.get_git_directory(cwd)
|
|
||||||
local profile = log.profile_start("git directory %s", cwd)
|
|
||||||
|
|
||||||
local cmd = { "git", "-C", cwd, "rev-parse", "--absolute-git-dir" }
|
|
||||||
log.line("git", vim.inspect(cmd))
|
|
||||||
|
|
||||||
local git_dir = vim.fn.system(cmd)
|
|
||||||
|
|
||||||
log.raw("git", git_dir)
|
|
||||||
log.profile_end(profile)
|
|
||||||
|
|
||||||
if vim.v.shell_error ~= 0 or not git_dir or #git_dir == 0 or git_dir:match "fatal" then
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
|
|
||||||
git_dir = utils.norm_path(git_dir)
|
|
||||||
if git_dir == nil then
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
|
|
||||||
-- remove newline
|
|
||||||
return git_dir:sub(0, -2)
|
|
||||||
end
|
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|||||||
@@ -5,11 +5,10 @@ local M = {
|
|||||||
debouncers = {},
|
debouncers = {},
|
||||||
}
|
}
|
||||||
|
|
||||||
local has_cygpath = vim.fn.executable "cygpath" == 1
|
|
||||||
|
|
||||||
M.is_unix = vim.fn.has "unix" == 1
|
M.is_unix = vim.fn.has "unix" == 1
|
||||||
M.is_macos = vim.fn.has "mac" == 1 or vim.fn.has "macunix" == 1
|
M.is_macos = vim.fn.has "mac" == 1 or vim.fn.has "macunix" == 1
|
||||||
M.is_wsl = vim.fn.has "wsl" == 1
|
M.is_wsl = vim.fn.has "wsl" == 1
|
||||||
|
-- false for WSL
|
||||||
M.is_windows = vim.fn.has "win32" == 1 or vim.fn.has "win32unix" == 1
|
M.is_windows = vim.fn.has "win32" == 1 or vim.fn.has "win32unix" == 1
|
||||||
|
|
||||||
function M.str_find(haystack, needle)
|
function M.str_find(haystack, needle)
|
||||||
@@ -39,26 +38,6 @@ function M.path_split(path)
|
|||||||
return path:gmatch("[^" .. path_separator .. "]+" .. path_separator .. "?")
|
return path:gmatch("[^" .. path_separator .. "]+" .. path_separator .. "?")
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Normalise a path:
|
|
||||||
--- windows: replace slashes with backslashes
|
|
||||||
--- cygwin: resolve path first via cygpath
|
|
||||||
--- @param path string
|
|
||||||
--- @return string|nil nil on cygpath failure
|
|
||||||
function M.norm_path(path)
|
|
||||||
if M.is_windows then
|
|
||||||
-- msys2 git support
|
|
||||||
if has_cygpath then
|
|
||||||
path = vim.fn.system("cygpath -w " .. vim.fn.shellescape(path))
|
|
||||||
if vim.v.shell_error ~= 0 then
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
path = path:gsub("/", "\\")
|
|
||||||
end
|
|
||||||
|
|
||||||
return path
|
|
||||||
end
|
|
||||||
|
|
||||||
---Get the basename of the given path.
|
---Get the basename of the given path.
|
||||||
---@param path string
|
---@param path string
|
||||||
---@return string
|
---@return string
|
||||||
|
|||||||
Reference in New Issue
Block a user