diff options
| author | Bruce Hill <bitbucket@bruce-hill.com> | 2017-10-10 00:52:07 -0700 |
|---|---|---|
| committer | Bruce Hill <bitbucket@bruce-hill.com> | 2017-10-10 00:52:07 -0700 |
| commit | d0b0cfcf397fea5d71e986d5e1a2e3b7aab5fcfe (patch) | |
| tree | 45f97fc9b2ad36931e9a72ff14da0c759d9f6f89 /nomsu.moon | |
| parent | a858775a6831e5d880d9c0f88470f12a7e9b91f9 (diff) | |
Added an option to pass in vars to run()
Diffstat (limited to 'nomsu.moon')
| -rwxr-xr-x | nomsu.moon | 9 |
1 files changed, 4 insertions, 5 deletions
@@ -274,7 +274,7 @@ class NomsuCompiler @print_tree tree, " " return tree - run: (src, filename, max_operations=nil)=> + run: (src, filename, vars={}, max_operations=nil)=> if max_operations timeout = -> debug.sethook! @@ -285,7 +285,6 @@ class NomsuCompiler assert tree.type == "File", "Attempt to run non-file: #{tree.type}" buffer = {} - vars = {} return_value = nil for statement in *tree.value if @debug @@ -320,15 +319,15 @@ class NomsuCompiler @error(ret) insert buffer, "#{statements or ''}\n#{expr and "ret = #{expr}" or ''}" + if max_operations + debug.sethook! lua_code = ([[ return (function(nomsu, vars) local ret; %s return ret; end);]])\format(concat(buffer, "\n")) - if max_operations - debug.sethook! - return return_value, lua_code + return return_value, lua_code, vars tree_to_value: (tree, vars)=> code = "return (function(nomsu, vars)\nreturn #{@tree_to_lua(tree)};\nend);" |
