fix(frontends/lean/builtin_cmds): issue #597
This commit is contained in:
parent
7f608fd907
commit
ed388b00f1
1 changed files with 8 additions and 1 deletions
|
@ -644,6 +644,7 @@ static environment add_abbrev(parser & p, environment const & env, name const &
|
||||||
// open/export [class] id (as id)? (id ...) (renaming id->id id->id) (hiding id ... id)
|
// open/export [class] id (as id)? (id ...) (renaming id->id id->id) (hiding id ... id)
|
||||||
environment open_export_cmd(parser & p, bool open) {
|
environment open_export_cmd(parser & p, bool open) {
|
||||||
environment env = p.env();
|
environment env = p.env();
|
||||||
|
unsigned fingerprint = 0;
|
||||||
while (true) {
|
while (true) {
|
||||||
buffer<name> metacls;
|
buffer<name> metacls;
|
||||||
parse_metaclasses(p, metacls);
|
parse_metaclasses(p, metacls);
|
||||||
|
@ -652,8 +653,11 @@ environment open_export_cmd(parser & p, bool open) {
|
||||||
std::find(metacls.begin(), metacls.end(), get_decls_tk()) != metacls.end() ||
|
std::find(metacls.begin(), metacls.end(), get_decls_tk()) != metacls.end() ||
|
||||||
std::find(metacls.begin(), metacls.end(), get_declarations_tk()) != metacls.end())
|
std::find(metacls.begin(), metacls.end(), get_declarations_tk()) != metacls.end())
|
||||||
decls = true;
|
decls = true;
|
||||||
|
for (name const & n : metacls)
|
||||||
|
fingerprint = hash(fingerprint, n.hash());
|
||||||
auto pos = p.pos();
|
auto pos = p.pos();
|
||||||
name ns = p.check_id_next("invalid 'open/export' command, identifier expected");
|
name ns = p.check_id_next("invalid 'open/export' command, identifier expected");
|
||||||
|
fingerprint = hash(fingerprint, ns.hash());
|
||||||
optional<name> real_ns = to_valid_namespace_name(env, ns);
|
optional<name> real_ns = to_valid_namespace_name(env, ns);
|
||||||
if (!real_ns)
|
if (!real_ns)
|
||||||
throw parser_error(sstream() << "invalid namespace name '" << ns << "'", pos);
|
throw parser_error(sstream() << "invalid namespace name '" << ns << "'", pos);
|
||||||
|
@ -680,6 +684,7 @@ environment open_export_cmd(parser & p, bool open) {
|
||||||
p.next();
|
p.next();
|
||||||
p.check_token_next(get_arrow_tk(), "invalid 'open/export' command renaming, '->' expected");
|
p.check_token_next(get_arrow_tk(), "invalid 'open/export' command renaming, '->' expected");
|
||||||
name to_id = p.check_id_next("invalid 'open/export' command renaming, identifier expected");
|
name to_id = p.check_id_next("invalid 'open/export' command renaming, identifier expected");
|
||||||
|
fingerprint = hash(hash(fingerprint, from_id.hash()), to_id.hash());
|
||||||
check_identifier(p, env, ns, from_id);
|
check_identifier(p, env, ns, from_id);
|
||||||
exceptions.push_back(from_id);
|
exceptions.push_back(from_id);
|
||||||
if (open)
|
if (open)
|
||||||
|
@ -694,12 +699,14 @@ environment open_export_cmd(parser & p, bool open) {
|
||||||
p.next();
|
p.next();
|
||||||
check_identifier(p, env, ns, id);
|
check_identifier(p, env, ns, id);
|
||||||
exceptions.push_back(id);
|
exceptions.push_back(id);
|
||||||
|
fingerprint = hash(fingerprint, id.hash());
|
||||||
}
|
}
|
||||||
} else if (p.curr_is_identifier()) {
|
} else if (p.curr_is_identifier()) {
|
||||||
found_explicit = true;
|
found_explicit = true;
|
||||||
while (p.curr_is_identifier()) {
|
while (p.curr_is_identifier()) {
|
||||||
name id = p.get_name_val();
|
name id = p.get_name_val();
|
||||||
p.next();
|
p.next();
|
||||||
|
fingerprint = hash(fingerprint, id.hash());
|
||||||
check_identifier(p, env, ns, id);
|
check_identifier(p, env, ns, id);
|
||||||
if (open)
|
if (open)
|
||||||
env = add_expr_alias(env, as+id, ns+id);
|
env = add_expr_alias(env, as+id, ns+id);
|
||||||
|
@ -736,7 +743,7 @@ environment open_export_cmd(parser & p, bool open) {
|
||||||
if (!p.curr_is_token(get_lbracket_tk()) && !p.curr_is_identifier())
|
if (!p.curr_is_token(get_lbracket_tk()) && !p.curr_is_identifier())
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return env;
|
return update_fingerprint(env, fingerprint);
|
||||||
}
|
}
|
||||||
environment open_cmd(parser & p) { return open_export_cmd(p, true); }
|
environment open_cmd(parser & p) { return open_export_cmd(p, true); }
|
||||||
environment export_cmd(parser & p) { return open_export_cmd(p, false); }
|
environment export_cmd(parser & p) { return open_export_cmd(p, false); }
|
||||||
|
|
Loading…
Reference in a new issue