fix(library/scope): make sure local levels are added in the beginning of the universe parameter list

The idea is to make sure it is consistent with the behavior used for regular local parameters.

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-06-02 14:06:27 -07:00
parent e9664cb042
commit b6d2328c1d
2 changed files with 14 additions and 2 deletions

View file

@ -90,7 +90,7 @@ public:
if (info.m_local) { if (info.m_local) {
return some_expr(update_constant(e, levels())); return some_expr(update_constant(e, levels()));
} else { } else {
return some_expr(mk_app(update_constant(e, append(const_levels(e), info.m_levels)), info.m_var_deps)); return some_expr(mk_app(update_constant(e, append(info.m_levels, const_levels(e))), info.m_var_deps));
} }
} else { } else {
levels new_ls = map(const_levels(e), [&](level const & l) { return convert(l); }); levels new_ls = map(const_levels(e), [&](level const & l) { return convert(l); });
@ -176,7 +176,7 @@ public:
expr new_type = convert(d.get_type()); expr new_type = convert(d.get_type());
expr new_value = convert(d.get_value()); expr new_value = convert(d.get_value());
level_param_names level_deps = mk_level_deps(); level_param_names level_deps = mk_level_deps();
level_param_names new_ls = append(d.get_params(), level_deps); level_param_names new_ls = append(level_deps, d.get_params());
dependencies var_deps = mk_var_deps(); dependencies var_deps = mk_var_deps();
new_type = Pi(new_type, var_deps); new_type = Pi(new_type, var_deps);
new_value = Fun(new_value, var_deps); new_value = Fun(new_value, var_deps);

12
tests/lua/sect1b.lua Normal file
View file

@ -0,0 +1,12 @@
local env = environment()
env = env:begin_section_scope()
env = env:add_global_level("l")
local l = mk_global_univ("l")
local l1 = mk_param_univ("l1")
env = add_decl(env, mk_definition("A", {l1}, mk_sort(max_univ(l, l1)+1), mk_sort(max_univ(l, l1))))
env = env:end_scope()
local ls = env:find("A"):univ_params()
assert(#ls == 2)
print(ls:head())
assert(ls:head() == name("l"))
assert(ls:tail():head() == name("l1"))