diff options
author | sumneko <sumneko@hotmail.com> | 2022-01-23 04:18:52 +0800 |
---|---|---|
committer | sumneko <sumneko@hotmail.com> | 2022-01-23 04:18:52 +0800 |
commit | a13a30f193b54f32138306463dd8e13d208fb45c (patch) | |
tree | 80ccf3511287bbeb5a4db4e5ea79b2867b4dbba2 | |
parent | 1c8095439f8d738390b3cc19fa3f82853dd89f95 (diff) | |
download | lua-language-server-a13a30f193b54f32138306463dd8e13d208fb45c.zip |
fix
-rw-r--r-- | script/workspace/require-path.lua | 3 | ||||
-rw-r--r-- | script/workspace/scope.lua | 2 | ||||
-rw-r--r-- | test/tclient/init.lua | 1 | ||||
-rw-r--r-- | test/tclient/lclient.lua | 8 | ||||
-rw-r--r-- | test/tclient/tests/folders-with-single-file.lua | 66 | ||||
-rw-r--r-- | test/tclient/tests/single-mode.lua | 7 |
6 files changed, 85 insertions, 2 deletions
diff --git a/script/workspace/require-path.lua b/script/workspace/require-path.lua index d0d96164..3454cbf1 100644 --- a/script/workspace/require-path.lua +++ b/script/workspace/require-path.lua @@ -164,6 +164,9 @@ function m.flush(suri) end end +for _, scp in ipairs(scope.folders) do + m.flush(scp.uri) +end m.flush(nil) files.watch(function (ev, uri) diff --git a/script/workspace/scope.lua b/script/workspace/scope.lua index 4e04d720..711fc1a1 100644 --- a/script/workspace/scope.lua +++ b/script/workspace/scope.lua @@ -123,7 +123,7 @@ end ---@return scope function m.getFolder(uri) for _, scope in ipairs(m.folders) do - if not uri or scope:isChildUri(uri) then + if scope:isChildUri(uri) then return scope end end diff --git a/test/tclient/init.lua b/test/tclient/init.lua index 872c34a4..b9054a00 100644 --- a/test/tclient/init.lua +++ b/test/tclient/init.lua @@ -1,3 +1,4 @@ require 'tclient.tests.single-mode' require 'tclient.tests.library-ignore-limit' require 'tclient.tests.multi-workspace' +require 'tclient.tests.folders-with-single-file' diff --git a/test/tclient/lclient.lua b/test/tclient/lclient.lua index 166add42..8da8d138 100644 --- a/test/tclient/lclient.lua +++ b/test/tclient/lclient.lua @@ -4,6 +4,7 @@ local proto = require 'proto' local await = require 'await' local timer = require 'timer' local pub = require 'pub' +local json = require 'json' require 'provider' @@ -152,7 +153,12 @@ end ---@async function mt:awaitRequest(method, params) return await.wait(function (waker) - self:request(method, params, waker) + self:request(method, params, function (result) + if result == json.null then + result = nil + end + waker(result) + end) end) end diff --git a/test/tclient/tests/folders-with-single-file.lua b/test/tclient/tests/folders-with-single-file.lua new file mode 100644 index 00000000..326dd623 --- /dev/null +++ b/test/tclient/tests/folders-with-single-file.lua @@ -0,0 +1,66 @@ +local lclient = require 'tclient.lclient' +local fs = require 'bee.filesystem' +local util = require 'utility' +local furi = require 'file-uri' +local ws = require 'workspace' +local files = require 'files' +local scope = require 'workspace.scope' + +---@async +lclient():start(function (client) + client:registerFakers() + + client:initialize { + rootUri = 'abc', + } + + client:notify('textDocument/didOpen', { + textDocument = { + uri = furi.encode('abc/1.lua'), + languageId = 'lua', + version = 0, + text = [[ +local x +print(x) +]] + } + }) + + ws.awaitReady('abc') + + local locations = client:awaitRequest('textDocument/definition', { + textDocument = { uri = furi.encode('abc/1.lua') }, + position = { line = 1, character = 7 }, + }) + + assert(util.equal(locations, { + { + uri = furi.encode('abc/1.lua'), + range = { + start = { line = 0, character = 6 }, + ['end'] = { line = 0, character = 7 }, + } + } + })) + + client:notify('textDocument/didOpen', { + textDocument = { + uri = 'test://single-file.lua', + languageId = 'lua', + version = 0, + text = [[ +local x +print(x) +]] + } + }) + + ws.awaitReady(nil) + + local locations = client:awaitRequest('textDocument/definition', { + textDocument = { uri = 'test://single-file.lua' }, + position = { line = 1, character = 0 }, + }) + + assert(#locations > 0) +end) diff --git a/test/tclient/tests/single-mode.lua b/test/tclient/tests/single-mode.lua index 0a7f85ff..10f3e2da 100644 --- a/test/tclient/tests/single-mode.lua +++ b/test/tclient/tests/single-mode.lua @@ -35,4 +35,11 @@ print(x) } } })) + + local locations = client:awaitRequest('textDocument/definition', { + textDocument = { uri = 'test://single-file.lua' }, + position = { line = 1, character = 0 }, + }) + + assert(#locations > 0) end) |