diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2018-11-09 14:36:15 -0800 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2018-11-09 14:37:22 -0800 |
| commit | 7d2b7199d87930096b7fd799709fe0105d51eccb (patch) | |
| tree | f33de61cb44357497758bb08ec6993753d8baa43 /nomsu_compiler.lua | |
| parent | ba96cdfa07cea15ada62f8f89b2563de1286a0de (diff) | |
Lots of cleanups, including expanded use of (... compiles to "text
literal") shorthand, deprecating Lua value, and more use of Lua "..."
with text interpolations.
Diffstat (limited to 'nomsu_compiler.lua')
| -rw-r--r-- | nomsu_compiler.lua | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/nomsu_compiler.lua b/nomsu_compiler.lua index 0538776..d293d99 100644 --- a/nomsu_compiler.lua +++ b/nomsu_compiler.lua @@ -50,13 +50,18 @@ compile_error = function(tree, err_msg, hint) title = "Compile error", error = err_msg, hint = hint, - source = tree:get_source_code(), + source = tree:get_source_file(), start = tree.source.start, stop = tree.source.stop, filename = tree.source.filename }) return error(err_str, 0) end +local tree_to_nomsu, tree_to_inline_nomsu +do + local _obj_0 = require("nomsu_decompiler") + tree_to_nomsu, tree_to_inline_nomsu = _obj_0.tree_to_nomsu, _obj_0.tree_to_inline_nomsu +end local math_expression = re.compile([[ (([*/^+-] / [0-9]+) " ")* [*/^+-] !. ]]) local compile_math_expression compile_math_expression = function(compile, tree, ...) @@ -125,9 +130,6 @@ local compile = setmetatable({ end return operate_on_text(code) end, - ["Lua value"] = function(compile, tree, code) - return compile.action["Lua"](compile, tree, code) - end, ["lua >"] = function(compile, tree, code) if code.type ~= "Text" then return tree @@ -159,7 +161,17 @@ local compile = setmetatable({ return LuaCode(tree.source, "TESTS") end, ["test"] = function(compile, tree, body) - return LuaCode(tree.source, "TESTS[" .. tostring(tostring(tree.source):as_lua()) .. "] = ", body:as_lua()) + if not (body.type == 'Block') then + compile_error(tree, "This should be a Block") + end + local test_nomsu = body:get_source_code():match(":[ ]*(.*)") + do + local indent = test_nomsu:match("\n([ ]*)") + if indent then + test_nomsu = test_nomsu:gsub("\n" .. indent, "\n") + end + end + return LuaCode(tree.source, "TESTS[" .. tostring(tostring(tree.source):as_lua()) .. "] = ", test_nomsu:as_lua()) end, ["is jit"] = function(compile, tree, code) return LuaCode(tree.source, "jit") |
