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:
commit
f07b62f852
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue