aboutsummaryrefslogtreecommitdiffhomepage
path: root/pretyping/pattern.mli
diff options
context:
space:
mode:
authorGravatar herbelin <herbelin@85f007b7-540e-0410-9357-904b9bb8a0f7>2000-12-26 10:46:42 +0000
committerGravatar herbelin <herbelin@85f007b7-540e-0410-9357-904b9bb8a0f7>2000-12-26 10:46:42 +0000
commit98048378aa9a0a0a5299bc0555963957b607a046 (patch)
tree40046209fc265c07d1d2e71b6b6df7c12d901344 /pretyping/pattern.mli
parent25fc4c8821140f0474735ca98d25045573e31b00 (diff)
Pattern sera mieux dans Pretyping; relâchement head_pattern_bound
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@1219 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'pretyping/pattern.mli')
-rw-r--r--pretyping/pattern.mli86
1 files changed, 86 insertions, 0 deletions
diff --git a/pretyping/pattern.mli b/pretyping/pattern.mli
new file mode 100644
index 000000000..5c5c28ba1
--- /dev/null
+++ b/pretyping/pattern.mli
@@ -0,0 +1,86 @@
+
+(*i $Id$ i*)
+
+(*i*)
+open Names
+open Sign
+open Term
+open Environ
+(*i*)
+
+type constr_pattern =
+ | PRef of global_reference
+ | PVar of identifier
+ | PRel of int
+ | PApp of constr_pattern * constr_pattern array
+ | PSoApp of int * constr_pattern list
+ | PBinder of Rawterm.binder_kind * name * constr_pattern * constr_pattern
+ | PSort of Rawterm.rawsort
+ | PMeta of int option
+ | PCase of constr_pattern option * constr_pattern * constr_pattern array
+ | PFix of fixpoint
+ | PCoFix of cofixpoint
+
+val occur_meta_pattern : constr_pattern -> bool
+
+type constr_label =
+ | ConstNode of section_path
+ | IndNode of inductive_path
+ | CstrNode of constructor_path
+ | VarNode of identifier
+ | SectionVarNode of section_path
+
+exception BoundPattern
+
+(* [head_pattern_bound t] extracts the head variable/constant of the
+ type [t] or raises [BoundPattern] (even if a sort); it raises an anomaly
+ if [t] is an abstraction *)
+
+val head_pattern_bound : constr_pattern -> constr_label
+
+(* [head_of_constr_reference c] assumes [r] denotes a reference and
+ returns its label; raises an anomaly otherwise *)
+
+val head_of_constr_reference : Term.constr -> constr_label
+
+(* [pattern_of_constr c] translates a term [c] with metavariables into
+ a pattern; currently, no destructor (Cases, Fix, Cofix) and no
+ existential variable are allowed in [c] *)
+
+val pattern_of_constr : constr -> constr_pattern
+
+
+exception PatternMatchingFailure
+
+(* [matches pat c] matches [c] against [pat] and returns the resulting
+ assignment of metavariables; it raises [PatternMatchingFailure] if
+ not matchable; bindings are given in increasing order based on the
+ numbers given in the pattern *)
+val matches :
+ constr_pattern -> constr -> (int * constr) list
+
+(* [is_matching pat c] just tells if [c] matches against [pat] *)
+
+val is_matching :
+ constr_pattern -> constr -> bool
+
+(* [matches_conv env sigma] matches up to conversion in environment
+ [(env,sigma)] when constants in pattern are concerned; it raises
+ [PatternMatchingFailure] if not matchable; bindings are given in
+ increasing order based on the numbers given in the pattern *)
+
+val matches_conv :
+ env -> 'a Evd.evar_map -> constr_pattern -> constr -> (int * constr) list
+
+(* To skip to the next occurrence *)
+exception NextOccurrence of int
+
+(* Tries to match a subterm of [c] with [pat] *)
+val sub_match :
+ int -> constr_pattern -> constr -> ((int * constr) list * constr)
+
+(* [is_matching_conv env sigma pat c] tells if [c] matches against [pat]
+ up to conversion for constants in patterns *)
+
+val is_matching_conv :
+ env -> 'a Evd.evar_map -> constr_pattern -> constr -> bool