--------------------------------------------------------------------------------
-- Helper function for "return <expr_list>" parsing.
--- Called when parsing return statements
+-- Called when parsing return statements.
+-- The specific test for initial ";" is because it's not a block terminator,
+-- so without itgg.list would choke on "return ;" statements.
+-- We don't make a modified copy of block_terminators because this list
+-- is sometimes modified at runtime, and the return parser would get out of
+-- sync if it was relying on a copy.
--------------------------------------------------------------------------------
-local return_expr_list_parser = gg.list {
- expr, separators = ",", terminators = block_terminators }
+local return_expr_list_parser = gg.multisequence{
+ { ";" , builder = function() return { } end },
+ default = gg.list {
+ expr, separators = ",", terminators = block_terminators } }
--------------------------------------------------------------------------------
-- for header, between [for] and [do] (exclusive).
local function funcdef_builder(x)
local name, method, func = x[1], x[2], x[3]
if method then
- name = { tag="Index", name, method }
+ name = { tag="Index", name, method, lineinfo = {
+ first = name.lineinfo.first,
+ last = method.lineinfo.last } }
_G.table.insert (func[1], 1, {tag="Id", "self"})
end
- return { tag="Set", {name}, {func} }
+ local r = { tag="Set", {name}, {func} }
+ r[1].lineinfo = name.lineinfo
+ r[2].lineinfo = func.lineinfo
+ return r
end
local local_stat_parser = gg.multisequence{
-- local function <name> <func_val>
{ "function", id, func_val, builder =
- function(x) return { tag="Localrec", { x[1] }, { x[2] } } end },
+ function(x)
+ local vars = { x[1], lineinfo = x[1].lineinfo }
+ local vals = { x[2], lineinfo = x[2].lineinfo }
+ return { tag="Localrec", vars, vals }
+ end },
-- local <id_list> ( = <expr_list> )?
default = gg.sequence{ id_list, gg.onkeyword{ "=", expr_list },
builder = function(x) return {tag="Local", x[1], x[2] or { } } end } }