X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fng_refiner%2FnCicCoercion.mli;h=ff6b439974c12f5dfc7b0eea9942629da09d9b93;hb=c471db7f3e949af87d9206861d9b36a13dfce45a;hp=73c88005c54e951385d127af692fcae23860bba8;hpb=dcdbb979433a61e2ef2842d96604098728824416;p=helm.git diff --git a/helm/software/components/ng_refiner/nCicCoercion.mli b/helm/software/components/ng_refiner/nCicCoercion.mli index 73c88005c..ff6b43997 100644 --- a/helm/software/components/ng_refiner/nCicCoercion.mli +++ b/helm/software/components/ng_refiner/nCicCoercion.mli @@ -13,22 +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 (list format) *) -val index_old_db: CoercDb.coerc_db -> db -> db - -val empty_db : db +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