2015-09-21 23:17:11 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "kernel/expr.h"
|
|
|
|
#include "kernel/declaration.h"
|
|
|
|
|
|
|
|
namespace lean {
|
|
|
|
namespace blast {
|
|
|
|
// API for creating maximally shared terms used by the blast tactic.
|
|
|
|
// The API assumes there is a single blast tactic using theses terms.
|
2015-09-30 19:54:03 +00:00
|
|
|
// The expression hash-consing tables are thread local and implemented
|
|
|
|
// in the kernel
|
2015-09-21 23:17:11 +00:00
|
|
|
|
|
|
|
// Remark: All procedures assume the children levels and expressions are maximally shared.
|
|
|
|
// That is, it assumes they have been created using the APIs provided by this module.
|
|
|
|
|
|
|
|
// Auxiliary object for resetting the the thread local hash-consing tables.
|
2015-09-30 19:54:03 +00:00
|
|
|
// It also uses an assertion to make sure it is not being used in a recursion.
|
2015-09-30 20:31:42 +00:00
|
|
|
class scope_hash_consing : public scoped_expr_caching {
|
2015-09-21 23:17:11 +00:00
|
|
|
public:
|
|
|
|
scope_hash_consing();
|
|
|
|
~scope_hash_consing();
|
|
|
|
};
|
|
|
|
|
|
|
|
level mk_level_zero();
|
|
|
|
level mk_level_one();
|
|
|
|
level mk_max(level const & l1, level const & l2);
|
|
|
|
level mk_imax(level const & l1, level const & l2);
|
|
|
|
level mk_succ(level const & l);
|
|
|
|
level mk_param_univ(name const & n);
|
|
|
|
level mk_global_univ(name const & n);
|
2015-10-02 22:48:01 +00:00
|
|
|
level mk_uref(unsigned idx);
|
|
|
|
|
|
|
|
bool is_uref(level const & l);
|
|
|
|
unsigned uref_index(level const & l);
|
2015-09-21 23:17:11 +00:00
|
|
|
|
|
|
|
expr mk_var(unsigned idx);
|
2015-09-29 19:13:20 +00:00
|
|
|
// mk_href and mk_mref are helper functions for creating hypotheses and meta-variables used in the blast tactic.
|
2015-09-28 20:02:15 +00:00
|
|
|
// Remark: the local constants and metavariables manipulated by the blast tactic do **not** store their types.
|
2015-09-29 19:13:20 +00:00
|
|
|
expr mk_href(unsigned idx);
|
2015-09-21 23:17:11 +00:00
|
|
|
expr mk_mref(unsigned idx);
|
|
|
|
expr mk_sort(level const & l);
|
|
|
|
expr mk_constant(name const & n, levels const & ls);
|
2015-10-02 20:11:17 +00:00
|
|
|
expr mk_local(name const & n, name const & pp_n, expr const & t, binder_info const & bi);
|
2015-09-21 23:17:11 +00:00
|
|
|
expr mk_app(expr const & f, expr const & a);
|
2015-09-25 21:43:42 +00:00
|
|
|
expr mk_app(expr const & f, unsigned num_args, expr const * args);
|
|
|
|
expr mk_app(unsigned num_args, expr const * args);
|
2015-10-01 23:21:17 +00:00
|
|
|
expr mk_rev_app(expr const & f, unsigned num_args, expr const * args);
|
|
|
|
expr mk_rev_app(unsigned num_args, expr const * args);
|
2015-09-21 23:17:11 +00:00
|
|
|
expr mk_binding(expr_kind k, name const & n, expr const & t, expr const & e, binder_info const & bi);
|
|
|
|
inline expr mk_pi(name const & n, expr const & t, expr const & e, binder_info const & bi) {
|
|
|
|
return blast::mk_binding(expr_kind::Pi, n, t, e, bi);
|
|
|
|
}
|
|
|
|
inline expr mk_lambda(name const & n, expr const & t, expr const & e, binder_info const & bi) {
|
|
|
|
return blast::mk_binding(expr_kind::Lambda, n, t, e, bi);
|
|
|
|
}
|
|
|
|
inline expr mk_binding(expr_kind k, name const & n, expr const & t, expr const & e) {
|
|
|
|
return blast::mk_binding(k, n, t, e, binder_info());
|
|
|
|
}
|
|
|
|
inline expr mk_pi(name const & n, expr const & t, expr const & e) {
|
|
|
|
return blast::mk_pi(n, t, e, binder_info());
|
|
|
|
}
|
|
|
|
inline expr mk_lambda(name const & n, expr const & t, expr const & e) {
|
|
|
|
return blast::mk_lambda(n, t, e, binder_info());
|
|
|
|
}
|
|
|
|
expr mk_macro(macro_definition const & m, unsigned num, expr const * args);
|
|
|
|
|
2015-09-29 19:13:20 +00:00
|
|
|
bool is_href(expr const & e);
|
|
|
|
unsigned href_index(expr const & e);
|
2015-09-28 20:02:15 +00:00
|
|
|
bool is_mref(expr const & e);
|
|
|
|
unsigned mref_index(expr const & e);
|
2015-09-29 19:13:20 +00:00
|
|
|
/** \brief Return true iff \c e contain href's */
|
|
|
|
bool has_href(expr const & e);
|
2015-09-28 23:40:19 +00:00
|
|
|
/** \brief Return true iff \c e contain mref's */
|
|
|
|
bool has_mref(expr const & e);
|
2015-09-21 23:17:11 +00:00
|
|
|
|
2015-09-29 19:27:18 +00:00
|
|
|
bool is_local(expr const & e);
|
|
|
|
unsigned local_index(expr const & e);
|
|
|
|
expr const & local_type(expr const & e);
|
|
|
|
bool has_local(expr const & e);
|
|
|
|
|
2015-09-21 23:17:11 +00:00
|
|
|
level update_succ(level const & l, level const & new_arg);
|
|
|
|
level update_max(level const & l, level const & new_lhs, level const & new_rhs);
|
|
|
|
|
|
|
|
expr update_app(expr const & e, expr const & new_fn, expr const & new_arg);
|
2015-09-28 20:02:15 +00:00
|
|
|
expr update_metavar(expr const & e, expr const & new_type);
|
2015-09-21 23:17:11 +00:00
|
|
|
expr update_binding(expr const & e, expr const & new_domain, expr const & new_body);
|
|
|
|
expr update_sort(expr const & e, level const & new_level);
|
|
|
|
expr update_constant(expr const & e, levels const & new_levels);
|
2015-10-04 01:18:44 +00:00
|
|
|
expr update_local(expr const & e, expr const & new_type);
|
2015-09-21 23:17:11 +00:00
|
|
|
expr update_macro(expr const & e, unsigned num, expr const * args);
|
|
|
|
|
2015-09-28 20:02:15 +00:00
|
|
|
void initialize_expr();
|
|
|
|
void finalize_expr();
|
2015-09-21 23:17:11 +00:00
|
|
|
}
|
|
|
|
}
|