diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-03-28 14:01:01 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-03-28 14:01:01 +0800 |
commit | 37bee650922156a8f2928ea9d95207ab8e973975 (patch) | |
tree | 17393e56287782d13db2a1fb8436f6e077d4fb06 /server | |
parent | b4bbfce903852d6c837f9a9a06f00406a5fc86a5 (diff) | |
download | lua-language-server-37bee650922156a8f2928ea9d95207ab8e973975.zip |
可以快速禁用诊断了
Diffstat (limited to 'server')
-rw-r--r-- | server/src/json/decode.lua | 10 | ||||
-rw-r--r-- | server/src/method/init.lua | 1 | ||||
-rw-r--r-- | server/src/method/initialize.lua | 5 | ||||
-rw-r--r-- | server/src/method/textDocument/codeAction.lua | 11 | ||||
-rw-r--r-- | server/src/method/workspace/executeCommand.lua | 55 |
5 files changed, 72 insertions, 10 deletions
diff --git a/server/src/json/decode.lua b/server/src/json/decode.lua index 6a93d127..aebd49ca 100644 --- a/server/src/json/decode.lua +++ b/server/src/json/decode.lua @@ -119,10 +119,12 @@ local Token = P return function (str, save_sort_) save_sort = save_sort_ - local table, pos = Token:match(str) - if not pos or pos <= #str then - pos = pos or 1 - error(('没匹配完[%s]\n%s'):format(pos, str:sub(pos, pos+100))) + local table, res, pos = Token:match(str) + if not table then + if not pos or pos <= #str then + pos = pos or 1 + error(('没匹配完[%s][%s]\n%s'):format(pos, res, str:sub(pos, pos+100))) + end end return table end diff --git a/server/src/method/init.lua b/server/src/method/init.lua index 2fe9f4b1..565fdb64 100644 --- a/server/src/method/init.lua +++ b/server/src/method/init.lua @@ -25,5 +25,6 @@ init 'textDocument/signatureHelp' init 'workspace/didChangeConfiguration' init 'workspace/didChangeWatchedFiles' init 'workspace/didChangeWorkspaceFolders' +init 'workspace/executeCommand' return method diff --git a/server/src/method/initialize.lua b/server/src/method/initialize.lua index 5148e24b..f63b9f7c 100644 --- a/server/src/method/initialize.lua +++ b/server/src/method/initialize.lua @@ -39,6 +39,11 @@ return function (lsp) changeNotifications = true, } }, + executeCommandProvider = { + commands = { + 'config' + }, + }, } } end diff --git a/server/src/method/textDocument/codeAction.lua b/server/src/method/textDocument/codeAction.lua index 4c4e85a3..04a07e3b 100644 --- a/server/src/method/textDocument/codeAction.lua +++ b/server/src/method/textDocument/codeAction.lua @@ -1,5 +1,4 @@ return function (lsp, params) - log.debug(table.dump(params)) local uri = params.textDocument.uri local result = {} @@ -13,17 +12,17 @@ return function (lsp, params) title = '测试', command = 'config', arguments = { - key = {'diagnostics', 'disable'}, - action = 'add', - value = data.code, + { + key = {'diagnostics', 'disable'}, + action = 'add', + value = data.code, + } } } } end end - log.debug(table.dump(result)) - if #result == 0 then return nil end diff --git a/server/src/method/workspace/executeCommand.lua b/server/src/method/workspace/executeCommand.lua new file mode 100644 index 00000000..4ee06c5b --- /dev/null +++ b/server/src/method/workspace/executeCommand.lua @@ -0,0 +1,55 @@ +local fs = require 'bee.filesystem' +local json = require 'json' +local config = require 'config' + +local command = {} + +function command.config(lsp, data) + local def = config.config + for _, k in ipairs(data.key) do + def = def[k] + if not def then + return + end + end + if data.action == 'add' then + if type(def) ~= 'table' then + return + end + end + + local vscodePath = lsp.workspace.root / '.vscode' + local settingBuf = io.load(vscodePath / 'settings.json') + if not settingBuf then + fs.create_directories(vscodePath) + end + + local setting = json.decode(settingBuf, true) or {} + local key = 'Lua.' .. table.concat(data.key, '.') + local attr = setting[key] + + if data.action == 'add' then + if attr == nil then + attr = {} + elseif type(attr) == 'string' then + attr = {attr} + elseif type(attr) == 'table' then + else + return + end + + attr[#attr+1] = data.value + setting[key] = attr + end + + io.save(vscodePath / 'settings.json', json.encode(setting) .. '\r\n') +end + +return function (lsp, params) + local name = params.command + if not command[name] then + return + end + local result = command[name](lsp, params.arguments[1]) + return result +end |