exception Subst_not_found of int
val lookup_meta: int -> Cic.metasenv -> Cic.conjecture
-val lookup_subst: int -> Cic.substitution -> Cic.context * Cic.term
+val lookup_subst: int -> Cic.substitution -> Cic.context * Cic.term * Cic.term
val exists_meta: int -> Cic.metasenv -> bool
val clean_up_local_context :
Cic.substitution -> Cic.metasenv -> int -> (Cic.term option) list
-> (Cic.term option) list
val is_closed : Cic.term -> bool
+val is_meta_closed : Cic.term -> bool
-val meta_closed : Cic.term -> bool
-
+ (** @raise UriManager.IllFormedUri *)
val term_of_uri: string -> Cic.term
+ (** packing/unpacking of several terms into a single one *)
+val pack: Cic.term list -> Cic.term
+val unpack: Cic.term -> Cic.term list
+
+ (** @raise Failure "not enough prods" *)
+val strip_prods: int -> Cic.term -> Cic.term
+
+(** {2 Cic selectors} *)
+
+val params_of_obj: Cic.obj -> UriManager.uri list
+val attributes_of_obj: Cic.obj -> Cic.attribute list
+
+(** {2 Contexts}
+ * A context is a Cic term in which Cic.Implicit terms annotated with `Hole
+ * appears *)
+
+(** create a context from a term and a list of subterm.
+* @param equality equality function used while walking the term. Defaults to
+* physical equality (==) *)
+val context_of:
+ ?equality:(Cic.term -> Cic.term -> bool) -> term:Cic.term -> Cic.term list ->
+ Cic.term
+
+(** select all subterms of a given term matching a given context (i.e. subtrees
+* rooted at context's holes *)
+val select: term:Cic.term -> context:Cic.term -> Cic.term list
+