diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-07-05 15:15:44 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-07-05 15:15:44 +0800 |
commit | b73c30b3bec7c56e9b46021ccf9824df3d0a529b (patch) | |
tree | 68eaedea046f53af904101f0e8ef66eac0611a4e /server/src | |
parent | d91adfe4ebd18099fde3e4389655d4532fc9b00c (diff) | |
download | lua-language-server-b73c30b3bec7c56e9b46021ccf9824df3d0a529b.zip |
符号限制
Diffstat (limited to 'server/src')
-rw-r--r-- | server/src/core/diagnostics.lua | 17 | ||||
-rw-r--r-- | server/src/method/workspace/executeCommand.lua | 17 |
2 files changed, 32 insertions, 2 deletions
diff --git a/server/src/core/diagnostics.lua b/server/src/core/diagnostics.lua index 239c8121..77898b17 100644 --- a/server/src/core/diagnostics.lua +++ b/server/src/core/diagnostics.lua @@ -256,6 +256,21 @@ function mt:searchRedundantParameters(callback) end) end +local opMap = { + ['+'] = true, + ['-'] = true, + ['*'] = true, + ['/'] = true, + ['//'] = true, + ['^'] = true, + ['<<'] = true, + ['>>'] = true, + ['&'] = true, + ['|'] = true, + ['~'] = true, + ['..'] = true, +} + function mt:searchAmbiguity1(callback) self.vm:eachSource(function (source) if source.op ~= 'or' then @@ -267,7 +282,7 @@ function mt:searchAmbiguity1(callback) local y = x % 2 + 1 local exp = source[x] local other = source[y] - if exp.op and not other.op then + if opMap[exp.op] and not opMap[other.op] then callback(source.start, source.finish, exp.start, exp.finish) end end diff --git a/server/src/method/workspace/executeCommand.lua b/server/src/method/workspace/executeCommand.lua index 9b234fc1..6ae407ae 100644 --- a/server/src/method/workspace/executeCommand.lua +++ b/server/src/method/workspace/executeCommand.lua @@ -123,6 +123,21 @@ function command.removeSpace(lsp, data) }) end +local opMap = { + ['+'] = true, + ['-'] = true, + ['*'] = true, + ['/'] = true, + ['//'] = true, + ['^'] = true, + ['<<'] = true, + ['>>'] = true, + ['&'] = true, + ['|'] = true, + ['~'] = true, + ['..'] = true, +} + function command.solve(lsp, data) local uri = data.uri local vm, lines = lsp:getVM(uri) @@ -144,7 +159,7 @@ function command.solve(lsp, data) local y = x % 2 + 1 local exp = source[x] local other = source[y] - if exp.op and not other.op then + if opMap[exp.op] and not opMap[other.op] then if x == 1 then -- (a + b) or c --> a + (b or c) return { |