Mod_typingSourceMain functions for translating module entries
translate_module produces a module_body out of a module_entry. In the output fields:
mod_expr is Abstract for a MType entry, or Algebraic for MExpr.mod_type_alg is None only for a MExpr without explicit signature.val translate_module :
'a Reduction.universe_state ->
Environ.env ->
Names.ModPath.t ->
Entries.inline ->
Entries.module_entry ->
Declarations.module_body * 'atranslate_modtype produces a module_type_body whose mod_type_alg cannot be None (and of course mod_expr is Abstract).
val translate_modtype :
'a Reduction.universe_state ->
Environ.env ->
Names.ModPath.t ->
Entries.inline ->
Entries.module_type_entry ->
Declarations.module_type_body * 'aLow-level function for translating a module struct entry :
ModPath.t is given, otherwise to a module type.type 'alg translation =
Declarations.module_signature
* 'alg
* Mod_subst.delta_resolver
* Univ.Constraints.tval translate_mse :
'a Reduction.universe_state ->
Environ.env ->
Names.ModPath.t option ->
Entries.inline ->
Entries.module_struct_entry ->
Declarations.module_signature
* (Constr.t * Univ.AbstractContext.t option) Declarations.module_alg_expr
* Mod_subst.delta_resolver
* 'aFrom an already-translated (or interactive) implementation and an (optional) signature entry, produces a final module_body
val finalize_module :
'a Reduction.universe_state ->
Environ.env ->
Names.ModPath.t ->
(Declarations.module_signature
* Declarations.module_expression option
* Mod_subst.delta_resolver) ->
(Entries.module_type_entry * Entries.inline) option ->
Declarations.module_body * 'atranslate_mse_incl translate the mse of a module or module type given to an Include
val translate_mse_include :
bool ->
'a Reduction.universe_state ->
Environ.env ->
Names.ModPath.t ->
Entries.inline ->
Entries.module_struct_entry ->
Declarations.module_signature * unit * Mod_subst.delta_resolver * 'a