feat(library/aliases): protected definitions in nested namespaces, closes #331
This commit is contained in:
parent
0443c1e70c
commit
d10bb92a7d
2 changed files with 27 additions and 6 deletions
|
@ -190,20 +190,20 @@ environment add_aliases(environment const & env, name const & prefix, name const
|
||||||
unsigned num_exceptions, name const * exceptions, bool overwrite) {
|
unsigned num_exceptions, name const * exceptions, bool overwrite) {
|
||||||
aliases_ext ext = get_extension(env);
|
aliases_ext ext = get_extension(env);
|
||||||
env.for_each_declaration([&](declaration const & d) {
|
env.for_each_declaration([&](declaration const & d) {
|
||||||
if (!is_protected(env, d.get_name()) &&
|
if (is_prefix_of(prefix, d.get_name()) && !is_exception(d.get_name(), prefix, num_exceptions, exceptions)) {
|
||||||
is_prefix_of(prefix, d.get_name()) && !is_exception(d.get_name(), prefix, num_exceptions, exceptions)) {
|
|
||||||
name a = d.get_name().replace_prefix(prefix, new_prefix);
|
name a = d.get_name().replace_prefix(prefix, new_prefix);
|
||||||
if (!a.is_anonymous())
|
if (!(is_protected(env, d.get_name()) && a.is_atomic()) &&
|
||||||
|
!(a.is_anonymous()))
|
||||||
ext.add_expr_alias(a, d.get_name(), overwrite);
|
ext.add_expr_alias(a, d.get_name(), overwrite);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
env.for_each_universe([&](name const & u) {
|
env.for_each_universe([&](name const & u) {
|
||||||
if (!is_protected(env, u) &&
|
if (is_prefix_of(prefix, u) && !is_exception(u, prefix, num_exceptions, exceptions)) {
|
||||||
is_prefix_of(prefix, u) && !is_exception(u, prefix, num_exceptions, exceptions)) {
|
|
||||||
name a = u.replace_prefix(prefix, new_prefix);
|
name a = u.replace_prefix(prefix, new_prefix);
|
||||||
if (env.is_universe(a))
|
if (env.is_universe(a))
|
||||||
throw exception(sstream() << "universe level alias '" << a << "' shadows existing global universe level");
|
throw exception(sstream() << "universe level alias '" << a << "' shadows existing global universe level");
|
||||||
if (!a.is_anonymous())
|
if (!(is_protected(env, u) && a.is_atomic()) &&
|
||||||
|
!a.is_anonymous())
|
||||||
ext.add_level_alias(a, u);
|
ext.add_level_alias(a, u);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
21
tests/lean/run/331.lean
Normal file
21
tests/lean/run/331.lean
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
namespace nat
|
||||||
|
inductive less (a : nat) : nat → Prop :=
|
||||||
|
base : less a (succ a),
|
||||||
|
step : Π {b}, less a b → less a (succ b)
|
||||||
|
|
||||||
|
end nat
|
||||||
|
|
||||||
|
open nat
|
||||||
|
check less.rec_on
|
||||||
|
|
||||||
|
namespace foo1
|
||||||
|
protected definition foo2.bar := 10
|
||||||
|
end foo1
|
||||||
|
|
||||||
|
example : foo1.foo2.bar = 10 :=
|
||||||
|
rfl
|
||||||
|
|
||||||
|
open foo1
|
||||||
|
|
||||||
|
example : foo2.bar = 10 :=
|
||||||
|
rfl
|
Loading…
Reference in a new issue