X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Flibrary%2FcoercDb.mli;h=130987df84ae8badbe70efcdb1209e46c74ad570;hb=82f61808091c59aa884eb232b96ee1c655dcb39a;hp=95dd96c0b18a2fd9a3849a8b707b74b1e1a7e38a;hpb=bdf989481462c1185c9cbbfdd4b31d13aa4352b3;p=helm.git diff --git a/helm/software/components/library/coercDb.mli b/helm/software/components/library/coercDb.mli index 95dd96c0b..130987df8 100644 --- a/helm/software/components/library/coercDb.mli +++ b/helm/software/components/library/coercDb.mli @@ -24,40 +24,41 @@ *) - (** THIS MODULE SHOULD BE USED ONLY BY CoercGraph/CicCoercion/librarySync - * - * and may be merged with CicCoercion... - * - * **) - - - (** XXX WARNING: non-reentrant *) -type coerc_carr = +type coerc_carr = private | Uri of UriManager.uri (* const, mutind, mutconstr *) | Sort of Cic.sort (* Prop, Set, Type *) - | Term of Cic.term (* nothing supported *) + | Fun of int + | Dead +;; -exception EqCarrNotImplemented of string Lazy.t -exception EqCarrOnNonMetaClosed -val eq_carr: coerc_carr -> coerc_carr -> bool -val coerc_carr_of_term: Cic.term -> coerc_carr -val name_of_carr: coerc_carr -> string +val eq_carr: ?exact:bool -> coerc_carr -> coerc_carr -> bool +val string_of_carr: coerc_carr -> string + +(* takes a term in whnf ~delta:false and a desired ariety *) +val coerc_carr_of_term: Cic.term -> int -> coerc_carr val to_list: unit -> - (coerc_carr * coerc_carr * UriManager.uri list) list + (coerc_carr * coerc_carr * (UriManager.uri * int * int) list) list -val add_coercion: - coerc_carr * coerc_carr * UriManager.uri -> unit +type coerc_db +val dump: unit -> coerc_db +val restore: coerc_db -> unit -val remove_coercion: - (coerc_carr * coerc_carr * UriManager.uri -> bool) -> unit +(* src carr, tgt carr, uri, saturations, coerced position + * invariant: + * if the constant pointed by uri has n argments + * n = coerced position + saturations + FunClass arity + *) + +type saturations = int +type coerced_pos = int +type coercion_entry = + coerc_carr * coerc_carr * UriManager.uri * saturations * coerced_pos +val add_coercion: coercion_entry -> unit +val remove_coercion: (coercion_entry -> bool) -> unit val find_coercion: - (coerc_carr * coerc_carr -> bool) -> UriManager.uri list + (coerc_carr * coerc_carr -> bool) -> (UriManager.uri * int) list -val is_a_coercion: UriManager.uri -> bool -val get_carr: UriManager.uri -> coerc_carr * coerc_carr - -val term_of_carr: coerc_carr -> Cic.term - +val is_a_coercion: Cic.term -> coercion_entry option