Better text interpolation/handling of "\". Also added syntax support for
(statement; statement)
This commit is contained in:
parent
6fecb5d395
commit
b54829de36
@ -13,7 +13,7 @@ immediately
|
|||||||
end
|
end
|
||||||
stubs = repr(stubs);
|
stubs = repr(stubs);
|
||||||
if #stubs > 80 then
|
if #stubs > 80 then
|
||||||
lua:append("\\n ",stubs,",\\n ");
|
lua:append("\n ",stubs,",\n ");
|
||||||
else
|
else
|
||||||
lua:append(stubs,", ");
|
lua:append(stubs,", ");
|
||||||
end
|
end
|
||||||
@ -30,7 +30,7 @@ immediately
|
|||||||
body_lua:convert_to_statements("return ");
|
body_lua:convert_to_statements("return ");
|
||||||
body_lua:remove_free_vars(unpack(args));
|
body_lua:remove_free_vars(unpack(args));
|
||||||
body_lua:declare_locals();
|
body_lua:declare_locals();
|
||||||
lua:append(")\\n ", body_lua, "\\nend);");
|
lua:append(")\n ", body_lua, "\nend);");
|
||||||
return lua;
|
return lua;
|
||||||
end);
|
end);
|
||||||
|
|
||||||
@ -45,7 +45,7 @@ immediately
|
|||||||
end
|
end
|
||||||
stubs = repr(stubs);
|
stubs = repr(stubs);
|
||||||
if #stubs > 80 then
|
if #stubs > 80 then
|
||||||
lua:append("\\n ",stubs,",\\n ");
|
lua:append("\n ",stubs,",\n ");
|
||||||
else
|
else
|
||||||
lua:append(stubs,", ");
|
lua:append(stubs,", ");
|
||||||
end
|
end
|
||||||
@ -62,7 +62,7 @@ immediately
|
|||||||
body_lua:convert_to_statements("return ");
|
body_lua:convert_to_statements("return ");
|
||||||
body_lua:remove_free_vars(unpack(args));
|
body_lua:remove_free_vars(unpack(args));
|
||||||
body_lua:declare_locals();
|
body_lua:declare_locals();
|
||||||
lua:append(")\\n ", body_lua, "\\nend);")
|
lua:append(")\n ", body_lua, "\nend);")
|
||||||
return lua;
|
return lua;
|
||||||
|
|
||||||
# Macro to make nomsu macros
|
# Macro to make nomsu macros
|
||||||
@ -76,7 +76,7 @@ immediately
|
|||||||
end
|
end
|
||||||
stubs = repr(stubs);
|
stubs = repr(stubs);
|
||||||
if #stubs > 80 then
|
if #stubs > 80 then
|
||||||
lua:append("\\n ",stubs,",\\n ");
|
lua:append("\n ",stubs,",\n ");
|
||||||
else
|
else
|
||||||
lua:append(stubs,", ");
|
lua:append(stubs,", ");
|
||||||
end
|
end
|
||||||
|
@ -123,7 +123,7 @@ immediately
|
|||||||
vars[i] = tostring(target_lua);
|
vars[i] = tostring(target_lua);
|
||||||
end
|
end
|
||||||
\%lua:remove_free_vars(vars);
|
\%lua:remove_free_vars(vars);
|
||||||
\%lua:prepend("local ", lhs, " = ", rhs, ";\\n");
|
\%lua:prepend("local ", lhs, " = ", rhs, ";\n");
|
||||||
return
|
return
|
||||||
Lua ".."
|
Lua ".."
|
||||||
do
|
do
|
||||||
|
@ -165,9 +165,9 @@ do
|
|||||||
local text_loc = lpeg.userdata.source_code.source:sub(pos, pos)
|
local text_loc = lpeg.userdata.source_code.source:sub(pos, pos)
|
||||||
line_no = text_loc:get_line_number()
|
line_no = text_loc:get_line_number()
|
||||||
src = FILE_CACHE[text_loc.filename]
|
src = FILE_CACHE[text_loc.filename]
|
||||||
local prev_line = src:sub(LINE_STARTS[src][line_no - 1] or 1, LINE_STARTS[src][line_no] - 1)
|
local prev_line = src:sub(LINE_STARTS[src][line_no - 1] or 1, LINE_STARTS[src][line_no] - 2)
|
||||||
local err_line = src:sub(LINE_STARTS[src][line_no], (LINE_STARTS[src][line_no + 1] or 0) - 1)
|
local err_line = src:sub(LINE_STARTS[src][line_no], (LINE_STARTS[src][line_no + 1] or 0) - 2)
|
||||||
local next_line = src:sub(LINE_STARTS[src][line_no + 1] or -1, (LINE_STARTS[src][line_no + 2] or 0) - 1)
|
local next_line = src:sub(LINE_STARTS[src][line_no + 1] or -1, (LINE_STARTS[src][line_no + 2] or 0) - 2)
|
||||||
local pointer = ("-"):rep(pos - LINE_STARTS[src][line_no]) .. "^"
|
local pointer = ("-"):rep(pos - LINE_STARTS[src][line_no]) .. "^"
|
||||||
err_msg = (err_msg or "Parse error") .. " in " .. tostring(lpeg.userdata.source_code.source.filename) .. " on line " .. tostring(line_no) .. ":\n"
|
err_msg = (err_msg or "Parse error") .. " in " .. tostring(lpeg.userdata.source_code.source.filename) .. " on line " .. tostring(line_no) .. ":\n"
|
||||||
err_msg = err_msg .. "\n" .. tostring(prev_line) .. "\n" .. tostring(err_line) .. "\n" .. tostring(pointer) .. "\n" .. tostring(next_line) .. "\n"
|
err_msg = err_msg .. "\n" .. tostring(prev_line) .. "\n" .. tostring(err_line) .. "\n" .. tostring(pointer) .. "\n" .. tostring(next_line) .. "\n"
|
||||||
|
@ -35,7 +35,6 @@ debug_getinfo = debug.getinfo
|
|||||||
-- Do a pass on all actions to enforce parameters-are-nouns heuristic
|
-- Do a pass on all actions to enforce parameters-are-nouns heuristic
|
||||||
-- Maybe do some sort of lazy definitions of actions that defer until they're used in code
|
-- Maybe do some sort of lazy definitions of actions that defer until they're used in code
|
||||||
-- Add a ((%x foo %y) where {x:"asdf", y:"fdsa"}) compile-time action for substitution
|
-- Add a ((%x foo %y) where {x:"asdf", y:"fdsa"}) compile-time action for substitution
|
||||||
-- Allow plain text backslash like: "\n" in indented text without requiring "\\n"
|
|
||||||
-- Maybe support some kind of regex action definitions like "foo %first (and %next)*"?
|
-- Maybe support some kind of regex action definitions like "foo %first (and %next)*"?
|
||||||
-- Re-implement nomsu-to-lua comment translation?
|
-- Re-implement nomsu-to-lua comment translation?
|
||||||
|
|
||||||
@ -155,9 +154,9 @@ NOMSU_DEFS = with {}
|
|||||||
text_loc = lpeg.userdata.source_code.source\sub(pos,pos)
|
text_loc = lpeg.userdata.source_code.source\sub(pos,pos)
|
||||||
line_no = text_loc\get_line_number!
|
line_no = text_loc\get_line_number!
|
||||||
src = FILE_CACHE[text_loc.filename]
|
src = FILE_CACHE[text_loc.filename]
|
||||||
prev_line = src\sub(LINE_STARTS[src][line_no-1] or 1, LINE_STARTS[src][line_no]-1)
|
prev_line = src\sub(LINE_STARTS[src][line_no-1] or 1, LINE_STARTS[src][line_no]-2)
|
||||||
err_line = src\sub(LINE_STARTS[src][line_no], (LINE_STARTS[src][line_no+1] or 0)-1)
|
err_line = src\sub(LINE_STARTS[src][line_no], (LINE_STARTS[src][line_no+1] or 0)-2)
|
||||||
next_line = src\sub(LINE_STARTS[src][line_no+1] or -1, (LINE_STARTS[src][line_no+2] or 0)-1)
|
next_line = src\sub(LINE_STARTS[src][line_no+1] or -1, (LINE_STARTS[src][line_no+2] or 0)-2)
|
||||||
pointer = ("-")\rep(pos-LINE_STARTS[src][line_no]) .. "^"
|
pointer = ("-")\rep(pos-LINE_STARTS[src][line_no]) .. "^"
|
||||||
err_msg = (err_msg or "Parse error").." in #{lpeg.userdata.source_code.source.filename} on line #{line_no}:\n"
|
err_msg = (err_msg or "Parse error").." in #{lpeg.userdata.source_code.source.filename} on line #{line_no}:\n"
|
||||||
err_msg ..="\n#{prev_line}\n#{err_line}\n#{pointer}\n#{next_line}\n"
|
err_msg ..="\n#{prev_line}\n#{err_line}\n#{pointer}\n#{next_line}\n"
|
||||||
|
23
nomsu.peg
23
nomsu.peg
@ -11,20 +11,20 @@ statement: action / expression
|
|||||||
inline_statement: inline_action / inline_expression
|
inline_statement: inline_action / inline_expression
|
||||||
|
|
||||||
inline_block (Block):
|
inline_block (Block):
|
||||||
{| inline_statement (";" inline_statement)+ |}
|
{| inline_statement (%ws* ";" %ws* inline_statement)+ |} -> Tuple
|
||||||
block (Block):
|
block (Block):
|
||||||
{| statement (nodent statement)+ |} -> Tuple
|
{| statement (nodent statement)+ |} -> Tuple
|
||||||
|
|
||||||
inline_nomsu (Nomsu): "\" noindex_inline_expression
|
inline_nomsu (Nomsu): "\" noindex_inline_expression
|
||||||
indented_nomsu (Nomsu):
|
indented_nomsu (Nomsu):
|
||||||
"\" (noindex_inline_expression / (":" %ws* (inline_action / inline_expression) eol) / indented_expression)
|
"\" (noindex_inline_expression / (":" %ws* (inline_block / inline_action / inline_expression) eol) / indented_expression)
|
||||||
|
|
||||||
index_chain (IndexChain):
|
index_chain (IndexChain):
|
||||||
{| noindex_inline_expression ("." ((({} ({|{%operator / (!number plain_word)}|} -> Tuple) {}) -> Text) / noindex_inline_expression))+ |} -> Tuple
|
{| noindex_inline_expression ("." ((({} ({|{%operator / (!number plain_word)}|} -> Tuple) {}) -> Text) / noindex_inline_expression))+ |} -> Tuple
|
||||||
|
|
||||||
noindex_inline_expression:
|
noindex_inline_expression:
|
||||||
number / variable / inline_text / inline_list / inline_dict / inline_nomsu
|
number / variable / inline_text / inline_list / inline_dict / inline_nomsu
|
||||||
/ ("(" %ws* (inline_action / inline_expression) %ws* ")")
|
/ ("(" %ws* (inline_block / inline_action / inline_expression) %ws* ")")
|
||||||
|
|
||||||
inline_expression:
|
inline_expression:
|
||||||
index_chain / noindex_inline_expression
|
index_chain / noindex_inline_expression
|
||||||
@ -36,12 +36,12 @@ indented_expression:
|
|||||||
/ block (dedent / (("" -> "Error while parsing indented expression") => error)))
|
/ block (dedent / (("" -> "Error while parsing indented expression") => error)))
|
||||||
)
|
)
|
||||||
expression:
|
expression:
|
||||||
inline_expression / (":" %ws* (inline_action / inline_expression) eol) / indented_expression
|
inline_expression / (":" %ws* (inline_block / inline_action / inline_expression) eol) / indented_expression
|
||||||
|
|
||||||
-- Function calls need at least one word in them
|
-- Function calls need at least one word in them
|
||||||
inline_action (Action):
|
inline_action (Action):
|
||||||
{| (inline_expression %ws*)* word (%ws* (inline_expression / word))*
|
{| (inline_expression %ws*)* word (%ws* (inline_expression / word))*
|
||||||
(%ws* ":" %ws* (inline_action / inline_expression))?|} -> Tuple
|
(%ws* ":" %ws* (inline_block / inline_action / inline_expression))?|} -> Tuple
|
||||||
action (Action):
|
action (Action):
|
||||||
{| (expression (dotdot / %ws*))* word ((dotdot / %ws*) (expression / word))* |} -> Tuple
|
{| (expression (dotdot / %ws*))* word ((dotdot / %ws*) (expression / word))* |} -> Tuple
|
||||||
|
|
||||||
@ -58,20 +58,17 @@ indented_text (Text):
|
|||||||
'".."' eol %nl ({|
|
'".."' eol %nl ({|
|
||||||
{~ (%nl*) (%indent -> "") ~}
|
{~ (%nl*) (%indent -> "") ~}
|
||||||
({~
|
({~
|
||||||
(("\\" -> "\") / (("\" eol %nl+ %nodent "..") -> "")
|
(("\\" -> "\") / (("\" nodent "..") -> "")/ (%nl+ {~ %nodent -> "" ~}) / [^%nl\] / (!text_interpolation "\"))+
|
||||||
/ (%nl+ {~ %nodent -> "" ~}) / [^%nl\])+
|
|
||||||
~} / text_interpolation)*
|
~} / text_interpolation)*
|
||||||
|} -> Tuple) (((!.) &%dedent) / (&(%nl %dedent)) / (("" -> "Error while parsing Text") => error))
|
|} -> Tuple) (((!.) &%dedent) / (&(%nl %dedent)) / (("" -> "Error while parsing Text") => error))
|
||||||
inline_text_interpolation:
|
inline_text_interpolation:
|
||||||
"\" (
|
"\" (
|
||||||
variable / inline_list / inline_dict / inline_text
|
variable / inline_list / inline_dict / inline_text
|
||||||
/ ("(" %ws* (inline_action / inline_expression) %ws* ")")
|
/ ("(" %ws* (inline_block / inline_action / inline_expression) %ws* ")")
|
||||||
)
|
)
|
||||||
text_interpolation:
|
text_interpolation:
|
||||||
inline_text_interpolation /
|
inline_text_interpolation /
|
||||||
("\"
|
("\" indented_expression nodent "..")
|
||||||
(block_comment / line_comment / indented_expression)?
|
|
||||||
nodent "..")
|
|
||||||
|
|
||||||
number (Number): (("-"? (([0-9]+ "." [0-9]+) / ("." [0-9]+) / ([0-9]+)))-> tonumber)
|
number (Number): (("-"? (([0-9]+ "." [0-9]+) / ("." [0-9]+) / ([0-9]+)))-> tonumber)
|
||||||
|
|
||||||
@ -90,7 +87,7 @@ indented_list (List):
|
|||||||
list_line:
|
list_line:
|
||||||
((action / expression) !comma)
|
((action / expression) !comma)
|
||||||
/ (inline_list_item (comma list_line?)?)
|
/ (inline_list_item (comma list_line?)?)
|
||||||
inline_list_item: inline_action / inline_expression
|
inline_list_item: inline_block / inline_action / inline_expression
|
||||||
|
|
||||||
inline_dict (Dict):
|
inline_dict (Dict):
|
||||||
!('{..}')
|
!('{..}')
|
||||||
@ -104,7 +101,7 @@ dict_line:
|
|||||||
((dict_key %ws* ":" %ws* (action / expression)) -> DictEntry !comma)
|
((dict_key %ws* ":" %ws* (action / expression)) -> DictEntry !comma)
|
||||||
/ (inline_dict_item (comma dict_line?)?)
|
/ (inline_dict_item (comma dict_line?)?)
|
||||||
inline_dict_item:
|
inline_dict_item:
|
||||||
(dict_key %ws* ":" %ws* (inline_action / inline_expression)) -> DictEntry
|
(dict_key %ws* ":" %ws* (inline_block / inline_action / inline_expression)) -> DictEntry
|
||||||
dict_key:
|
dict_key:
|
||||||
(({} ({|{%operator / (!number plain_word)}|} -> Tuple) {}) -> Text) / inline_expression
|
(({} ({|{%operator / (!number plain_word)}|} -> Tuple) {}) -> Text) / inline_expression
|
||||||
|
|
||||||
|
@ -22,3 +22,34 @@ immediately
|
|||||||
"\(%)世界"
|
"\(%)世界"
|
||||||
|
|
||||||
assume ((%こんにちは と言う) = "こんにちは世界") or barf "Unicode doesn't work"
|
assume ((%こんにちは と言う) = "こんにちは世界") or barf "Unicode doesn't work"
|
||||||
|
|
||||||
|
%s <- ".."
|
||||||
|
one two\nthree\
|
||||||
|
..four
|
||||||
|
assume (%s = "one two\\nthreefour")
|
||||||
|
%s <- ".."
|
||||||
|
list:\[..]
|
||||||
|
1,2,3
|
||||||
|
..
|
||||||
|
assume (%s = "list:{1, 2, 3}")
|
||||||
|
|
||||||
|
assume
|
||||||
|
".."
|
||||||
|
foo = \
|
||||||
|
1 + 2
|
||||||
|
..!
|
||||||
|
..= "foo = 3!"
|
||||||
|
|
||||||
|
assume
|
||||||
|
".."
|
||||||
|
one\"\n"two
|
||||||
|
..= "one\ntwo"
|
||||||
|
|
||||||
|
assume
|
||||||
|
".."
|
||||||
|
no\ # Comment
|
||||||
|
#comment
|
||||||
|
#..
|
||||||
|
block comment
|
||||||
|
..gap
|
||||||
|
..= "nogap"
|
||||||
|
Loading…
Reference in New Issue
Block a user