Fixed some bugs.

This commit is contained in:
Bruce Hill 2018-06-12 20:15:52 -07:00
parent 63a19db0dc
commit 968b5da150
3 changed files with 13 additions and 11 deletions

View File

@ -5,10 +5,10 @@
# Compile-time action to make compile-time actions:
immediately
lua> ".."
_ENV['ACTION'..string.as_lua_id("compile % to %")] = function(tree, \%actions, \%lua)
_ENV['ACTION'..string.as_lua_id("compile % to %")] = compile_time(function(tree, \%actions, \%lua)
local lua = Lua(tree.source)
local canonical = \%actions[1]
lua:append("ACTION", string.as_lua_id(canonical.stub), ' = function(tree')
lua:append("ACTION", string.as_lua_id(canonical.stub), ' = compile_time(function(tree')
local args = {}
for i,tok in ipairs(canonical) do
if tok.type == "Var" then args[#args+1] = tok end
@ -21,8 +21,7 @@ immediately
local body_lua = nomsu:tree_to_lua(\%lua):as_statements("return ")
body_lua:remove_free_vars(args)
body_lua:declare_locals()
lua:append(")\n ", body_lua, "\nend")
lua:append("\nCOMPILE_TIME[ACTION", string.as_lua_id(canonical.stub), "] = true")
lua:append(")\n ", body_lua, "\nend)")
for i=2,#\%actions do
local action = \%actions[i]
@ -35,7 +34,6 @@ immediately
end
end
lua:append("\n", "ARG_ORDERS[", repr(action.stub), "] = ", repr(arg_positions))
lua:append("\nCOMPILE_TIME[ACTION", string.as_lua_id(action.stub), "] = true")
end
lua:append("\nALIASES[ACTION", string.as_lua_id(canonical.stub), "] = {")
for i,action in ipairs(\%actions) do
@ -44,8 +42,7 @@ immediately
end
lua:append("}")
return lua
end
COMPILE_TIME[_ENV['ACTION'..string.as_lua_id("compile % to %")]] = true
end)
# Compile-time action to make actions
immediately
@ -95,7 +92,7 @@ immediately
lua> ".."
local lua = Lua(tree.source)
local canonical = \%shorthand[1]
lua:append("ACTION", string.as_lua_id(canonical.stub), ' = function(tree')
lua:append("ACTION", string.as_lua_id(canonical.stub), ' = compile_time(function(tree')
local args = {}
for i,tok in ipairs(canonical) do
if tok.type == "Var" then args[#args+1] = tok end
@ -129,8 +126,7 @@ immediately
return t.type.."("..table.concat(bits, ", ")..")"
end
end
lua:append(")\n local tree = ", make_tree(\%longhand), "\n return nomsu:tree_to_lua(tree)\nend")
lua:append("\nCOMPILE_TIME[ACTION", string.as_lua_id(canonical.stub), "] = true")
lua:append(")\n local tree = ", make_tree(\%longhand), "\n return nomsu:tree_to_lua(tree)\nend)")
for i=2,#\%shorthand do
local action = \%shorthand[i]
@ -143,7 +139,6 @@ immediately
end
end
lua:append("\n", "ARG_ORDERS[", repr(action.stub), "] = ", repr(arg_positions))
lua:append("\nCOMPILE_TIME[ACTION", string.as_lua_id(action.stub), "] = true")
end
lua:append("\nALIASES[ACTION", string.as_lua_id(canonical.stub), "] = {")
for i,action in ipairs(\%shorthand) do

View File

@ -1288,6 +1288,10 @@ do
self.environment.ALIASES = setmetatable({ }, {
__mode = "k"
})
self.environment.compile_time = function(fn)
self.environment.COMPILE_TIME[fn] = true
return fn
end
self.environment.COMPILE_TIME = { }
self.environment.LOADED = { }
self.environment.AST = AST

View File

@ -283,6 +283,9 @@ class NomsuCompiler
@environment.Source = Source
@environment.ARG_ORDERS = setmetatable({}, {__mode:"k"})
@environment.ALIASES = setmetatable({}, {__mode:"k"})
@environment.compile_time = (fn)->
@environment.COMPILE_TIME[fn] = true
return fn
@environment.COMPILE_TIME = {}
@environment.LOADED = {}
@environment.AST = AST