feat(library/module): provide predicate module::is_definition

This commit is contained in:
Leonardo de Moura 2014-09-17 16:28:22 -07:00
parent 9733401c20
commit 1fbb554a16
2 changed files with 33 additions and 19 deletions

View file

@ -38,6 +38,7 @@ typedef pair<std::string, std::function<void(serializer &)>> writer;
struct module_ext : public environment_extension { struct module_ext : public environment_extension {
list<module_name> m_direct_imports; list<module_name> m_direct_imports;
list<writer> m_writers; list<writer> m_writers;
name_set m_module_defs;
}; };
struct module_ext_reg { struct module_ext_reg {
@ -140,17 +141,34 @@ environment add_universe(environment const & env, name const & l) {
return add(new_env, g_glvl_key, [=](serializer & s) { s << l; }); return add(new_env, g_glvl_key, [=](serializer & s) { s << l; });
} }
environment update_module_defs(environment const & env, declaration const & d) {
if (d.is_definition() && !d.is_theorem()) {
module_ext ext = get_extension(env);
ext.m_module_defs.insert(d.get_name());
return update(env, ext);
} else {
return env;
}
}
environment add(environment const & env, certified_declaration const & d) { environment add(environment const & env, certified_declaration const & d) {
environment new_env = env.add(d); environment new_env = env.add(d);
declaration _d = d.get_declaration(); declaration _d = d.get_declaration();
new_env = update_module_defs(new_env, _d);
return add(new_env, g_decl_key, [=](serializer & s) { s << _d; }); return add(new_env, g_decl_key, [=](serializer & s) { s << _d; });
} }
environment add(environment const & env, declaration const & d) { environment add(environment const & env, declaration const & d) {
environment new_env = env.add(d); environment new_env = env.add(d);
new_env = update_module_defs(new_env, d);
return add(new_env, g_decl_key, [=](serializer & s) { s << d; }); return add(new_env, g_decl_key, [=](serializer & s) { s << d; });
} }
bool is_definition(environment const & env, name const & n) {
module_ext const & ext = get_extension(env);
return ext.m_module_defs.contains(n);
}
static std::string g_inductive("ind"); static std::string g_inductive("ind");
environment add_inductive(environment env, environment add_inductive(environment env,

View file

@ -31,8 +31,7 @@ public:
optional<unsigned> const & get_k() const { return m_relative; } optional<unsigned> const & get_k() const { return m_relative; }
}; };
/** /** \brief Return an environment based on \c env, where all modules in \c modules are imported.
\brief Return an environment based on \c env, where all modules in \c modules are imported.
Modules included directly or indirectly by them are also imported. Modules included directly or indirectly by them are also imported.
The environment \c env is usually an empty environment. The environment \c env is usually an empty environment.
@ -44,9 +43,7 @@ environment import_modules(environment const & env, std::string const & base, un
environment import_module(environment const & env, std::string const & base, module_name const & module, environment import_module(environment const & env, std::string const & base, module_name const & module,
unsigned num_threads, bool keep_proofs, io_state const & ios); unsigned num_threads, bool keep_proofs, io_state const & ios);
/** /** \brief Store/Export module using \c env to the output stream \c out. */
\brief Store/Export module using \c env to the output stream \c out.
*/
void export_module(std::ostream & out, environment const & env); void export_module(std::ostream & out, environment const & env);
/** \brief An asynchronous update. It goes into a task queue, and can be executed by a different execution thread. */ /** \brief An asynchronous update. It goes into a task queue, and can be executed by a different execution thread. */
@ -59,8 +56,7 @@ typedef std::function<void(shared_environment & env)> asynch_update_fn;
*/ */
typedef std::function<environment(environment const & env, io_state const & ios)> delayed_update_fn; typedef std::function<environment(environment const & env, io_state const & ios)> delayed_update_fn;
/** /** \brief A reader for importing data from a stream using deserializer \c d.
\brief A reader for importing data from a stream using deserializer \c d.
There are three ways to update the environment being constructed. There are three ways to update the environment being constructed.
1- Direct update it using \c senv. 1- Direct update it using \c senv.
2- Asynchronous update using add_asynch_update. 2- Asynchronous update using add_asynch_update.
@ -70,8 +66,7 @@ typedef void (*module_object_reader)(deserializer & d, module_idx midx, shared_e
std::function<void(asynch_update_fn const &)> & add_asynch_update, std::function<void(asynch_update_fn const &)> & add_asynch_update,
std::function<void(delayed_update_fn const &)> & add_delayed_update); std::function<void(delayed_update_fn const &)> & add_delayed_update);
/** /** \brief Register a module object reader. The key \c k is used to identify the class of objects
\brief Register a module object reader. The key \c k is used to identify the class of objects
that can be read by the given reader. that can be read by the given reader.
*/ */
void register_module_object_reader(std::string const & k, module_object_reader r); void register_module_object_reader(std::string const & k, module_object_reader r);
@ -84,8 +79,7 @@ struct register_module_object_reader_fn {
}; };
namespace module { namespace module {
/** /** \brief Add a function that should be invoked when the environment is exported.
\brief Add a function that should be invoked when the environment is exported.
The key \c k identifies which module_object_reader should be used to deserialize the object The key \c k identifies which module_object_reader should be used to deserialize the object
when the module is imported. when the module is imported.
@ -98,12 +92,14 @@ environment add_universe(environment const & env, name const & l);
/** \brief Add the given declaration to the environment, and mark it to be exported. */ /** \brief Add the given declaration to the environment, and mark it to be exported. */
environment add(environment const & env, certified_declaration const & d); environment add(environment const & env, certified_declaration const & d);
/** /** \brief Add the given declaration to the environment, and mark it to be exported.
\brief Add the given declaration to the environment, and mark it to be exported.
This method throws an exception if the trust_level <= LEAN_BELIEVER_TRUST_LEVEL This method throws an exception if the trust_level <= LEAN_BELIEVER_TRUST_LEVEL
*/ */
environment add(environment const & env, declaration const & d); environment add(environment const & env, declaration const & d);
/** \brief Return true iff \c n is a definition added to the current module using #module::add */
bool is_definition(environment const & env, name const & n);
/** \brief Add the given inductive declaration to the environment, and mark it to be exported. */ /** \brief Add the given inductive declaration to the environment, and mark it to be exported. */
environment add_inductive(environment env, environment add_inductive(environment env,
level_param_names const & level_params, level_param_names const & level_params,