X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;ds=sidebyside;f=helm%2Fsoftware%2Fcomponents%2Fng_refiner%2FnCicCoercion.mli;h=ff6b439974c12f5dfc7b0eea9942629da09d9b93;hb=refs%2Fheads%2Fmatita-lablgtk3;hp=d01e30a5ad9d286e3735a24e38ce0cb974cd6087;hpb=62f476a05884d451bfb90d845ea2b1c0a1c77f96;p=helm.git diff --git a/helm/software/components/ng_refiner/nCicCoercion.mli b/helm/software/components/ng_refiner/nCicCoercion.mli index d01e30a5a..ff6b43997 100644 --- a/helm/software/components/ng_refiner/nCicCoercion.mli +++ b/helm/software/components/ng_refiner/nCicCoercion.mli @@ -13,20 +13,48 @@ type db +val set_convert_term: + (UriManager.uri -> Cic.term -> NCic.term * NCic.obj list) -> unit + +class type g_status = + object + inherit NCicUnifHint.g_status + method coerc_db: db + end + +class status : + object ('self) + inherit NCicUnifHint.status + inherit g_status + method coerc_db: db + method set_coerc_db: db -> 'self + method set_coercion_status: #g_status -> 'self + end + +val empty_db: db + (* index (\x.c ?? x ??): A -> B index_coercion db c A B \arity_left(c ??x??) \position(x,??x??) *) val index_coercion: - db -> NCic.term -> NCic.term -> NCic.term -> int -> int -> db + #status as 'status -> string -> + NCic.term -> NCic.term -> NCic.term -> int -> int -> 'status - (* gets the old imperative coercion DB *) -val db : unit -> db + (* gets the old imperative coercion DB (list format) *) +val index_old_db: CoercDb.coerc_db -> (#status as 'status) -> 'status val look_for_coercion: - db -> + #status -> NCic.metasenv -> NCic.substitution -> NCic.context -> (* inferred type, expected type *) NCic.term -> NCic.term -> - (* enriched metasenv, new term, its type, metavriable to + (* name, enriched metasenv, new term, its type, metavriable to * be unified with the old term *) - (NCic.metasenv * NCic.term * NCic.term * NCic.term) list + (string * NCic.metasenv * NCic.term * NCic.term * NCic.term) list + +(* returns (coercion,arity,arg) *) +val match_coercion: + #status -> metasenv:NCic.metasenv -> subst:NCic.substitution -> + context:NCic.context -> NCic.term -> (NCic.term * int * int) option + +val generate_dot_file: #status -> Format.formatter -> unit