refactor(frontends/lean): minor code reorg
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
43fa75f7a9
commit
6c442b250c
4 changed files with 37 additions and 37 deletions
|
@ -149,22 +149,6 @@ environment axiom_cmd(parser & p) {
|
||||||
return variable_cmd_core(p, true);
|
return variable_cmd_core(p, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sort local_names by order of occurrence in the section, and copy the associated parameters to section_ps
|
|
||||||
void mk_section_params(name_set const & local_names, parser const & p, buffer<expr> & section_ps) {
|
|
||||||
local_names.for_each([&](name const & n) {
|
|
||||||
section_ps.push_back(*p.get_local(n));
|
|
||||||
});
|
|
||||||
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));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Collect local (section) constants occurring in type and value, sort them, and store in section_ps
|
|
||||||
void collect_section_locals(expr const & type, expr const & value, parser const & p, buffer<expr> & section_ps) {
|
|
||||||
name_set ls = collect_locals(type, collect_locals(value));
|
|
||||||
return mk_section_params(ls, p, section_ps);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct decl_modifiers {
|
struct decl_modifiers {
|
||||||
bool m_is_private;
|
bool m_is_private;
|
||||||
bool m_is_opaque;
|
bool m_is_opaque;
|
||||||
|
@ -198,18 +182,6 @@ struct decl_modifiers {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Return the levels in \c ls that are defined in the section
|
|
||||||
levels collect_section_levels(level_param_names const & ls, parser & p) {
|
|
||||||
buffer<level> section_ls_buffer;
|
|
||||||
for (name const & l : ls) {
|
|
||||||
if (p.get_local_level_index(l))
|
|
||||||
section_ls_buffer.push_back(mk_param_univ(l));
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return to_list(section_ls_buffer.begin(), section_ls_buffer.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
environment definition_cmd_core(parser & p, bool is_theorem, bool _is_opaque) {
|
environment definition_cmd_core(parser & p, bool is_theorem, bool _is_opaque) {
|
||||||
name n = p.check_id_next("invalid declaration, identifier expected");
|
name n = p.check_id_next("invalid declaration, identifier expected");
|
||||||
check_atomic(n);
|
check_atomic(n);
|
||||||
|
|
|
@ -21,14 +21,5 @@ bool parse_univ_params(parser & p, buffer<name> & ps);
|
||||||
Then sort \c ls_buffer (using the order in which the universe levels were declared).
|
Then sort \c ls_buffer (using the order in which the universe levels were declared).
|
||||||
*/
|
*/
|
||||||
void update_univ_parameters(buffer<name> & ls_buffer, name_set const & found_ls, parser const & p);
|
void update_univ_parameters(buffer<name> & ls_buffer, name_set const & found_ls, parser const & p);
|
||||||
/**
|
|
||||||
\brief Copy the parameters associated with the local names in \c local_names to \c section_ps.
|
|
||||||
Then sort \c section_ps (using the order in which they were declared).
|
|
||||||
*/
|
|
||||||
void mk_section_params(name_set const & local_names, parser const & p, buffer<expr> & section_ps);
|
|
||||||
/**
|
|
||||||
\brief Return the levels in \c ls that are defined in the section.
|
|
||||||
*/
|
|
||||||
levels collect_section_levels(level_param_names const & ls, parser & p);
|
|
||||||
void register_decl_cmds(cmd_table & r);
|
void register_decl_cmds(cmd_table & r);
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ Author: Leonardo de Moura
|
||||||
*/
|
*/
|
||||||
#include "util/sstream.h"
|
#include "util/sstream.h"
|
||||||
#include "library/scoped_ext.h"
|
#include "library/scoped_ext.h"
|
||||||
|
#include "library/locals.h"
|
||||||
#include "frontends/lean/parser.h"
|
#include "frontends/lean/parser.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
|
@ -25,4 +26,32 @@ bool is_root_namespace(name const & n) {
|
||||||
name remove_root_prefix(name const & n) {
|
name remove_root_prefix(name const & n) {
|
||||||
return n.replace_prefix(g_root, name());
|
return n.replace_prefix(g_root, name());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sort local_names by order of occurrence in the section, and copy the associated parameters to section_ps
|
||||||
|
void mk_section_params(name_set const & local_names, parser const & p, buffer<expr> & section_ps) {
|
||||||
|
local_names.for_each([&](name const & n) {
|
||||||
|
section_ps.push_back(*p.get_local(n));
|
||||||
|
});
|
||||||
|
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 the levels in \c ls that are defined in the section
|
||||||
|
levels collect_section_levels(level_param_names const & ls, parser & p) {
|
||||||
|
buffer<level> section_ls_buffer;
|
||||||
|
for (name const & l : ls) {
|
||||||
|
if (p.get_local_level_index(l))
|
||||||
|
section_ls_buffer.push_back(mk_param_univ(l));
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return to_list(section_ls_buffer.begin(), section_ls_buffer.end());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Collect local (section) constants occurring in type and value, sort them, and store in section_ps
|
||||||
|
void collect_section_locals(expr const & type, expr const & value, parser const & p, buffer<expr> & section_ps) {
|
||||||
|
name_set ls = collect_locals(type, collect_locals(value));
|
||||||
|
return mk_section_params(ls, p, section_ps);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,4 +12,12 @@ void check_atomic(name const & n);
|
||||||
void check_in_section(parser const & p);
|
void check_in_section(parser const & p);
|
||||||
bool is_root_namespace(name const & n);
|
bool is_root_namespace(name const & n);
|
||||||
name remove_root_prefix(name const & n);
|
name remove_root_prefix(name const & n);
|
||||||
|
/** \brief Copy the parameters associated with the local names in \c local_names to \c section_ps.
|
||||||
|
Then sort \c section_ps (using the order in which they were declared).
|
||||||
|
*/
|
||||||
|
void mk_section_params(name_set const & local_names, parser const & p, buffer<expr> & section_ps);
|
||||||
|
/** \brief Return the levels in \c ls that are defined in the section. */
|
||||||
|
levels collect_section_levels(level_param_names const & ls, parser & p);
|
||||||
|
/** \brief Collect local (section) constants occurring in type and value, sort them, and store in section_ps */
|
||||||
|
void collect_section_locals(expr const & type, expr const & value, parser const & p, buffer<expr> & section_ps);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue