#.. Tests for the stuff defined in lib/metaprogramming.nom use "core" immediately compile [five] to: Lua value "5" assume ((five) = 5) or barf "Compile to expression failed." immediately compile [loc x] to: Lua "local _x = 99;" lua> "do" loc x assume (%x is 99) or barf "Compile to statements with locals failed." lua> "end" assume (%x is (nil)) or barf "Failed to properly localize a variable." immediately compile [asdf] to %tmp <- "" return: Lua %tmp asdf assume (%tmp is (nil)) or barf "compile to is leaking variables" action [foo %x] %y <- (%x + 1) return %y assume ((foo 10) = 11) or barf "Action didn't work." assume (%y is (nil)) or barf "Action leaked a local into globals." immediately parse [baz %] as: foo % assume ((baz 10) = 11) or barf "Parse as action failed." immediately parse [V] as: five assume ((V) = 5) or barf "Parse as compile action failed." remove action "foo %" try: foo 99 ..and if it succeeds: barf "Failed to delete action" assume ((\(5 + 5) as value) = 10) or barf "%tree as value failed." assume (((\(foo %x) as nomsu) as text) = "foo %x") or barf "source code failed." assume ((repr [1,2]) = "{1, 2}") or barf "repr failed." assume ((type of {}) = "table") or barf "type of failed." assume ((nomsu) = (=lua "nomsu")) or barf "nomsu failed" assume (((\%x as lua identifier) as text) = "_x") or barf "converting to identifier failed." assume ((run "return 99") = 99) or barf "run % failed." say "Metaprogramming test passed." %code <-: Lua "global_x = true;" lua> %code assume (=lua "global_x") or barf "Running lua from a variable failed." %code <-: Lua value "global_x" assume (=lua %code) or barf "Running lua from a variable failed."