summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-01-27 19:44:29 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-01-27 19:44:29 +0800
commit43a29d8842d5533750c8cfc5198f5df603fa8ca5 (patch)
tree858d8a0740f55a89e3d88e13177aa654427e820b /script
parent954826cb2dcbdb25fde09d6fd38760a69d06475a (diff)
downloadlua-language-server-43a29d8842d5533750c8cfc5198f5df603fa8ca5.zip
wait for workspace ready
Diffstat (limited to 'script')
-rw-r--r--script/provider/provider.lua11
-rw-r--r--script/workspace/workspace.lua15
2 files changed, 24 insertions, 2 deletions
diff --git a/script/provider/provider.lua b/script/provider/provider.lua
index 47fe457f..4df42610 100644
--- a/script/provider/provider.lua
+++ b/script/provider/provider.lua
@@ -120,7 +120,7 @@ proto.on('initialized', function (params)
}
}
})
- await.call(workspace.awaitPreload)
+ workspace.awaitReload()
return true
end)
@@ -216,6 +216,7 @@ end)
proto.on('textDocument/hover', function (params)
await.close 'hover'
await.setID 'hover'
+ workspace.awaitReady()
local core = require 'core.hover'
local doc = params.textDocument
local uri = doc.uri
@@ -244,6 +245,7 @@ proto.on('textDocument/hover', function (params)
end)
proto.on('textDocument/definition', function (params)
+ workspace.awaitReady()
local core = require 'core.definition'
local uri = params.textDocument.uri
if not files.exists(uri) then
@@ -271,6 +273,7 @@ proto.on('textDocument/definition', function (params)
end)
proto.on('textDocument/references', function (params)
+ workspace.awaitReady()
local core = require 'core.reference'
local uri = params.textDocument.uri
if not files.exists(uri) then
@@ -313,6 +316,7 @@ proto.on('textDocument/documentHighlight', function (params)
end)
proto.on('textDocument/rename', function (params)
+ workspace.awaitReady()
local core = require 'core.rename'
local uri = params.textDocument.uri
if not files.exists(uri) then
@@ -355,6 +359,7 @@ proto.on('textDocument/prepareRename', function (params)
end)
proto.on('textDocument/completion', function (params)
+ workspace.awaitReady()
--log.info(util.dump(params))
local core = require 'core.completion'
--log.debug('textDocument/completion')
@@ -478,6 +483,7 @@ proto.on('textDocument/signatureHelp', function (params)
if not config.config.signatureHelp.enable then
return nil
end
+ workspace.awaitReady()
local uri = params.textDocument.uri
if not files.exists(uri) then
return nil
@@ -601,6 +607,7 @@ proto.on('workspace/executeCommand', function (params)
end)
proto.on('workspace/symbol', function (params)
+ workspace.awaitReady()
local core = require 'core.workspace-symbol'
await.close('workspace/symbol')
@@ -632,6 +639,7 @@ end)
proto.on('textDocument/semanticTokens/full', function (params)
+ workspace.awaitReady()
local core = require 'core.semantic-tokens'
local uri = params.textDocument.uri
log.debug('semanticTokens/full', uri)
@@ -647,6 +655,7 @@ proto.on('textDocument/semanticTokens/full', function (params)
end)
proto.on('textDocument/semanticTokens/range', function (params)
+ workspace.awaitReady()
local core = require 'core.semantic-tokens'
local uri = params.textDocument.uri
log.debug('semanticTokens/range', uri)
diff --git a/script/workspace/workspace.lua b/script/workspace/workspace.lua
index 94b1d9e5..76dbd195 100644
--- a/script/workspace/workspace.lua
+++ b/script/workspace/workspace.lua
@@ -402,14 +402,27 @@ function m.getCache(name)
end
function m.reload()
+ await.call(m.awaitReload)
+end
+
+function m.awaitReload()
local rpath = require 'workspace.require-path'
local plugin = require 'plugin'
+ m.ready = false
files.flushAllLibrary()
files.removeAllClosed()
files.flushCache()
rpath.flush()
plugin.init()
- await.call(m.awaitPreload)
+ m.awaitPreload()
+ m.ready = true
+end
+
+---等待工作目录加载完成
+function m.awaitReady()
+ while not m.ready do
+ await.sleep(0.1)
+ end
end
files.watch(function (ev, uri)