Merge pull request #1100 from Guldoman/PR_fix_path_suggest

Remove dot slash from suggested paths in `common.path_suggest`
This commit is contained in:
Jefferson González 2022-08-17 13:59:19 -04:00 committed by GitHub
commit f07b62f852
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 14 additions and 4 deletions

View File

@ -152,20 +152,24 @@ function common.path_suggest(text, root)
root = root .. PATHSEP root = root .. PATHSEP
end end
local path, name = text:match("^(.-)([^/\\]*)$") local path, name = text:match("^(.-)([^/\\]*)$")
local clean_dotslash = false
-- ignore root if path is absolute -- ignore root if path is absolute
local is_absolute = common.is_absolute_path(text) local is_absolute = common.is_absolute_path(text)
if not is_absolute then if not is_absolute then
if path == "" then if path == "" then
path = root or "." path = root or "."
clean_dotslash = not root
else else
path = (root or "") .. path path = (root or "") .. path
end end
end end
local files = system.list_dir(path) or {} -- Only in Windows allow using both styles of PATHSEP
if path:sub(-1) ~= PATHSEP then if (PATHSEP == "\\" and not string.match(path:sub(-1), "[\\/]")) or
(PATHSEP ~= "\\" and path:sub(-1) ~= PATHSEP) then
path = path .. PATHSEP path = path .. PATHSEP
end end
local files = system.list_dir(path) or {}
local res = {} local res = {}
for _, file in ipairs(files) do for _, file in ipairs(files) do
file = path .. file file = path .. file
@ -180,6 +184,12 @@ function common.path_suggest(text, root)
if s == 1 then if s == 1 then
file = file:sub(e + 1) file = file:sub(e + 1)
end end
elseif clean_dotslash then
-- remove added dot slash
local s, e = file:find("." .. PATHSEP, nil, true)
if s == 1 then
file = file:sub(e + 1)
end
end end
if file:lower():find(text:lower(), nil, true) == 1 then if file:lower():find(text:lower(), nil, true) == 1 then
table.insert(res, file) table.insert(res, file)
@ -362,11 +372,11 @@ end
-- absolute path without . or .. elements. -- absolute path without . or .. elements.
-- This function exists because on Windows the drive letter returned -- This function exists because on Windows the drive letter returned
-- by system.absolute_path is sometimes with a lower case and sometimes -- by system.absolute_path is sometimes with a lower case and sometimes
-- with an upper case to we normalize to upper case. -- with an upper case so we normalize to upper case.
function common.normalize_volume(filename) function common.normalize_volume(filename)
if not filename then return end if not filename then return end
if PATHSEP == '\\' then if PATHSEP == '\\' then
local drive, rem = filename:match('^([a-zA-Z]:\\)(.*)') local drive, rem = filename:match('^([a-zA-Z]:\\)(.-)'..PATHSEP..'?$')
if drive then if drive then
return drive:upper() .. rem return drive:upper() .. rem
end end