From 8dd62e76bedc16d04e1bb7254f59fabf71a57f09 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Sun, 10 Nov 2013 08:32:29 -0800 Subject: [PATCH] feat(lua): add mk_metavar to Lua API Signed-off-by: Leonardo de Moura --- src/bindings/lua/expr.cpp | 10 ++++++++++ tests/lua/expr4.lua | 4 ++++ 2 files changed, 14 insertions(+) create mode 100644 tests/lua/expr4.lua diff --git a/src/bindings/lua/expr.cpp b/src/bindings/lua/expr.cpp index 1d51af8a9..4b4ebb24f 100644 --- a/src/bindings/lua/expr.cpp +++ b/src/bindings/lua/expr.cpp @@ -16,6 +16,7 @@ Author: Leonardo de Moura #include "bindings/lua/util.h" #include "bindings/lua/name.h" #include "bindings/lua/level.h" +#include "bindings/lua/local_context.h" namespace lean { constexpr char const * expr_mt = "expr.mt"; @@ -171,6 +172,14 @@ static int expr_type(lua_State * L) { return push_expr(L, Type(to_level(L, 1))); } +static int expr_mk_metavar(lua_State * L) { + int nargs = lua_gettop(L); + if (nargs == 1) + return push_expr(L, mk_metavar(to_name_ext(L, 1))); + else + return push_expr(L, mk_metavar(to_name_ext(L, 1), to_local_context(L, 2))); +} + static int expr_is_null(lua_State * L) { lua_pushboolean(L, !to_expr(L, 1)); return 1; @@ -208,5 +217,6 @@ void open_expr(lua_State * L) { set_global_function(L, "Let"); set_global_function(L, "mk_type"); set_global_function(L, "Type"); + set_global_function(L, "mk_metavar"); } } diff --git a/tests/lua/expr4.lua b/tests/lua/expr4.lua new file mode 100644 index 000000000..04ce2507e --- /dev/null +++ b/tests/lua/expr4.lua @@ -0,0 +1,4 @@ +m1 = mk_metavar("a") +print(m1) +m2 = mk_metavar("b", local_context(mk_inst(1, Const("a")), local_context())) +print(m2)