summaryrefslogtreecommitdiff
path: root/server-beta/src/parser
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2019-11-16 03:02:01 +0800
committer最萌小汐 <sumneko@hotmail.com>2019-11-16 03:02:01 +0800
commit81fb889cbf994be47f162dbfda446f80e51c6fab (patch)
tree3bf11ab96b180000e3228ea16188d1d888475df8 /server-beta/src/parser
parentf2c235601da54117b803e084d94bbf88ba53b891 (diff)
downloadlua-language-server-81fb889cbf994be47f162dbfda446f80e51c6fab.zip
支持高亮
Diffstat (limited to 'server-beta/src/parser')
-rw-r--r--server-beta/src/parser/ast.lua127
-rw-r--r--server-beta/src/parser/grammar.lua59
-rw-r--r--server-beta/src/parser/guide.lua2
3 files changed, 124 insertions, 64 deletions
diff --git a/server-beta/src/parser/ast.lua b/server-beta/src/parser/ast.lua
index ded42891..ff5a6ae1 100644
--- a/server-beta/src/parser/ast.lua
+++ b/server-beta/src/parser/ast.lua
@@ -662,6 +662,9 @@ local Defs = {
return e
end,
Binary = function (first, op, second, ...)
+ if not first then
+ return second
+ end
if not op then
return first
end
@@ -836,20 +839,28 @@ local Defs = {
finish = start,
}
end,
- Function = function (start, args, actions, finish)
+ Function = function (functionStart, functionFinish, args, actions, endStart, endFinish)
actions.type = 'function'
- actions.start = start
- actions.finish = finish - 1
+ actions.start = functionStart
+ actions.finish = endFinish - 1
actions.args = args
- checkMissEnd(start)
+ actions.keyword= {
+ functionStart, functionFinish - 1,
+ endStart, endFinish - 1,
+ }
+ checkMissEnd(functionStart)
return actions
end,
- NamedFunction = function (start, name, args, actions, finish)
+ NamedFunction = function (functionStart, functionFinish, name, args, actions, endStart, endFinish)
actions.type = 'function'
- actions.start = start
- actions.finish = finish - 1
+ actions.start = functionStart
+ actions.finish = endFinish - 1
actions.args = args
- checkMissEnd(start)
+ actions.keyword= {
+ functionStart, functionFinish - 1,
+ endStart, endFinish - 1,
+ }
+ checkMissEnd(functionStart)
if not name then
return
end
@@ -864,13 +875,18 @@ local Defs = {
name.value = actions
end
name.range = actions.finish
+ name.vstart = functionStart
return name
end,
- LocalFunction = function (start, name, args, actions, finish)
+ LocalFunction = function (start, functionStart, functionFinish, name, args, actions, endStart, endFinish)
actions.type = 'function'
actions.start = start
- actions.finish = finish - 1
+ actions.finish = endFinish - 1
actions.args = args
+ actions.keyword= {
+ functionStart, functionFinish - 1,
+ endStart, endFinish - 1,
+ }
checkMissEnd(start)
if not name then
@@ -888,6 +904,7 @@ local Defs = {
local loc = createLocal(name, name.start, actions)
loc.localfunction = true
+ loc.vstart = functionStart
return loc
end,
@@ -1126,10 +1143,14 @@ local Defs = {
end
return tableUnpack(keys)
end,
- Do = function (start, actions, finish)
+ Do = function (start, actions, endA, endB)
actions.type = 'do'
actions.start = start
- actions.finish = finish - 1
+ actions.finish = endB - 1
+ actions.keyword= {
+ start, start + #'do' - 1,
+ endA , endB - 1,
+ }
checkMissEnd(start)
return actions
end,
@@ -1184,30 +1205,41 @@ local Defs = {
name.type = 'goto'
return name
end,
- IfBlock = function (start, exp, actions, finish)
+ IfBlock = function (ifStart, ifFinish, exp, thenStart, thenFinish, actions, finish)
actions.type = 'ifblock'
- actions.start = start
+ actions.start = ifStart
actions.finish = finish - 1
actions.filter = exp
+ actions.keyword= {
+ ifStart, ifFinish - 1,
+ thenStart, thenFinish - 1,
+ }
return actions
end,
- ElseIfBlock = function (start, exp, actions, finish)
+ ElseIfBlock = function (elseifStart, elseifFinish, exp, thenStart, thenFinish, actions, finish)
actions.type = 'elseifblock'
- actions.start = start
+ actions.start = elseifStart
actions.finish = finish - 1
actions.filter = exp
+ actions.keyword= {
+ elseifStart, elseifFinish - 1,
+ thenStart, thenFinish - 1,
+ }
return actions
end,
- ElseBlock = function (start, actions, finish)
+ ElseBlock = function (elseStart, elseFinish, actions, finish)
actions.type = 'elseblock'
- actions.start = start
+ actions.start = elseStart
actions.finish = finish - 1
+ actions.keyword= {
+ elseStart, elseFinish - 1,
+ }
return actions
end,
- If = function (start, blocks, finish)
+ If = function (start, blocks, endStart, endFinish)
blocks.type = 'if'
blocks.start = start
- blocks.finish = finish - 1
+ blocks.finish = endFinish - 1
local hasElse
for i = 1, #blocks do
local block = blocks[i]
@@ -1235,23 +1267,34 @@ local Defs = {
checkMissEnd(start)
return blocks
end,
- Loop = function (start, arg, steps, blockStart, block, finish)
+ Loop = function (forA, forB, arg, steps, doA, doB, blockStart, block, endA, endB)
local loc = createLocal(arg, blockStart, steps[1])
block.type = 'loop'
- block.start = start
- block.finish = finish - 1
+ block.start = forA
+ block.finish = endB - 1
block.loc = loc
block.max = steps[2]
block.step = steps[3]
- checkMissEnd(start)
+ block.keyword= {
+ forA, forB - 1,
+ doA , doB - 1,
+ endA, endB - 1,
+ }
+ checkMissEnd(forA)
return block
end,
- In = function (start, keys, exp, blockStart, block, finish)
+ In = function (forA, forB, keys, inA, inB, exp, doA, doB, blockStart, block, endA, endB)
local func = tableRemove(exp, 1)
block.type = 'in'
- block.start = start
- block.finish = finish - 1
+ block.start = forA
+ block.finish = endB - 1
block.keys = keys
+ block.keyword= {
+ forA, forB - 1,
+ inA , inB - 1,
+ doA , doB - 1,
+ endA, endB - 1,
+ }
local values
if func then
@@ -1270,22 +1313,31 @@ local Defs = {
createLocal(loc, blockStart)
end
end
- checkMissEnd(start)
+ checkMissEnd(forA)
return block
end,
- While = function (start, filter, block, finish)
+ While = function (whileA, whileB, filter, doA, doB, block, endA, endB)
block.type = 'while'
- block.start = start
- block.finish = finish - 1
+ block.start = whileA
+ block.finish = endB - 1
block.filter = filter
- checkMissEnd(start)
+ block.keyword= {
+ whileA, whileB - 1,
+ doA , doB - 1,
+ endA , endB - 1,
+ }
+ checkMissEnd(whileA)
return block
end,
- Repeat = function (start, block, filter, finish)
+ Repeat = function (repeatA, repeatB, block, untilA, untilB, filter, finish)
block.type = 'repeat'
- block.start = start
+ block.start = repeatA
block.finish = finish
block.filter = filter
+ block.keyword= {
+ repeatA, repeatB - 1,
+ untilA , untilB - 1,
+ }
return block
end,
Lua = function (start, actions, finish)
@@ -1491,6 +1543,7 @@ local Defs = {
symbol = 'end',
}
}
+ return pos, pos
end,
MissDo = function (pos)
PushError {
@@ -1501,6 +1554,7 @@ local Defs = {
symbol = 'do',
}
}
+ return pos, pos
end,
MissComma = function (pos)
PushError {
@@ -1521,6 +1575,7 @@ local Defs = {
symbol = 'in',
}
}
+ return pos, pos
end,
MissUntil = function (pos)
PushError {
@@ -1531,6 +1586,7 @@ local Defs = {
symbol = 'until',
}
}
+ return pos, pos
end,
MissThen = function (pos)
PushError {
@@ -1541,6 +1597,7 @@ local Defs = {
symbol = 'then',
}
}
+ return pos, pos
end,
MissName = function (pos)
PushError {
@@ -1639,6 +1696,7 @@ local Defs = {
}
}
}
+ return start, finish
end,
ErrDo = function (start, finish)
PushError {
@@ -1654,6 +1712,7 @@ local Defs = {
}
}
}
+ return start, finish
end,
}
diff --git a/server-beta/src/parser/grammar.lua b/server-beta/src/parser/grammar.lua
index 944f34ea..b64f6277 100644
--- a/server-beta/src/parser/grammar.lua
+++ b/server-beta/src/parser/grammar.lua
@@ -112,28 +112,30 @@ Rest <- (!%nl .)*
AND <- Sp {'and'} Cut
BREAK <- Sp 'break' Cut
-DO <- Sp 'do' Cut
- / Sp ({} 'then' Cut {}) -> ErrDo
-ELSE <- Sp 'else' Cut
-ELSEIF <- Sp 'elseif' Cut
-END <- Sp 'end' Cut
FALSE <- Sp 'false' Cut
-FOR <- Sp 'for' Cut
-FUNCTION <- Sp 'function' Cut
GOTO <- Sp 'goto' Cut
-IF <- Sp 'if' Cut
-IN <- Sp 'in' Cut
LOCAL <- Sp 'local' Cut
NIL <- Sp 'nil' Cut
NOT <- Sp 'not' Cut
OR <- Sp {'or'} Cut
-REPEAT <- Sp 'repeat' Cut
RETURN <- Sp 'return' Cut
-THEN <- Sp 'then' Cut
- / Sp ({} 'do' Cut {}) -> ErrThen
TRUE <- Sp 'true' Cut
-UNTIL <- Sp 'until' Cut
-WHILE <- Sp 'while' Cut
+
+DO <- Sp {} 'do' {} Cut
+ / Sp({} 'then' {} Cut) -> ErrDo
+IF <- Sp {} 'if' {} Cut
+ELSE <- Sp {} 'else' {} Cut
+ELSEIF <- Sp {} 'elseif' {} Cut
+END <- Sp {} 'end' {} Cut
+FOR <- Sp {} 'for' {} Cut
+FUNCTION <- Sp {} 'function' {} Cut
+IN <- Sp {} 'in' {} Cut
+REPEAT <- Sp {} 'repeat' {} Cut
+THEN <- Sp {} 'then' {} Cut
+ / Sp({} 'do' {} Cut) -> ErrThen
+UNTIL <- Sp {} 'until' {} Cut
+WHILE <- Sp {} 'while' {} Cut
+
Esc <- '\' -> ''
EChar
@@ -365,7 +367,7 @@ NewIndex <- Sp ({} Index NeedAssign DirtyExp {})
NewField <- Sp ({} MustName ASSIGN DirtyExp {})
-> NewField
-Function <- Sp ({} FunctionBody {})
+Function <- FunctionBody
-> Function
FuncArgs <- Sp ({} PL {| FuncArg+ |} DirtyPR {})
-> FuncArgs
@@ -415,8 +417,7 @@ SimpleList <- {| Simple (Sp ',' Simple)* |}
Do <- Sp ({}
'do' Cut
{| (!END Action)* |}
- NeedEnd
- {})
+ NeedEnd)
-> Do
Break <- Sp ({} BREAK {})
@@ -435,14 +436,14 @@ Label <- Sp ({} LABEL MustName DirtyLabel {})
GoTo <- Sp ({} GOTO MustName {})
-> GoTo
-If <- Sp ({} {| IfHead IfBody* |} NeedEnd {})
+If <- Sp ({} {| IfHead IfBody* |} NeedEnd)
-> If
-IfHead <- Sp ({} IfPart {}) -> IfBlock
- / Sp ({} ElseIfPart {}) -> ElseIfBlock
- / Sp ({} ElsePart {}) -> ElseBlock
-IfBody <- Sp ({} ElseIfPart {}) -> ElseIfBlock
- / Sp ({} ElsePart {}) -> ElseBlock
+IfHead <- Sp (IfPart {}) -> IfBlock
+ / Sp (ElseIfPart {}) -> ElseIfBlock
+ / Sp (ElsePart {}) -> ElseBlock
+IfBody <- Sp (ElseIfPart {}) -> ElseIfBlock
+ / Sp (ElsePart {}) -> ElseBlock
IfPart <- IF DirtyExp NeedThen
{| (!ELSEIF !ELSE !END Action)* |}
ElseIfPart <- ELSEIF DirtyExp NeedThen
@@ -452,7 +453,7 @@ ElsePart <- ELSE
For <- Loop / In
-Loop <- Sp ({} LoopBody {})
+Loop <- LoopBody
-> Loop
LoopBody <- FOR LoopArgs NeedDo
{} {| (!END Action)* |}
@@ -461,7 +462,7 @@ LoopArgs <- MustName AssignOrEQ
({} {| (COMMA / !DO !END Exp)* |} {})
-> PackLoopArgs
-In <- Sp ({} InBody {})
+In <- InBody
-> In
InBody <- FOR InNameList NeedIn InExpList NeedDo
{} {| (!END Action)* |}
@@ -471,13 +472,13 @@ InNameList <- ({} {| (COMMA / !IN !DO !END Name)* |} {})
InExpList <- ({} {| (COMMA / !DO !DO !END Exp)* |} {})
-> PackInExpList
-While <- Sp ({} WhileBody {})
+While <- WhileBody
-> While
WhileBody <- WHILE DirtyExp NeedDo
{| (!END Action)* |}
NeedEnd
-Repeat <- Sp ({} RepeatBody {})
+Repeat <- (RepeatBody {})
-> Repeat
RepeatBody <- REPEAT
{| (!UNTIL Action)* |}
@@ -499,11 +500,11 @@ Call <- Simple
-> SimpleCall
LocalFunction
- <- Sp ({} LOCAL FunctionNamedBody {})
+ <- Sp ({} LOCAL FunctionNamedBody)
-> LocalFunction
NamedFunction
- <- Sp ({} FunctionNamedBody {})
+ <- FunctionNamedBody
-> NamedFunction
FunctionNamedBody
<- FUNCTION FuncName FuncArgs
diff --git a/server-beta/src/parser/guide.lua b/server-beta/src/parser/guide.lua
index a5b8202e..4750fcaf 100644
--- a/server-beta/src/parser/guide.lua
+++ b/server-beta/src/parser/guide.lua
@@ -268,7 +268,7 @@ end
---
--- 主要针对赋值等语句时,key包含value
function m.isInRange(source, offset)
- return source.start <= offset and (source.range or source.finish) >= offset - 1
+ return (source.vstart or source.start) <= offset and (source.range or source.finish) >= offset - 1
end
--- 添加child