summaryrefslogtreecommitdiff
path: root/server/src
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2019-04-05 19:30:57 +0800
committer最萌小汐 <sumneko@hotmail.com>2019-04-05 19:30:57 +0800
commit5d2aee69ef5edd7e3890997cf652cc60737a330f (patch)
tree9f3e5aaa23d7ed1db71451526befccc2248d0f82 /server/src
parent5ed7ded384aca2cff4d09401cc852f7943a1ea94 (diff)
downloadlua-language-server-5d2aee69ef5edd7e3890997cf652cc60737a330f.zip
更新Lua解析
Diffstat (limited to 'server/src')
-rw-r--r--server/src/method/textDocument/publishDiagnostics.lua5
-rw-r--r--server/src/parser/ast.lua35
2 files changed, 36 insertions, 4 deletions
diff --git a/server/src/method/textDocument/publishDiagnostics.lua b/server/src/method/textDocument/publishDiagnostics.lua
index f2e1a593..fbe65bb3 100644
--- a/server/src/method/textDocument/publishDiagnostics.lua
+++ b/server/src/method/textDocument/publishDiagnostics.lua
@@ -1,6 +1,5 @@
local core = require 'core'
local lang = require 'language'
-local config = require 'config'
local DiagnosticSeverity = {
Error = 1,
@@ -85,9 +84,9 @@ local function buildError(err, lines, uri)
}
if err.version then
if type(err.version) == 'table' then
- diagnostic.message = ('%s(%s)'):format(diagnostic.message, lang.script('DIAG_NEED_VERSION', table.concat(err.version, '/'), config.config.runtime.version))
+ diagnostic.message = ('%s(%s)'):format(diagnostic.message, lang.script('DIAG_NEED_VERSION', table.concat(err.version, '/')))
else
- diagnostic.message = ('%s(%s)'):format(diagnostic.message, lang.script('DIAG_NEED_VERSION', err.version, config.config.runtime.version))
+ diagnostic.message = ('%s(%s)'):format(diagnostic.message, lang.script('DIAG_NEED_VERSION', err.version))
end
end
if err.level == 'error' then
diff --git a/server/src/parser/ast.lua b/server/src/parser/ast.lua
index 1d4d6a23..57d88b0c 100644
--- a/server/src/parser/ast.lua
+++ b/server/src/parser/ast.lua
@@ -44,6 +44,36 @@ local RESERVED = {
['while'] = true,
}
+local VersionOp = {
+ ['&'] = {'Lua 5.3', 'Lua 5.4'},
+ ['~'] = {'Lua 5.3', 'Lua 5.4'},
+ ['|'] = {'Lua 5.3', 'Lua 5.4'},
+ ['<<'] = {'Lua 5.3', 'Lua 5.4'},
+ ['>>'] = {'Lua 5.3', 'Lua 5.4'},
+ ['//'] = {'Lua 5.3', 'Lua 5.4'},
+}
+
+local function checkOpVersion(op, start)
+ local versions = VersionOp[op]
+ if not versions then
+ return
+ end
+ for i = 1, #versions do
+ if versions[i] == State.Version then
+ return
+ end
+ end
+ pushError {
+ type = 'UNSUPPORT_SYMBOL',
+ start = start,
+ finish = start + #op - 1,
+ version = versions,
+ info = {
+ version = State.Version,
+ }
+ }
+end
+
local Exp
local function expSplit(list, start, finish, level)
@@ -71,6 +101,7 @@ local function binaryForward(list, start, finish, level)
if not e2 then
goto CONTINUE
end
+ checkOpVersion(op, list[i-1])
return {
type = 'binary',
op = op,
@@ -98,6 +129,7 @@ local function binaryBackward(list, start, finish, level)
if not e2 then
goto CONTINUE
end
+ checkOpVersion(op, list[i-1])
return {
type = 'binary',
op = op,
@@ -118,6 +150,7 @@ local function unary(list, start, finish, level)
if info[op] then
local e1 = expSplit(list, start+2, finish, level)
if e1 then
+ checkOpVersion(op, list[start])
return {
type = 'unary',
op = op,
@@ -1210,7 +1243,7 @@ local Defs = {
return
end
pushError {
- type = 'TOCLOSE',
+ type = 'UNSUPPORT_SYMBOL',
start = start,
finish = start + #'*toclose' - 1,
version = 'Lua 5.4',