aboutsummaryrefslogtreecommitdiff
path: root/nomsu.moon
diff options
context:
space:
mode:
authorBruce Hill <bitbucket@bruce-hill.com>2017-10-10 00:52:07 -0700
committerBruce Hill <bitbucket@bruce-hill.com>2017-10-10 00:52:07 -0700
commitd0b0cfcf397fea5d71e986d5e1a2e3b7aab5fcfe (patch)
tree45f97fc9b2ad36931e9a72ff14da0c759d9f6f89 /nomsu.moon
parenta858775a6831e5d880d9c0f88470f12a7e9b91f9 (diff)
Added an option to pass in vars to run()
Diffstat (limited to 'nomsu.moon')
-rwxr-xr-xnomsu.moon9
1 files changed, 4 insertions, 5 deletions
diff --git a/nomsu.moon b/nomsu.moon
index bf5c979..1695906 100755
--- a/nomsu.moon
+++ b/nomsu.moon
@@ -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);"