summaryrefslogtreecommitdiff
path: root/server-beta/src/proto
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2019-09-24 12:48:20 +0800
committer最萌小汐 <sumneko@hotmail.com>2019-09-24 12:48:20 +0800
commitfd94e26e163e40ca0d932b84abc056522e5a049d (patch)
tree6f7da69de659d1eec87d2b9ab172dbb1b6be267a /server-beta/src/proto
parent897ba631156367453afb43bd3223821990ae6f2e (diff)
downloadlua-language-server-fd94e26e163e40ca0d932b84abc056522e5a049d.zip
加载配置
Diffstat (limited to 'server-beta/src/proto')
-rw-r--r--server-beta/src/proto/provider.lua80
1 files changed, 77 insertions, 3 deletions
diff --git a/server-beta/src/proto/provider.lua b/server-beta/src/proto/provider.lua
index 0b9c285e..fbaba8ca 100644
--- a/server-beta/src/proto/provider.lua
+++ b/server-beta/src/proto/provider.lua
@@ -6,6 +6,53 @@ local files = require 'files'
local proto = require 'proto.proto'
local inte = require 'proto.interface'
local workspace = require 'workspace'
+local config = require 'config'
+
+local function updateConfig()
+ local configs = proto.request('workspace/configuration', {
+ items = {
+ {
+ scopeUri = workspace.uri,
+ section = 'Lua',
+ },
+ {
+ scopeUri = workspace.uri,
+ section = 'files.associations',
+ },
+ {
+ scopeUri = workspace.uri,
+ section = 'files.exclude',
+ }
+ },
+ })
+
+ local updated = configs[1]
+ local other = {
+ associations = configs[2],
+ exclude = configs[3],
+ }
+
+ local oldConfig = util.deepCopy(config.config)
+ local oldOther = util.deepCopy(config.other)
+ config:setConfig(updated, other)
+ local newConfig = config.config
+ local newOther = config.other
+ if not util.equal(oldConfig.runtime, newConfig.runtime) then
+ end
+ if not util.equal(oldConfig.diagnostics, newConfig.diagnostics) then
+ end
+ if newConfig.completion.enable then
+ else
+ end
+ if not util.equal(oldConfig.plugin, newConfig.plugin) then
+ end
+ if not util.equal(oldConfig.workspace, newConfig.workspace)
+ or not util.equal(oldConfig.plugin, newConfig.plugin)
+ or not util.equal(oldOther.associations, newOther.associations)
+ or not util.equal(oldOther.exclude, newOther.exclude)
+ then
+ end
+end
proto.on('initialize', function (params)
--log.debug(util.dump(params))
@@ -13,9 +60,6 @@ proto.on('initialize', function (params)
local name = params.workspaceFolders[1].name
local uri = params.workspaceFolders[1].uri
workspace.init(name, uri)
- task.create(function ()
- workspace.preload()
- end)
end
return {
capabilities = cap.initer,
@@ -23,6 +67,32 @@ proto.on('initialize', function (params)
end)
proto.on('initialized', function (params)
+ updateConfig()
+ proto.request('client/registerCapability', {
+ registrations = {
+ -- 监视文件变化
+ {
+ id = '0',
+ method = 'workspace/didChangeWatchedFiles',
+ registerOptions = {
+ watchers = {
+ {
+ globPattern = '**/',
+ kind = 1 | 2 | 4,
+ }
+ },
+ },
+ },
+ -- 配置变化
+ {
+ id = '1',
+ method = 'workspace/didChangeConfiguration',
+ }
+ }
+ })
+ task.create(function ()
+ workspace.preload()
+ end)
return true
end)
@@ -36,6 +106,10 @@ proto.on('shutdown', function ()
return true
end)
+proto.on('workspace/configuration', function ()
+ updateConfig()
+end)
+
proto.on('textDocument/didOpen', function (params)
local doc = params.textDocument
local uri = doc.uri