blob: 533be48d2fd892d10da1df3658b395b95da38fef (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
local uv = vim.loop
local sep = (function()
---@diagnostic disable-next-line: undefined-global
if jit then
---@diagnostic disable-next-line: undefined-global
local os = string.lower(jit.os)
if os == "linux" or os == "osx" or os == "bsd" then
return "/"
else
return "\\"
end
else
return package.config:sub(1, 1)
end
end)()
local M = {}
function M.cwd()
return uv.fs_realpath "."
end
---@param path_components string[]
---@return string
function M.concat(path_components)
return table.concat(path_components, sep)
end
-- @param relpath string The relative path to get the realpath(1) to.
-- @param depth number The depth in the call stack to introspect. This effectively controls which stack frame should be used when producing the realpath.
-- The file of the elected stack frame will be used as the "starting point" for the provided relpath.
--
-- @return The realpath (absolute path). Note that this will currently produce results such as /Users/zuck/./script.js which may not be compatible with some tools.
function M.realpath(relpath, depth)
local callsite_abs_path = debug.getinfo(depth or 2, "S").source:sub(2)
local normalized_relpath = relpath:gsub("./", "")
return M.concat { vim.fn.fnamemodify(callsite_abs_path, ":h"), normalized_relpath }
end
function M.is_subdirectory(root_path, path)
return root_path == path or path:sub(1, #root_path + 1) == root_path .. sep
end
return M
|