2013-08-10 01:00:05 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2013 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
|
|
|
#include "frontend.h"
|
|
|
|
#include "environment.h"
|
2013-08-12 01:06:37 +00:00
|
|
|
#include "operator_info.h"
|
2013-08-17 17:55:42 +00:00
|
|
|
#include "kernel_exception.h"
|
2013-08-17 19:33:19 +00:00
|
|
|
#include "builtin.h"
|
2013-08-17 03:39:24 +00:00
|
|
|
#include "pp.h"
|
2013-08-10 01:00:05 +00:00
|
|
|
#include "test.h"
|
|
|
|
using namespace lean;
|
|
|
|
|
|
|
|
static void tst1() {
|
|
|
|
frontend f;
|
|
|
|
f.add_uvar("tst");
|
|
|
|
frontend c = f.mk_child();
|
|
|
|
lean_assert(c.get_uvar("tst") == f.get_uvar("tst"));
|
2013-08-17 03:39:24 +00:00
|
|
|
lean_assert(f.get_environment().has_children());
|
2013-08-10 01:00:05 +00:00
|
|
|
}
|
|
|
|
|
2013-08-12 01:06:37 +00:00
|
|
|
static void tst2() {
|
|
|
|
operator_info op1 = infixl(name("and"), 10);
|
|
|
|
operator_info op2 = infixr(name("implies"), 20);
|
|
|
|
lean_assert(op1.get_precedence() == 10);
|
2013-08-15 15:52:10 +00:00
|
|
|
lean_assert(op1.get_fixity() == fixity::Infixl);
|
2013-08-12 01:06:37 +00:00
|
|
|
op1.add_internal_name(name{"Bool","And"});
|
|
|
|
operator_info op3 = infixl(name("+"), 10);
|
|
|
|
op3.add_internal_name(name{"Int", "plus"});
|
|
|
|
op3.add_internal_name(name{"Real", "plus"});
|
|
|
|
std::cout << op3.get_internal_names() << "\n";
|
|
|
|
lean_assert(length(op3.get_internal_names()) == 2);
|
|
|
|
operator_info op4 = op3.copy();
|
|
|
|
op4.add_internal_name(name{"Complex", "plus"});
|
|
|
|
std::cout << op4.get_internal_names() << "\n";
|
|
|
|
lean_assert(length(op3.get_internal_names()) == 2);
|
|
|
|
lean_assert(length(op4.get_internal_names()) == 3);
|
2013-08-15 15:52:10 +00:00
|
|
|
lean_assert(op4.get_fixity() == fixity::Infixl);
|
2013-08-12 01:06:37 +00:00
|
|
|
lean_assert(op4.get_op_name() == op3.get_op_name());
|
|
|
|
lean_assert(prefix("tst", 20).get_fixity() == fixity::Prefix);
|
|
|
|
lean_assert(postfix("!", 20).get_fixity() == fixity::Postfix);
|
|
|
|
lean_assert(length(mixfixl({"if", "then", "else"}, 10).get_op_name_parts()) == 3);
|
|
|
|
lean_assert(mixfixc({"if", "then", "else", "endif"}, 10).get_fixity() == fixity::Mixfixc);
|
|
|
|
std::cout << mixfixc({"if", "then", "else", "endif"}, 10).get_op_name_parts() << "\n";
|
|
|
|
std::cout << op4 << "\n";
|
|
|
|
std::cout << op2 << "\n";
|
|
|
|
std::cout << mixfixc({"if", "then", "else", "endif"}, 10) << "\n";
|
|
|
|
}
|
|
|
|
|
2013-08-15 15:52:10 +00:00
|
|
|
static void tst3() {
|
|
|
|
frontend f;
|
2013-08-16 16:30:08 +00:00
|
|
|
std::cout << "====================\n";
|
2013-08-17 03:39:24 +00:00
|
|
|
std::cout << f << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
static void tst4() {
|
|
|
|
frontend f;
|
2013-08-17 18:29:43 +00:00
|
|
|
formatter fmt = mk_pp_formatter(f);
|
2013-08-17 03:39:24 +00:00
|
|
|
context c;
|
|
|
|
c = extend(c, "x", Bool);
|
|
|
|
c = extend(c, "y", Bool);
|
|
|
|
c = extend(c, "x", Bool, Var(1));
|
|
|
|
c = extend(c, "x", Bool, Var(2));
|
|
|
|
c = extend(c, "z", Bool, Var(1));
|
|
|
|
c = extend(c, "x", Bool, Var(4));
|
|
|
|
std::cout << fmt(c) << "\n";
|
2013-08-15 15:52:10 +00:00
|
|
|
}
|
|
|
|
|
2013-08-17 17:55:42 +00:00
|
|
|
static void tst5() {
|
|
|
|
std::cout << "=================\n";
|
|
|
|
frontend f;
|
2013-08-17 18:29:43 +00:00
|
|
|
formatter fmt = mk_pp_formatter(f);
|
2013-08-17 17:55:42 +00:00
|
|
|
f.add_var("A", Type());
|
|
|
|
f.add_var("x", Const("A"));
|
|
|
|
object const & obj = f.find_object("x");
|
|
|
|
lean_assert(obj);
|
|
|
|
lean_assert(obj.get_name() == "x");
|
|
|
|
std::cout << fmt(obj) << "\n";
|
|
|
|
object const & obj2 = f.find_object("y");
|
|
|
|
lean_assert(!obj2);
|
|
|
|
try {
|
|
|
|
f.get_object("y");
|
|
|
|
lean_unreachable();
|
|
|
|
} catch (unknown_name_exception & ex) {
|
|
|
|
std::cout << ex.what() << " " << ex.get_name() << "\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-17 18:04:22 +00:00
|
|
|
class alien_cell : public neutral_object_cell {
|
|
|
|
unsigned m_data[128];
|
|
|
|
public:
|
|
|
|
alien_cell() {}
|
|
|
|
unsigned & get_data(unsigned i) { return m_data[i]; }
|
|
|
|
virtual char const * keyword() const { return "alien"; }
|
|
|
|
};
|
|
|
|
|
|
|
|
static void tst6() {
|
|
|
|
std::cout << "=================\n";
|
|
|
|
frontend f;
|
|
|
|
environment env;
|
|
|
|
env.add_neutral_object(new alien_cell());
|
2013-08-17 18:29:43 +00:00
|
|
|
formatter fmt = mk_pp_formatter(f);
|
2013-08-17 18:04:22 +00:00
|
|
|
std::cout << fmt(env) << "\n";
|
|
|
|
}
|
|
|
|
|
2013-08-17 19:33:19 +00:00
|
|
|
static formatter mk() {
|
|
|
|
frontend f;
|
|
|
|
return mk_pp_formatter(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void tst7() {
|
|
|
|
formatter fmt = mk();
|
|
|
|
std::cout << fmt(And(Const("x"), Const("y"))) << "\n";
|
|
|
|
}
|
|
|
|
|
2013-08-10 01:00:05 +00:00
|
|
|
int main() {
|
|
|
|
tst1();
|
2013-08-12 01:06:37 +00:00
|
|
|
tst2();
|
2013-08-15 15:52:10 +00:00
|
|
|
tst3();
|
2013-08-17 03:51:11 +00:00
|
|
|
tst4();
|
2013-08-17 17:55:42 +00:00
|
|
|
tst5();
|
2013-08-17 18:04:22 +00:00
|
|
|
tst6();
|
2013-08-17 19:33:19 +00:00
|
|
|
tst7();
|
2013-08-10 01:00:05 +00:00
|
|
|
return has_violations() ? 1 : 0;
|
|
|
|
}
|