X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic_unification%2FcicMkImplicit.mli;h=476270144c9de7cef4b1b3c8512b21ae4f47fcc0;hb=4167cea65ca58897d1a3dbb81ff95de5074700cc;hp=a698386b5656bf5b17be8206ce913a34f368fc79;hpb=044618edc33fa1cf00ec345e84c2a62939746751;p=helm.git diff --git a/helm/ocaml/cic_unification/cicMkImplicit.mli b/helm/ocaml/cic_unification/cicMkImplicit.mli index a698386b5..476270144 100644 --- a/helm/ocaml/cic_unification/cicMkImplicit.mli +++ b/helm/ocaml/cic_unification/cicMkImplicit.mli @@ -1,39 +1,60 @@ +(* Copyright (C) 2004, HELM Team. + * + * This file is part of HELM, an Hypertextual, Electronic + * Library of Mathematics, developed at the Computer Science + * Department, University of Bologna, Italy. + * + * HELM is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * HELM is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with HELM; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, + * MA 02111-1307, USA. + * + * For details, see the HELM World-Wide-Web page, + * http://helm.cs.unibo.it/ + *) + (* identity_relocation_list_for_metavariable i canonical_context *) (* returns the identity relocation list, which is the list *) (* [Rel 1 ; ... ; Rel n] where n = List.length [canonical_context] *) val identity_relocation_list_for_metavariable : - 'a option list -> Cic.term option list + ?start: int -> 'a option list -> Cic.term option list (* Returns the first meta whose number is above the *) (* number of the higher meta. *) -val new_meta : Cic.metasenv -> int +val new_meta : Cic.metasenv -> Cic.substitution -> int (** [mk_implicit metasenv context] * add a fresh metavariable to the given metasenv, using given context * @return the new metasenv and the index of the added conjecture *) -val mk_implicit: Cic.metasenv -> Cic.context -> Cic.metasenv * int +val mk_implicit: Cic.metasenv -> Cic.substitution -> Cic.context -> Cic.metasenv * int + +(** as above, but the fresh metavariable represents a type *) +val mk_implicit_type: Cic.metasenv -> Cic.substitution -> Cic.context -> Cic.metasenv * int + +(** as above, but the fresh metavariable represents a sort *) +val mk_implicit_sort: Cic.metasenv -> Cic.substitution -> Cic.metasenv * int (** [mk_implicit metasenv context] create n fresh metavariables *) val n_fresh_metas: - Cic.metasenv -> Cic.context -> int -> Cic.metasenv * Cic.term list + Cic.metasenv -> Cic.substitution -> Cic.context -> int -> Cic.metasenv * Cic.term list -(** [mk_implicit metasenv context] takes in input a list of uri and +(** [fresh_subst metasenv context uris] takes in input a list of uri and creates a fresh explicit substitution *) val fresh_subst: Cic.metasenv -> - Cic.context -> - UriManager.uri list -> - Cic.metasenv * (Cic.term Cic.explicit_named_substitution) - -(** as above but return both the index of the added conjecture (2nd index) and - * the index of its type (1st index) *) -val mk_implicit': Cic.metasenv -> Cic.context -> Cic.metasenv * int * int - -(** as above, but the fresh metavariable represents a type *) -val mk_implicit_type: Cic.metasenv -> Cic.context -> Cic.metasenv * int - -val expand_implicits: - Cic.metasenv -> Cic.context -> Cic.term -> - Cic.metasenv * Cic.term + Cic.substitution -> + Cic.context -> + UriManager.uri list -> + Cic.metasenv * (Cic.term Cic.explicit_named_substitution)