fix(frontends/lean): name clash inside section, fixes #181

This commit is contained in:
Leonardo de Moura 2014-09-11 16:37:23 -07:00
parent 5cff53c447
commit 7ffe73b8ca
7 changed files with 19 additions and 6 deletions

View file

@ -14,7 +14,7 @@ section
parameters {A : Type} {B : A → Type} parameters {A : Type} {B : A → Type}
abbreviation dpr1 (p : Σ x, B x) : A := rec (λ a b, a) p abbreviation dpr1 (p : Σ x, B x) : A := rec (λ a b, a) p
abbreviation dpr2 {A : Type} {B : A → Type} (p : Σ x, B x) : B (dpr1 p) := rec (λ a b, b) p abbreviation dpr2 (p : Σ x, B x) : B (dpr1 p) := rec (λ a b, b) p
theorem dpr1_dpair (a : A) (b : B a) : dpr1 (dpair a b) = a := rfl theorem dpr1_dpair (a : A) (b : B a) : dpr1 (dpair a b) = a := rfl
theorem dpr2_dpair (a : A) (b : B a) : dpr2 (dpair a b) = b := rfl theorem dpr2_dpair (a : A) (b : B a) : dpr2 (dpair a b) = b := rfl

View file

@ -349,7 +349,7 @@ static expr parse_including_expr(parser & p, unsigned, expr const *, pos_info co
buffer<expr> new_locals; buffer<expr> new_locals;
for (auto old_l : locals) { for (auto old_l : locals) {
binder_info bi = mk_contextual_info(true); binder_info bi = mk_contextual_info(true);
expr new_l = p.save_pos(mk_local(local_pp_name(old_l), mk_as_is(mlocal_type(old_l)), bi), pos); expr new_l = p.save_pos(mk_local(p.mk_fresh_name(), local_pp_name(old_l), mk_as_is(mlocal_type(old_l)), bi), pos);
p.add_local(new_l); p.add_local(new_l);
new_locals.push_back(new_l); new_locals.push_back(new_l);
} }

View file

@ -81,7 +81,9 @@ static environment declare_var(parser & p, environment env,
binder_info bi; binder_info bi;
if (_bi) bi = *_bi; if (_bi) bi = *_bi;
if (in_section_or_context(p.env())) { if (in_section_or_context(p.env())) {
p.add_local(p.save_pos(mk_local(n, type, bi), pos)); name u = p.mk_fresh_name();
expr l = p.save_pos(mk_local(u, n, type, bi), pos);
p.add_local_expr(n, l);
return env; return env;
} else { } else {
name const & ns = get_namespace(env); name const & ns = get_namespace(env);

View file

@ -936,7 +936,8 @@ public:
} }
std::tuple<expr, expr, level_param_names> operator()(expr const & t, expr const & v, name const & n, bool is_opaque) { std::tuple<expr, expr, level_param_names> operator()(expr const & t, expr const & v, name const & n, bool is_opaque) {
lean_assert(!has_local(t)); lean_assert(!has_local(v)); lean_assert(!has_local(t));
lean_assert(!has_local(v));
constraint_seq t_cs; constraint_seq t_cs;
expr r_t = ensure_type(visit(t, t_cs), t_cs); expr r_t = ensure_type(visit(t, t_cs), t_cs);
// Opaque definitions in the main module may treat other opaque definitions (in the main module) as transparent. // Opaque definitions in the main module may treat other opaque definitions (in the main module) as transparent.

View file

@ -28,7 +28,11 @@ class local_decls {
public: public:
local_decls():m_counter(1) {} local_decls():m_counter(1) {}
local_decls(local_decls const & d):m_map(d.m_map), m_counter(d.m_counter), m_scopes(d.m_scopes) {} local_decls(local_decls const & d):m_map(d.m_map), m_counter(d.m_counter), m_scopes(d.m_scopes) {}
void insert(name const & k, V const & v) { m_map.insert(k, mk_pair(v, m_counter)); m_counter++; m_values = cons(v, m_values); } void insert(name const & k, V const & v) {
m_map.insert(k, mk_pair(v, m_counter));
m_counter++;
m_values = cons(v, m_values);
}
V const * find(name const & k) const { auto it = m_map.find(k); return it ? &(it->first) : nullptr; } V const * find(name const & k) const { auto it = m_map.find(k); return it ? &(it->first) : nullptr; }
unsigned find_idx(name const & k) const { auto it = m_map.find(k); return it ? it->second : 0; } unsigned find_idx(name const & k) const { auto it = m_map.find(k); return it ? it->second : 0; }
bool contains(name const & k) const { return m_map.contains(k); } bool contains(name const & k) const { return m_map.contains(k); }

View file

@ -38,7 +38,7 @@ void sort_section_params(expr_struct_set const & locals, parser const & p, buffe
for (expr const & l : locals) for (expr const & l : locals)
section_ps.push_back(l); section_ps.push_back(l);
std::sort(section_ps.begin(), section_ps.end(), [&](expr const & p1, expr const & p2) { std::sort(section_ps.begin(), section_ps.end(), [&](expr const & p1, expr const & p2) {
return p.get_local_index(mlocal_name(p1)) < p.get_local_index(mlocal_name(p2)); return p.get_local_index(local_pp_name(p1)) < p.get_local_index(local_pp_name(p2));
}); });
} }

View file

@ -0,0 +1,6 @@
section
parameter (A : Type)
definition foo := A
theorem bar {X : Type} {A : X} : foo :=
sorry
end