From 43a29d8842d5533750c8cfc5198f5df603fa8ca5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Wed, 27 Jan 2021 19:44:29 +0800 Subject: wait for workspace ready --- script/provider/provider.lua | 11 ++++++++++- script/workspace/workspace.lua | 15 ++++++++++++++- 2 files changed, 24 insertions(+), 2 deletions(-) (limited to 'script') 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) -- cgit v1.2.3