X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic%2FcicUtil.mli;h=4deec72419f148f292f75cbda418f4e0d5e3a830;hb=03d2302343e8e1b282c1b2afec8db7913413d9d1;hp=29657f401874ca46c865727666ffec8295bd02e7;hpb=e51a16c072144e4cabc8fc70841aa4e94a9325b6;p=helm.git diff --git a/helm/ocaml/cic/cicUtil.mli b/helm/ocaml/cic/cicUtil.mli index 29657f401..4deec7241 100644 --- a/helm/ocaml/cic/cicUtil.mli +++ b/helm/ocaml/cic/cicUtil.mli @@ -36,5 +36,33 @@ val clean_up_local_context : val is_closed : Cic.term -> bool val is_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 +