Fixed up some edge cases with parsing and comments.
This commit is contained in:
parent
d535dc5794
commit
c9ff0ff04b
@ -148,13 +148,15 @@ action [%var as lua identifier, %var as lua id]
|
||||
elseif \%var.type == 'Var' then return string.as_lua_id(\%var[1])
|
||||
elseif \%var.type == 'Action' then return "A"..string.as_lua_id(\%var.stub)
|
||||
end
|
||||
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
compile [% is syntax tree] to
|
||||
Lua value "AST.is_syntax_tree(\(% as lua expr))"
|
||||
|
||||
compile [% is %kind syntax tree] to
|
||||
Lua value "AST.is_syntax_tree(\(% as lua expr), \(%kind as lua expr))"
|
||||
|
||||
|
||||
compile [%tree with %t -> %replacement] to
|
||||
Lua value ".."
|
||||
\(%tree as lua expr):map(function(\(%t as lua expr))
|
||||
|
@ -4,7 +4,7 @@ file (File):
|
||||
comment? blank_lines?
|
||||
(chunk (nl_nodent chunk_delimeter nl_nodent chunk)*)?
|
||||
blank_lines?
|
||||
(!! .+ -> "Parse error" !!)?
|
||||
%ws* (!! .+ -> "Parse error" !!)?
|
||||
|
||||
nodent: =curr_indent !(" ")
|
||||
indent: =curr_indent " "
|
||||
@ -45,7 +45,7 @@ indented_expression:
|
||||
indented_text / indented_nomsu / indented_list / indented_dict / ({|
|
||||
("(..)")? nl_indent
|
||||
(block / action / expression) (nl_nodent comment)*
|
||||
(!! [^%nl]+ -> "Unexpected character while parsing indented expression" !!)?
|
||||
(eol / (!! [^%nl]+ -> "Unexpected character while parsing indented expression" !!))
|
||||
|} -> unpack)
|
||||
expression:
|
||||
inline_expression
|
||||
@ -121,7 +121,7 @@ inline_list (List):
|
||||
(inline_list_item (%ws* ',' %ws* inline_list_item)* (%ws* ',')?)? %ws*
|
||||
("]" / (","? (
|
||||
(!! eol -> "Line ended before finding a closing ]-bracket" !!)
|
||||
/(!! [^%nl]+ -> "Unexpected character while parsing List" !!)?
|
||||
/(!! [^%nl]+ -> "Unexpected character while parsing List" !!)
|
||||
)))
|
||||
indented_list (List):
|
||||
"[..]" eol nl_indent
|
||||
|
@ -725,11 +725,13 @@ do
|
||||
local _accum_0 = { }
|
||||
local _len_0 = 1
|
||||
for p, c in pairs(tree.comments or { }) do
|
||||
_accum_0[_len_0] = {
|
||||
comment = c,
|
||||
pos = p
|
||||
}
|
||||
_len_0 = _len_0 + 1
|
||||
if tree.source.start <= p and p <= tree.source.stop then
|
||||
_accum_0[_len_0] = {
|
||||
comment = c,
|
||||
pos = p
|
||||
}
|
||||
_len_0 = _len_0 + 1
|
||||
end
|
||||
end
|
||||
comments = _accum_0
|
||||
end
|
||||
|
@ -484,7 +484,7 @@ with NomsuCompiler
|
||||
.tree_to_nomsu = (tree, options)=>
|
||||
options or= {}
|
||||
unless options.pop_comments
|
||||
comments = [{comment:c, pos:p} for p,c in pairs(tree.comments or {})]
|
||||
comments = [{comment:c, pos:p} for p,c in pairs(tree.comments or {}) when tree.source.start <= p and p <= tree.source.stop]
|
||||
table.sort comments, (a,b)-> a.pos < b.pos
|
||||
comment_i = 1
|
||||
options.pop_comments = (pos)->
|
||||
|
Loading…
Reference in New Issue
Block a user