feat(kernel/expr): remove 'contextual' flag from binder_info
This commit is contained in:
parent
b41c65f549
commit
2b1d734544
8 changed files with 16 additions and 34 deletions
|
@ -56,7 +56,6 @@ static binder_info to_binder_info(lean_binder_kind k) {
|
||||||
case LEAN_BINDER_IMPLICIT: return mk_implicit_binder_info();
|
case LEAN_BINDER_IMPLICIT: return mk_implicit_binder_info();
|
||||||
case LEAN_BINDER_STRICT_IMPLICIT: return mk_strict_implicit_binder_info();
|
case LEAN_BINDER_STRICT_IMPLICIT: return mk_strict_implicit_binder_info();
|
||||||
case LEAN_BINDER_INST_IMPLICIT: return mk_inst_implicit_binder_info();
|
case LEAN_BINDER_INST_IMPLICIT: return mk_inst_implicit_binder_info();
|
||||||
case LEAN_BINDER_HIDDEN: return mk_contextual_info(false);
|
|
||||||
}
|
}
|
||||||
lean_unreachable();
|
lean_unreachable();
|
||||||
}
|
}
|
||||||
|
@ -68,8 +67,6 @@ static lean_binder_kind of_binder_info(binder_info k) {
|
||||||
return LEAN_BINDER_INST_IMPLICIT;
|
return LEAN_BINDER_INST_IMPLICIT;
|
||||||
else if (k.is_strict_implicit())
|
else if (k.is_strict_implicit())
|
||||||
return LEAN_BINDER_STRICT_IMPLICIT;
|
return LEAN_BINDER_STRICT_IMPLICIT;
|
||||||
else if (!k.is_contextual())
|
|
||||||
return LEAN_BINDER_HIDDEN;
|
|
||||||
else
|
else
|
||||||
return LEAN_BINDER_DEFAULT;
|
return LEAN_BINDER_DEFAULT;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,8 +41,7 @@ typedef enum {
|
||||||
LEAN_BINDER_DEFAULT, // (x : A)
|
LEAN_BINDER_DEFAULT, // (x : A)
|
||||||
LEAN_BINDER_IMPLICIT, // {x : A}
|
LEAN_BINDER_IMPLICIT, // {x : A}
|
||||||
LEAN_BINDER_STRICT_IMPLICIT, // {{x : A}}
|
LEAN_BINDER_STRICT_IMPLICIT, // {{x : A}}
|
||||||
LEAN_BINDER_INST_IMPLICIT, // [x : A]
|
LEAN_BINDER_INST_IMPLICIT // [x : A]
|
||||||
LEAN_BINDER_HIDDEN // like (x : A) but not included in proof goals
|
|
||||||
} lean_binder_kind;
|
} lean_binder_kind;
|
||||||
|
|
||||||
/** \brief Create a variable with de-Bruijn index \c i.
|
/** \brief Create a variable with de-Bruijn index \c i.
|
||||||
|
|
|
@ -341,7 +341,7 @@ static expr parse_using_expr(parser & p, pos_info const & using_pos) {
|
||||||
if (!is_local(l))
|
if (!is_local(l))
|
||||||
throw parser_error("invalid 'using' declaration for 'have', local expected", id_pos);
|
throw parser_error("invalid 'using' declaration for 'have', local expected", id_pos);
|
||||||
expr new_l;
|
expr new_l;
|
||||||
binder_info bi = local_info(l).update_contextual(true);
|
binder_info bi = local_info(l);
|
||||||
if (p.is_local_variable_parameter(local_pp_name(l))) {
|
if (p.is_local_variable_parameter(local_pp_name(l))) {
|
||||||
expr new_type = p.save_pos(mk_as_is(mlocal_type(l)), id_pos);
|
expr new_type = p.save_pos(mk_as_is(mlocal_type(l)), id_pos);
|
||||||
new_l = p.save_pos(mk_local(mlocal_name(l), local_pp_name(l), new_type, bi), id_pos);
|
new_l = p.save_pos(mk_local(mlocal_name(l), local_pp_name(l), new_type, bi), id_pos);
|
||||||
|
|
|
@ -941,8 +941,7 @@ expr elaborator::visit_binding(expr e, expr_kind k, constraint_seq & cs) {
|
||||||
ds.push_back(d);
|
ds.push_back(d);
|
||||||
expr l = mk_local(binding_name(e), d, binding_info(e));
|
expr l = mk_local(binding_name(e), d, binding_info(e));
|
||||||
if (!is_match_binder_name(binding_name(e))) {
|
if (!is_match_binder_name(binding_name(e))) {
|
||||||
if (binding_info(e).is_contextual())
|
m_context.add_local(l);
|
||||||
m_context.add_local(l);
|
|
||||||
m_full_context.add_local(l);
|
m_full_context.add_local(l);
|
||||||
}
|
}
|
||||||
ls.push_back(l);
|
ls.push_back(l);
|
||||||
|
|
|
@ -139,7 +139,7 @@ void expr_const::dealloc() {
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned binder_info::hash() const {
|
unsigned binder_info::hash() const {
|
||||||
return (m_implicit << 3) | (m_contextual << 2) | (m_strict_implicit << 1) | m_inst_implicit;
|
return (m_rec << 3) | (m_implicit << 2) | (m_strict_implicit << 1) | m_inst_implicit;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Expr metavariables and local variables
|
// Expr metavariables and local variables
|
||||||
|
@ -200,9 +200,9 @@ static unsigned dec(unsigned k) { return k == 0 ? 0 : k - 1; }
|
||||||
bool operator==(binder_info const & i1, binder_info const & i2) {
|
bool operator==(binder_info const & i1, binder_info const & i2) {
|
||||||
return
|
return
|
||||||
i1.is_implicit() == i2.is_implicit() &&
|
i1.is_implicit() == i2.is_implicit() &&
|
||||||
i1.is_contextual() == i2.is_contextual() &&
|
|
||||||
i1.is_strict_implicit() == i2.is_strict_implicit() &&
|
i1.is_strict_implicit() == i2.is_strict_implicit() &&
|
||||||
i1.is_inst_implicit() == i2.is_inst_implicit();
|
i1.is_inst_implicit() == i2.is_inst_implicit() &&
|
||||||
|
i1.is_rec() == i2.is_rec();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Expr binders (Lambda, Pi)
|
// Expr binders (Lambda, Pi)
|
||||||
|
|
|
@ -208,9 +208,6 @@ public:
|
||||||
*/
|
*/
|
||||||
class binder_info {
|
class binder_info {
|
||||||
unsigned m_implicit:1; //! if true, binder argument is an implicit argument
|
unsigned m_implicit:1; //! if true, binder argument is an implicit argument
|
||||||
/** if m_contextual is true, binder argument is assumed to be part of the context,
|
|
||||||
and may be argument for metavariables. */
|
|
||||||
unsigned m_contextual:1;
|
|
||||||
unsigned m_strict_implicit:1; //! if true, binder argument is assumed to be a strict implicit argument
|
unsigned m_strict_implicit:1; //! if true, binder argument is assumed to be a strict implicit argument
|
||||||
/** \brief if m_inst_implicit is true, binder argument is an implicit argument, and should be
|
/** \brief if m_inst_implicit is true, binder argument is an implicit argument, and should be
|
||||||
inferred by class-instance resolution. */
|
inferred by class-instance resolution. */
|
||||||
|
@ -219,23 +216,19 @@ class binder_info {
|
||||||
in recursive equations */
|
in recursive equations */
|
||||||
unsigned m_rec:1;
|
unsigned m_rec:1;
|
||||||
public:
|
public:
|
||||||
binder_info(bool implicit = false, bool contextual = true, bool strict_implicit = false, bool inst_implicit = false, bool rec = false):
|
binder_info(bool implicit = false, bool strict_implicit = false, bool inst_implicit = false, bool rec = false):
|
||||||
m_implicit(implicit), m_contextual(contextual), m_strict_implicit(strict_implicit),
|
m_implicit(implicit), m_strict_implicit(strict_implicit), m_inst_implicit(inst_implicit), m_rec(rec) {}
|
||||||
m_inst_implicit(inst_implicit), m_rec(rec) {}
|
|
||||||
bool is_implicit() const { return m_implicit; }
|
bool is_implicit() const { return m_implicit; }
|
||||||
bool is_contextual() const { return m_contextual; }
|
|
||||||
bool is_strict_implicit() const { return m_strict_implicit; }
|
bool is_strict_implicit() const { return m_strict_implicit; }
|
||||||
bool is_inst_implicit() const { return m_inst_implicit; }
|
bool is_inst_implicit() const { return m_inst_implicit; }
|
||||||
bool is_rec() const { return m_rec; }
|
bool is_rec() const { return m_rec; }
|
||||||
unsigned hash() const;
|
unsigned hash() const;
|
||||||
binder_info update_contextual(bool f) const { return binder_info(m_implicit, f, m_strict_implicit, m_inst_implicit, m_rec); }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline binder_info mk_implicit_binder_info() { return binder_info(true); }
|
inline binder_info mk_implicit_binder_info() { return binder_info(true); }
|
||||||
inline binder_info mk_strict_implicit_binder_info() { return binder_info(false, true, true); }
|
inline binder_info mk_strict_implicit_binder_info() { return binder_info(false, true); }
|
||||||
inline binder_info mk_inst_implicit_binder_info() { return binder_info(false, true, false, true); }
|
inline binder_info mk_inst_implicit_binder_info() { return binder_info(false, false, true); }
|
||||||
inline binder_info mk_contextual_info(bool f) { return binder_info(false, f); }
|
inline binder_info mk_rec_info(bool f) { return binder_info(false, false, false, f); }
|
||||||
inline binder_info mk_rec_info(bool f) { return binder_info(false, true, false, false, f); }
|
|
||||||
|
|
||||||
inline bool is_explicit(binder_info const & bi) {
|
inline bool is_explicit(binder_info const & bi) {
|
||||||
return !bi.is_implicit() && !bi.is_strict_implicit() && !bi.is_inst_implicit();
|
return !bi.is_implicit() && !bi.is_strict_implicit() && !bi.is_inst_implicit();
|
||||||
|
|
|
@ -118,9 +118,8 @@ static expr read_macro_definition(deserializer & d, unsigned num, expr const * a
|
||||||
|
|
||||||
serializer & operator<<(serializer & s, binder_info const & i) {
|
serializer & operator<<(serializer & s, binder_info const & i) {
|
||||||
unsigned w =
|
unsigned w =
|
||||||
(i.is_rec() ? 16 : 0) +
|
(i.is_rec() ? 8 : 0) +
|
||||||
(i.is_implicit() ? 8 : 0) +
|
(i.is_implicit() ? 4 : 0) +
|
||||||
(i.is_contextual() ? 4 : 0) +
|
|
||||||
(i.is_strict_implicit() ? 2 : 0) +
|
(i.is_strict_implicit() ? 2 : 0) +
|
||||||
(i.is_inst_implicit() ? 1 : 0);
|
(i.is_inst_implicit() ? 1 : 0);
|
||||||
s.write_char(w);
|
s.write_char(w);
|
||||||
|
@ -129,12 +128,11 @@ serializer & operator<<(serializer & s, binder_info const & i) {
|
||||||
|
|
||||||
static binder_info read_binder_info(deserializer & d) {
|
static binder_info read_binder_info(deserializer & d) {
|
||||||
unsigned w = d.read_char();
|
unsigned w = d.read_char();
|
||||||
bool rec = (w & 16) != 0;
|
bool rec = (w & 8) != 0;
|
||||||
bool imp = (w & 8) != 0;
|
bool imp = (w & 4) != 0;
|
||||||
bool ctx = (w & 4) != 0;
|
|
||||||
bool s_imp = (w & 2) != 0;
|
bool s_imp = (w & 2) != 0;
|
||||||
bool i_imp = (w & 1) != 0;
|
bool i_imp = (w & 1) != 0;
|
||||||
return binder_info(imp, ctx, s_imp, i_imp, rec);
|
return binder_info(imp, s_imp, i_imp, rec);
|
||||||
}
|
}
|
||||||
|
|
||||||
static name * g_binder_name = nullptr;
|
static name * g_binder_name = nullptr;
|
||||||
|
|
|
@ -158,8 +158,6 @@ struct print_expr_fn {
|
||||||
out() << "{";
|
out() << "{";
|
||||||
else if (binding_info(e).is_inst_implicit())
|
else if (binding_info(e).is_inst_implicit())
|
||||||
out() << "[";
|
out() << "[";
|
||||||
else if (!binding_info(e).is_contextual())
|
|
||||||
out() << "[[";
|
|
||||||
else if (binding_info(e).is_strict_implicit())
|
else if (binding_info(e).is_strict_implicit())
|
||||||
out() << "{{";
|
out() << "{{";
|
||||||
else
|
else
|
||||||
|
@ -170,8 +168,6 @@ struct print_expr_fn {
|
||||||
out() << "}";
|
out() << "}";
|
||||||
else if (binding_info(e).is_inst_implicit())
|
else if (binding_info(e).is_inst_implicit())
|
||||||
out() << "]";
|
out() << "]";
|
||||||
else if (!binding_info(e).is_contextual())
|
|
||||||
out() << "]]";
|
|
||||||
else if (binding_info(e).is_strict_implicit())
|
else if (binding_info(e).is_strict_implicit())
|
||||||
out() << "}}";
|
out() << "}}";
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in a new issue