mirror of
https://github.com/neovim/neovim.git
synced 2025-10-02 16:08:36 +00:00
Merge #6789 from ZyX-I/lua-path
lua: Add paths from &runtimepath to package.path and package.cpath
This commit is contained in:
@@ -327,11 +327,11 @@ describe('api', function()
|
||||
{'nvim_get_mode', {}},
|
||||
{'nvim_eval', {'1'}},
|
||||
}
|
||||
eq({{{mode='n', blocking=false},
|
||||
13,
|
||||
{mode='n', blocking=false}, -- TODO: should be blocked=true
|
||||
1},
|
||||
NIL}, meths.call_atomic(req))
|
||||
eq({ { {mode='n', blocking=false},
|
||||
13,
|
||||
{mode='n', blocking=false}, -- TODO: should be blocked=true
|
||||
1 },
|
||||
NIL}, meths.call_atomic(req))
|
||||
eq({mode='r', blocking=true}, nvim("get_mode"))
|
||||
end)
|
||||
-- TODO: bug #6166
|
||||
@@ -588,6 +588,36 @@ describe('api', function()
|
||||
end)
|
||||
end)
|
||||
|
||||
describe('list_runtime_paths', function()
|
||||
it('returns nothing with empty &runtimepath', function()
|
||||
meths.set_option('runtimepath', '')
|
||||
eq({}, meths.list_runtime_paths())
|
||||
end)
|
||||
it('returns single runtimepath', function()
|
||||
meths.set_option('runtimepath', 'a')
|
||||
eq({'a'}, meths.list_runtime_paths())
|
||||
end)
|
||||
it('returns two runtimepaths', function()
|
||||
meths.set_option('runtimepath', 'a,b')
|
||||
eq({'a', 'b'}, meths.list_runtime_paths())
|
||||
end)
|
||||
it('returns empty strings when appropriate', function()
|
||||
meths.set_option('runtimepath', 'a,,b')
|
||||
eq({'a', '', 'b'}, meths.list_runtime_paths())
|
||||
meths.set_option('runtimepath', ',a,b')
|
||||
eq({'', 'a', 'b'}, meths.list_runtime_paths())
|
||||
meths.set_option('runtimepath', 'a,b,')
|
||||
eq({'a', 'b', ''}, meths.list_runtime_paths())
|
||||
end)
|
||||
it('truncates too long paths', function()
|
||||
local long_path = ('/a'):rep(8192)
|
||||
meths.set_option('runtimepath', long_path)
|
||||
local paths_list = meths.list_runtime_paths()
|
||||
neq({long_path}, paths_list)
|
||||
eq({long_path:sub(1, #(paths_list[1]))}, paths_list)
|
||||
end)
|
||||
end)
|
||||
|
||||
it('can throw exceptions', function()
|
||||
local status, err = pcall(nvim, 'get_option', 'invalid-option')
|
||||
eq(false, status)
|
||||
|
@@ -581,6 +581,24 @@ local function missing_provider(provider)
|
||||
end
|
||||
end
|
||||
|
||||
local function alter_slashes(obj)
|
||||
if not iswin() then
|
||||
return obj
|
||||
end
|
||||
if type(obj) == 'string' then
|
||||
local ret = obj:gsub('/', '\\')
|
||||
return ret
|
||||
elseif type(obj) == 'table' then
|
||||
local ret = {}
|
||||
for k, v in pairs(obj) do
|
||||
ret[k] = alter_slashes(v)
|
||||
end
|
||||
return ret
|
||||
else
|
||||
assert(false, 'Could only alter slashes for tables of strings and strings')
|
||||
end
|
||||
end
|
||||
|
||||
local module = {
|
||||
prepend_argv = prepend_argv,
|
||||
clear = clear,
|
||||
@@ -649,6 +667,7 @@ local module = {
|
||||
NIL = mpack.NIL,
|
||||
get_pathsep = get_pathsep,
|
||||
missing_provider = missing_provider,
|
||||
alter_slashes = alter_slashes,
|
||||
}
|
||||
|
||||
return function(after_each)
|
||||
|
@@ -3,14 +3,17 @@ local helpers = require('test.functional.helpers')(after_each)
|
||||
local Screen = require('test.functional.ui.screen')
|
||||
|
||||
local eq = helpers.eq
|
||||
local neq = helpers.neq
|
||||
local NIL = helpers.NIL
|
||||
local feed = helpers.feed
|
||||
local clear = helpers.clear
|
||||
local funcs = helpers.funcs
|
||||
local meths = helpers.meths
|
||||
local iswin = helpers.iswin
|
||||
local command = helpers.command
|
||||
local write_file = helpers.write_file
|
||||
local redir_exec = helpers.redir_exec
|
||||
local alter_slashes = helpers.alter_slashes
|
||||
|
||||
local screen
|
||||
|
||||
@@ -173,3 +176,119 @@ describe('debug.debug', function()
|
||||
]])
|
||||
end)
|
||||
end)
|
||||
|
||||
describe('package.path/package.cpath', function()
|
||||
local sl = alter_slashes
|
||||
|
||||
local function get_new_paths(sufs, runtimepaths)
|
||||
runtimepaths = runtimepaths or meths.list_runtime_paths()
|
||||
local new_paths = {}
|
||||
local sep = package.config:sub(1, 1)
|
||||
for _, v in ipairs(runtimepaths) do
|
||||
for _, suf in ipairs(sufs) do
|
||||
new_paths[#new_paths + 1] = v .. sep .. 'lua' .. suf
|
||||
end
|
||||
end
|
||||
return new_paths
|
||||
end
|
||||
local function execute_lua(cmd, ...)
|
||||
return meths.execute_lua(cmd, {...})
|
||||
end
|
||||
local function eval_lua(expr, ...)
|
||||
return meths.execute_lua('return ' .. expr, {...})
|
||||
end
|
||||
local function set_path(which, value)
|
||||
return execute_lua('package[select(1, ...)] = select(2, ...)', which, value)
|
||||
end
|
||||
|
||||
it('contains directories from &runtimepath on first invocation', function()
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
|
||||
local new_cpaths = get_new_paths(iswin() and {'\\?.dll'} or {'/?.so'})
|
||||
local new_cpaths_str = table.concat(new_cpaths, ';')
|
||||
eq(new_cpaths_str, eval_lua('package.cpath'):sub(1, #new_cpaths_str))
|
||||
end)
|
||||
it('puts directories from &runtimepath always at the start', function()
|
||||
meths.set_option('runtimepath', 'a,b')
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {'a', 'b'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
|
||||
set_path('path', sl'foo/?.lua;foo/?/init.lua;' .. new_paths_str)
|
||||
|
||||
neq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
|
||||
command('set runtimepath+=c')
|
||||
new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {'a', 'b', 'c'})
|
||||
new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
end)
|
||||
it('understands uncommon suffixes', function()
|
||||
set_path('cpath', './?/foo/bar/baz/x.nlua')
|
||||
meths.set_option('runtimepath', 'a')
|
||||
local new_paths = get_new_paths({'/?/foo/bar/baz/x.nlua'}, {'a'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.cpath'):sub(1, #new_paths_str))
|
||||
|
||||
set_path('cpath', './yyy?zzz/x')
|
||||
meths.set_option('runtimepath', 'b')
|
||||
new_paths = get_new_paths({'/yyy?zzz/x'}, {'b'})
|
||||
new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.cpath'):sub(1, #new_paths_str))
|
||||
|
||||
set_path('cpath', './yyy?zzz/123?ghi/x')
|
||||
meths.set_option('runtimepath', 'b')
|
||||
new_paths = get_new_paths({'/yyy?zzz/123?ghi/x'}, {'b'})
|
||||
new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.cpath'):sub(1, #new_paths_str))
|
||||
end)
|
||||
it('preserves empty items', function()
|
||||
local many_empty_path = ';;;;;;'
|
||||
local many_empty_cpath = ';;;;;;./?.luaso'
|
||||
set_path('path', many_empty_path)
|
||||
set_path('cpath', many_empty_cpath)
|
||||
meths.set_option('runtimepath', 'a')
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {'a'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str .. ';' .. many_empty_path, eval_lua('package.path'))
|
||||
local new_cpaths = get_new_paths({'/?.luaso'}, {'a'})
|
||||
local new_cpaths_str = table.concat(new_cpaths, ';')
|
||||
eq(new_cpaths_str .. ';' .. many_empty_cpath, eval_lua('package.cpath'))
|
||||
end)
|
||||
it('preserves empty value', function()
|
||||
set_path('path', '')
|
||||
meths.set_option('runtimepath', 'a')
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {'a'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str .. ';', eval_lua('package.path'))
|
||||
end)
|
||||
it('purges out all additions if runtimepath is set to empty', function()
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
local path = eval_lua('package.path')
|
||||
eq(new_paths_str, path:sub(1, #new_paths_str))
|
||||
|
||||
local new_cpaths = get_new_paths(iswin() and {'\\?.dll'} or {'/?.so'})
|
||||
local new_cpaths_str = table.concat(new_cpaths, ';')
|
||||
local cpath = eval_lua('package.cpath')
|
||||
eq(new_cpaths_str, cpath:sub(1, #new_cpaths_str))
|
||||
|
||||
meths.set_option('runtimepath', '')
|
||||
eq(path:sub(#new_paths_str + 2, -1), eval_lua('package.path'))
|
||||
eq(cpath:sub(#new_cpaths_str + 2, -1), eval_lua('package.cpath'))
|
||||
end)
|
||||
it('works with paths with escaped commas', function()
|
||||
meths.set_option('runtimepath', '\\,')
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {','})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
end)
|
||||
it('ignores paths with semicolons', function()
|
||||
meths.set_option('runtimepath', 'foo;bar,\\,')
|
||||
local new_paths = get_new_paths(sl{'/?.lua', '/?/init.lua'}, {','})
|
||||
local new_paths_str = table.concat(new_paths, ';')
|
||||
eq(new_paths_str, eval_lua('package.path'):sub(1, #new_paths_str))
|
||||
end)
|
||||
end)
|
||||
|
Reference in New Issue
Block a user