feat(frontends/lean): add helper function mk_section_local_ref
This commit is contained in:
parent
d445857f56
commit
f7bbe09db2
4 changed files with 15 additions and 6 deletions
|
@ -362,10 +362,8 @@ environment definition_cmd_core(parser & p, bool is_theorem, bool is_opaque, boo
|
||||||
ls = to_list(ls_buffer.begin(), ls_buffer.end());
|
ls = to_list(ls_buffer.begin(), ls_buffer.end());
|
||||||
levels section_ls = collect_section_nonvar_levels(p, ls);
|
levels section_ls = collect_section_nonvar_levels(p, ls);
|
||||||
remove_section_variables(p, section_ps);
|
remove_section_variables(p, section_ps);
|
||||||
for (expr & param : section_ps)
|
|
||||||
param = mk_explicit(param);
|
|
||||||
if (!section_ps.empty()) {
|
if (!section_ps.empty()) {
|
||||||
expr ref = mk_implicit(mk_app(mk_explicit(mk_constant(real_n, section_ls)), section_ps));
|
expr ref = mk_section_local_ref(real_n, section_ls, section_ps.size(), section_ps.data());
|
||||||
p.add_local_expr(n, ref);
|
p.add_local_expr(n, ref);
|
||||||
} else if (section_ls) {
|
} else if (section_ls) {
|
||||||
expr ref = mk_constant(real_n, section_ls);
|
expr ref = mk_constant(real_n, section_ls);
|
||||||
|
|
|
@ -594,9 +594,7 @@ struct inductive_cmd_fn {
|
||||||
else
|
else
|
||||||
id = name(full_id.get_string());
|
id = name(full_id.get_string());
|
||||||
if (in_section_or_context(env)) {
|
if (in_section_or_context(env)) {
|
||||||
expr r = mk_explicit(mk_constant(full_id, section_levels));
|
expr r = mk_section_local_ref(full_id, section_levels, section_params.size(), section_params.data());
|
||||||
r = mk_app(r, section_params);
|
|
||||||
r = mk_implicit(r);
|
|
||||||
m_p.add_local_expr(id, r);
|
m_p.add_local_expr(id, r);
|
||||||
}
|
}
|
||||||
if (full_id != id)
|
if (full_id != id)
|
||||||
|
|
|
@ -107,6 +107,13 @@ list<expr> locals_to_context(expr const & e, parser const & p) {
|
||||||
return to_list(locals.begin(), locals.end());
|
return to_list(locals.begin(), locals.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
expr mk_section_local_ref(name const & n, levels const & sec_ls, unsigned num_sec_params, expr const * sec_params) {
|
||||||
|
buffer<expr> params;
|
||||||
|
for (unsigned i = 0; i < num_sec_params; i++)
|
||||||
|
params.push_back(mk_explicit(sec_params[i]));
|
||||||
|
return mk_implicit(mk_app(mk_explicit(mk_constant(n, sec_ls)), params));
|
||||||
|
}
|
||||||
|
|
||||||
expr Fun(buffer<expr> const & locals, expr const & e, parser & p) {
|
expr Fun(buffer<expr> const & locals, expr const & e, parser & p) {
|
||||||
bool use_cache = false;
|
bool use_cache = false;
|
||||||
return p.rec_save_pos(Fun(locals, e, use_cache), p.pos_of(e));
|
return p.rec_save_pos(Fun(locals, e, use_cache), p.pos_of(e));
|
||||||
|
|
|
@ -31,6 +31,12 @@ void sort_section_params(expr_struct_set const & locals, parser const & p, buffe
|
||||||
/** \brief Remove from \c ps local constants that are tagged as section variables. */
|
/** \brief Remove from \c ps local constants that are tagged as section variables. */
|
||||||
void remove_section_variables(parser const & p, buffer<expr> & ps);
|
void remove_section_variables(parser const & p, buffer<expr> & ps);
|
||||||
list<expr> locals_to_context(expr const & e, parser const & p);
|
list<expr> locals_to_context(expr const & e, parser const & p);
|
||||||
|
/** \brief Create the term <tt>(@^-1 (@n.{sec_ls} @sec_params[0] ... @sec_params[num_sec_params-1]))</tt>
|
||||||
|
When we declare \c n inside of a section, the section parameters and universes are fixes.
|
||||||
|
That is, when the user writes \c n inside the section she is really getting the term returned by this function.
|
||||||
|
*/
|
||||||
|
expr mk_section_local_ref(name const & n, levels const & sec_ls, unsigned num_sec_params, expr const * sec_params);
|
||||||
|
|
||||||
/** \brief Fun(locals, e), but also propagate \c e position to result */
|
/** \brief Fun(locals, e), but also propagate \c e position to result */
|
||||||
expr Fun(buffer<expr> const & locals, expr const & e, parser & p);
|
expr Fun(buffer<expr> const & locals, expr const & e, parser & p);
|
||||||
/** \brief Pi(locals, e), but also propagate \c e position to result */
|
/** \brief Pi(locals, e), but also propagate \c e position to result */
|
||||||
|
|
Loading…
Reference in a new issue