(* in clause pattern *) RequireImport TestSuite.vector. Check (fun n (x: Vector.t True (S n)) => match x in Vector.t _ (S m) return True with
|Vector.cons _ h _ _ => h end).
(* Notation *) Notation"A \dots n" := (Vector.t A n) (at level 200). Check (fun m (x: Vector.t nat m) => match x in _ \dots k return Vector.t nat (S k) with
| Vector.nil _ => Vector.cons _ 0 _ (Vector.nil _)
| Vector.cons _ h _ t => Vector.cons _ h _ (Vector.cons _ h _ t) end).
(* N should be a variable and not the inductiveRef *) Inductive N := Constr. Theorem foo : forall (n m : nat) (pf : n = m), match pf in _ = N with
| eq_refl => unit end. Abort.
(* Check redundant clause is removed *) Inductive I : nat * nat -> Type := C : I (0,0). Checkfun x : I (1,1) => match x in I (y,z) return y = z with C => eq_refl end.
(* An example of non-local inference of the type of an impossible case *) Check (fun y n (x:Vector.t nat (S n)) => match x with Vector.cons _ a _ _ => a | _ => y end) 2.
Messung V0.5
¤ Dauer der Verarbeitung: 0.13 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.