refactor(frontends/lua): replace lean.lua.h with util.lua

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-12-26 19:49:04 -08:00
parent 40eca048e0
commit 3f0279b88c
25 changed files with 36 additions and 25 deletions

16
src/extra/util.lua Normal file
View file

@ -0,0 +1,16 @@
-- Extra useful functions
-- Create sequence of expressions.
-- Examples:
-- local a, b, c = Consts("a,b,c")
-- We can use ';', ' ', ',', tabs ad line breaks for separating the constant names
-- local a, b, c = Consts("a b c")
function Consts(s)
r = {}
i = 1
for c in string.gmatch(s, '[^ ,;\\t\\n]+') do
r[i] = Const(c)
i = i + 1
end
return unpack(r)
end

View file

@ -1,16 +0,0 @@
/*
Copyright (c) 2013 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
static char const * g_extra_code =
"function Consts(s)\n"
" r = {}\n"
" i = 1\n"
" for c in string.gmatch(s, '[^ ,;\\t\\n]+') do\n"
" r[i] = Const(c)\n"
" i = i + 1\n"
" end\n"
" return unpack(r)\n"
"end\n";

View file

@ -11,7 +11,6 @@ Author: Leonardo de Moura
#include "library/arith/register_module.h" #include "library/arith/register_module.h"
#include "library/tactic/register_module.h" #include "library/tactic/register_module.h"
#include "frontends/lean/register_module.h" #include "frontends/lean/register_module.h"
#include "frontends/lua/lean.lua.h"
namespace lean { namespace lean {
void register_modules() { void register_modules() {
@ -21,6 +20,5 @@ void register_modules() {
register_arith_module(); register_arith_module();
register_tactic_module(); register_tactic_module();
register_frontend_lean_module(); register_frontend_lean_module();
script_state::register_code(g_extra_code);
} }
} }

View file

@ -1,14 +1,13 @@
Variables x y z : Int Variables x y z : Int
(** (**
import("util.lua")
local env = get_environment() local env = get_environment()
local plus = Const{"Int", "add"} local plus = Const{"Int", "add"}
local x, y = Consts("x y") local x, y = Consts("x y")
local def = plus(plus(x, y), iVal(1000)) local def = plus(plus(x, y), iVal(1000))
print(def, ":", env:type_check(def)) print(def, ":", env:type_check(def))
env:add_definition("sum", def) env:add_definition("sum", def)
**) **)
Eval sum + 3 Eval sum + 3

View file

@ -1,6 +1,7 @@
Variable x : Bool Variable x : Bool
(** (**
import("util.lua")
local env = get_environment() local env = get_environment()
local Int = Const("Int") local Int = Const("Int")
local plus = Const{"Int", "add"} local plus = Const{"Int", "add"}

View file

@ -1,3 +1,4 @@
import("util.lua")
f, a, b = Consts("f, a, b") f, a, b = Consts("f, a, b")
nodes = {} nodes = {}

View file

@ -1,3 +1,4 @@
import("util.lua")
e = environment() e = environment()
assert(is_environment(e)) assert(is_environment(e))
e:add_uvar("M1") e:add_uvar("M1")

View file

@ -1,3 +1,4 @@
import("util.lua")
f = Const("f") f = Const("f")
x = Const("x") x = Const("x")
y = Const("y") y = Const("y")

View file

@ -1,3 +1,4 @@
import("util.lua")
function print_leaves(e, ctx) function print_leaves(e, ctx)
if (not e) then if (not e) then
return return

View file

@ -1,3 +1,4 @@
import("util.lua")
local f, g, a, b, c, d = Consts("f, g, a, b, c, d") local f, g, a, b, c, d = Consts("f, g, a, b, c, d")
local x = Var(0) local x = Var(0)
local y = Var(1) local y = Var(1)
@ -16,4 +17,3 @@ assert(F:lift_free_vars(1):abstract(a):instantiate{c, d} == f(g(c, d), f(b, f(c,
assert(F:lift_free_vars(1):abstract(a):instantiate{c, d}:abstract{c, b} == f(g(y, d), f(x, f(y, y)))) assert(F:lift_free_vars(1):abstract(a):instantiate{c, d}:abstract{c, b} == f(g(y, d), f(x, f(y, y))))
assert(F:lift_free_vars(1):lower_free_vars(1) == F) assert(F:lift_free_vars(1):lower_free_vars(1) == F)
assert(F:lift_free_vars(0, 1):lower_free_vars(1, 1) == F) assert(F:lift_free_vars(0, 1):lower_free_vars(1, 1) == F)

View file

@ -1,3 +1,4 @@
import("util.lua")
local f, g, a, b, c, d = Consts("f, g, a, b, c, d") local f, g, a, b, c, d = Consts("f, g, a, b, c, d")
local N, M = Consts("N, M") local N, M = Consts("N, M")
local x = Var(0) local x = Var(0)

View file

@ -1,3 +1,4 @@
import("util.lua")
local env = environment() local env = environment()
print(get_options()) print(get_options())
parse_lean_cmds([[ parse_lean_cmds([[

View file

@ -1,3 +1,4 @@
import("util.lua")
-- This examples demonstrates that Lean objects are not very useful as Lua table keys. -- This examples demonstrates that Lean objects are not very useful as Lua table keys.
local f = Const("f") local f = Const("f")
local m = {} local m = {}

View file

@ -1,3 +1,4 @@
import("util.lua")
local menv = metavar_env() local menv = metavar_env()
assert(is_metavar_env(menv)) assert(is_metavar_env(menv))
local m1 = menv:mk_metavar() local m1 = menv:mk_metavar()

View file

@ -1,3 +1,4 @@
import("util.lua")
local env = environment() local env = environment()
parse_lean_cmds([[ parse_lean_cmds([[
Variable N : Type Variable N : Type

View file

@ -1,3 +1,4 @@
import("util.lua")
local ps = proof_state() local ps = proof_state()
local env = environment() local env = environment()
local Bool = Const("Bool") local Bool = Const("Bool")
@ -23,5 +24,3 @@ local pb = ps:proof_builder()
local cb = ps:cex_builder() local cb = ps:cex_builder()
assert(not ps:is_proof_final_state()) assert(not ps:is_proof_final_state())
assert(not ps:is_cex_final_state()) assert(not ps:is_cex_final_state())

View file

@ -1,3 +1,4 @@
import("util.lua")
local ps = proof_state() local ps = proof_state()
local env = environment() local env = environment()
local Bool = Const("Bool") local Bool = Const("Bool")

View file

@ -1,3 +1,4 @@
import("util.lua")
import("template.lua") import("template.lua")
local env = environment() local env = environment()
parse_lean_cmds([[ parse_lean_cmds([[

View file

@ -8,7 +8,7 @@ LEAN=$1
NUM_ERRORS=0 NUM_ERRORS=0
for f in `ls *.lua`; do for f in `ls *.lua`; do
echo "-- testing $f" echo "-- testing $f"
if $LEAN util.lua $f > $f.produced.out; then if $LEAN extra.lua $f > $f.produced.out; then
echo "-- worked" echo "-- worked"
else else
echo "ERROR executing $f, produced output is at $f.produced.out" echo "ERROR executing $f, produced output is at $f.produced.out"

View file

@ -7,7 +7,7 @@ ulimit -s unlimited
LEAN=$1 LEAN=$1
f=$2 f=$2
echo "-- testing $f" echo "-- testing $f"
if $LEAN util.lua $f > $f.produced.out; then if $LEAN extra.lua $f > $f.produced.out; then
echo "-- worked" echo "-- worked"
exit 0 exit 0
else else

View file

@ -1,3 +1,4 @@
import("util.lua")
local env = environment() local env = environment()
local ios = io_state() local ios = io_state()
local Bool = Const("Bool") local Bool = Const("Bool")

View file

@ -1,3 +1,4 @@
import("util.lua")
local env = environment() local env = environment()
local ios = io_state() local ios = io_state()
local Bool = Const("Bool") local Bool = Const("Bool")

View file

@ -1,3 +1,4 @@
import("util.lua")
local f, g, a, b, c, x = Consts("f, g, a, b, c, x") local f, g, a, b, c, x = Consts("f, g, a, b, c, x")
local m1 = mk_metavar("m1") local m1 = mk_metavar("m1")
local m2 = mk_metavar("m2") local m2 = mk_metavar("m2")