2015-04-22 05:40:20 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
|
|
|
#include <string>
|
|
|
|
#include "library/scoped_ext.h"
|
|
|
|
|
|
|
|
namespace lean {
|
|
|
|
/*
|
|
|
|
When we declare a definition in a section, we create an alias for it that fixes the parameters in
|
|
|
|
universe parameters. We have to store the number of parameters and universes that have been fixed
|
|
|
|
to be able to correctly pretty print terms.
|
|
|
|
*/
|
|
|
|
struct local_ref_entry {
|
|
|
|
name m_name;
|
2015-05-29 21:07:38 +00:00
|
|
|
expr m_ref;
|
2015-04-22 05:40:20 +00:00
|
|
|
local_ref_entry() {}
|
2015-05-29 21:07:38 +00:00
|
|
|
local_ref_entry(name const & n, expr const & ref):
|
|
|
|
m_name(n), m_ref(ref) {}
|
2015-04-22 05:40:20 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static name * g_local_ref_name = nullptr;
|
|
|
|
static std::string * g_key = nullptr;
|
|
|
|
|
|
|
|
struct local_ref_config {
|
2015-05-29 21:07:38 +00:00
|
|
|
typedef name_map<expr> state;
|
|
|
|
typedef local_ref_entry entry;
|
2015-04-22 05:40:20 +00:00
|
|
|
|
|
|
|
static void add_entry(environment const &, io_state const &, state & s, entry const & e) {
|
2015-05-29 21:07:38 +00:00
|
|
|
s.insert(e.m_name, e.m_ref);
|
2015-04-22 05:40:20 +00:00
|
|
|
}
|
|
|
|
static name const & get_class_name() {
|
|
|
|
return *g_local_ref_name;
|
|
|
|
}
|
|
|
|
static std::string const & get_serialization_key() {
|
|
|
|
return *g_key;
|
|
|
|
}
|
|
|
|
static void write_entry(serializer &, entry const &) {
|
|
|
|
lean_unreachable();
|
|
|
|
}
|
|
|
|
static entry read_entry(deserializer &) {
|
|
|
|
lean_unreachable();
|
|
|
|
}
|
|
|
|
static optional<unsigned> get_fingerprint(entry const &) {
|
|
|
|
return optional<unsigned>();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
template class scoped_ext<local_ref_config>;
|
|
|
|
typedef scoped_ext<local_ref_config> local_ref_ext;
|
|
|
|
|
2015-05-29 21:07:38 +00:00
|
|
|
environment save_local_ref_info(environment const & env, name const & n, expr const & ref) {
|
2015-04-22 05:40:20 +00:00
|
|
|
bool persistent = false;
|
2015-12-05 18:28:01 +00:00
|
|
|
return local_ref_ext::add_entry(env, get_dummy_ios(), local_ref_entry(n, ref), get_namespace(env), persistent);
|
2015-04-22 05:40:20 +00:00
|
|
|
}
|
|
|
|
|
2015-05-29 21:07:38 +00:00
|
|
|
optional<expr> get_local_ref_info(environment const & env, name const & n) {
|
2015-04-22 05:40:20 +00:00
|
|
|
if (auto r = local_ref_ext::get_state(env).find(n))
|
2015-05-29 21:07:38 +00:00
|
|
|
return some_expr(*r);
|
2015-04-22 05:40:20 +00:00
|
|
|
else
|
2015-05-29 21:07:38 +00:00
|
|
|
return none_expr();
|
2015-04-22 05:40:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void initialize_local_ref_info() {
|
|
|
|
g_local_ref_name = new name("localrefinfo");
|
|
|
|
g_key = new std::string("localrefinfo");
|
|
|
|
local_ref_ext::initialize();
|
|
|
|
}
|
|
|
|
|
|
|
|
void finalize_local_ref_info() {
|
|
|
|
local_ref_ext::finalize();
|
|
|
|
delete g_local_ref_name;
|
|
|
|
delete g_key;
|
|
|
|
}
|
|
|
|
}
|