summaryrefslogtreecommitdiff
path: root/server/src
diff options
context:
space:
mode:
Diffstat (limited to 'server/src')
-rw-r--r--server/src/parser/ast.lua8
-rw-r--r--server/src/parser/grammar.lua21
2 files changed, 20 insertions, 9 deletions
diff --git a/server/src/parser/ast.lua b/server/src/parser/ast.lua
index 8c5f7fe9..291d93c6 100644
--- a/server/src/parser/ast.lua
+++ b/server/src/parser/ast.lua
@@ -317,17 +317,21 @@ local defs = {
end,
List = function (first, second, ...)
if second then
- return {
+ local list = {
type = 'list',
+ start = first.start,
first, second, ...
}
+ local last = list[#list]
+ list.finish = last.finish
+ return list
elseif first == '' then
return nil
else
return first
end
end,
- ExpList = function (start, ...)
+ CallArgList = function (start, ...)
local args = {...}
local max = #args
local finish = args[max] - 1
diff --git a/server/src/parser/grammar.lua b/server/src/parser/grammar.lua
index 18118ac6..3bff2e31 100644
--- a/server/src/parser/grammar.lua
+++ b/server/src/parser/grammar.lua
@@ -289,13 +289,19 @@ Suffix <- DOT MustName
/ Sp ({} Table {}) -> Call
/ Sp ({} String {}) -> Call
/ Sp ({} BL DirtyExp (BR / Sp) {}) -> Index
- / Sp ({} PL ExpList DirtyPR {}) -> Call
+ / Sp ({} PL CallArgList DirtyPR {}) -> Call
DirtyExp <- Exp
/ {} -> DirtyExp
-ExpList <- Sp ({} (!%nl (COMMA {} / Exp))+ {})
- -> ExpList
+ExpList <- (COMMA Exp)+
+ -> List
+ / (Exp (COMMA Exp)*)
+ -> List
+CallArgList <- Sp ({} (COMMA {} / Exp / DirtyCallArg)+ {})
+ -> CallArgList
/ %nil
+DirtyCallArg<- Sp ({} {(!PR !PL !COMMA !Word .)+})
+ -> UnknownSymbol
NameList <- (COMMA MustName)+
-> List
/ (Name (COMMA MustName)*)
@@ -313,10 +319,10 @@ AfterArg <- DOTS
/ MustName
-Table <- Sp ({} TL TableFields DirtyTR {})
+Table <- Sp ({} TL TableFields? DirtyTR {})
-> Table
-TableFields <- (TableSep {} / TableField / DirtyField)*
-DirtyField <- Sp ({} {(!TR !COMMA !SEMICOLON !Word !BL .)+})
+TableFields <- (TableSep {} / TableField / DirtyField)+
+DirtyField <- Sp ({} {(!TR !BL !COMMA !SEMICOLON !Word .)+})
-> UnknownSymbol
TableSep <- COMMA / SEMICOLON
TableField <- NewIndex / NewField / Exp
@@ -343,6 +349,7 @@ FuncSuffix <- DOT MustName
-- 纯占位,修改了 `relabel.lua` 使重复定义不抛错
Action <- !END .
+Set <- END
]]
grammar 'Action' [[
@@ -443,7 +450,7 @@ RepeatBody <- REPEAT
Local <- (LOCAL TOCLOSE? NameList (ASSIGN ExpList)?)
-> Local
-Set <- (SimpleList ASSIGN ExpList)
+Set <- (SimpleList ASSIGN ExpList?)
-> Set
Call <- Simple