X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic_transformations%2FtacticAst.ml;h=3f4d4226f96fe5f19f40cb75495cae1a7707a9a2;hb=d43002dfc61afac676ea14bc6a1418e5ec0e3e9c;hp=63314d96f04f9d5b618becc9a613ddd27780fa54;hpb=0eab2248345360e8e4b261f653f897db645998a7;p=helm.git diff --git a/helm/ocaml/cic_transformations/tacticAst.ml b/helm/ocaml/cic_transformations/tacticAst.ml index 63314d96f..3f4d4226f 100644 --- a/helm/ocaml/cic_transformations/tacticAst.ml +++ b/helm/ocaml/cic_transformations/tacticAst.ml @@ -23,44 +23,51 @@ * http://helm.cs.unibo.it/ *) -type direction = [ `Left | `Right ] +type direction = [ `LeftToRight | `RightToLeft ] type reduction_kind = [ `Reduce | `Simpl | `Whd | `Normalize ] type loc = CicAst.location -type ('term, 'ident) pattern = - ('ident * 'term) list * 'term option +type ('term, 'ident) pattern = 'term option * ('ident * 'term) list * 'term + +type ('term, 'ident) type_spec = + | Ident of 'ident + | Type of UriManager.uri * int type ('term, 'ident) tactic = | Absurd of loc * 'term | Apply of loc * 'term - | Auto of loc * int option | Assumption of loc - | Change of loc * 'term * 'term * ('term,'ident) pattern (* what, with what, where *) + | Auto of loc * int option * int option * string option (* depth, width, paramodulation ALB *) + | Change of loc * ('term,'ident) pattern * 'term + | Clear of loc * 'ident + | ClearBody of loc * 'ident | Compare of loc * 'term | Constructor of loc * int | Contradiction of loc - | Cut of loc * 'term + | Cut of loc * 'ident option * 'term | DecideEquality of loc - | Decompose of loc * 'term + | Decompose of loc * ('term, 'ident) type_spec list * 'ident * 'ident list | Discriminate of loc * 'term - | Elim of loc * 'term * 'term option (* what to elim, which principle to use *) - | ElimType of loc * 'term + | Elim of loc * 'term * 'term option * int option * 'ident list + | ElimType of loc * 'term * 'term option * int option * 'ident list | Exact of loc * 'term | Exists of loc - | Fold of loc * reduction_kind * 'term + | Fail of loc + | Fold of loc * reduction_kind * 'term * ('term, 'ident) pattern | Fourier of loc - | FwdSimpl of loc * 'term - | Generalize of loc * 'term * ('term, 'ident) pattern + | FwdSimpl of loc * string * 'ident list + | Generalize of loc * ('term, 'ident) pattern * 'ident option | Goal of loc * int (* change current goal, argument is goal number 1-based *) + | IdTac of loc | Injection of loc * 'term | Intros of loc * int option * 'ident list - | LApply of loc * 'term option * 'term + | LApply of loc * int option * 'term list * 'term * 'ident option | Left of loc | LetIn of loc * 'term * 'ident | Reduce of loc * reduction_kind * ('term, 'ident) pattern | Reflexivity of loc - | Replace of loc * 'term * 'term (* what, with what *) + | Replace of loc * ('term, 'ident) pattern * 'term | Rewrite of loc * direction * 'term * ('term, 'ident) pattern | Right of loc | Ring of loc @@ -68,13 +75,7 @@ type ('term, 'ident) tactic = | Symmetry of loc | Transitivity of loc * 'term -type thm_flavour = - [ `Definition - | `Fact - | `Lemma - | `Remark - | `Theorem - ] +type thm_flavour = Cic.object_flavour (** * true means inductive, false coinductive *) @@ -123,7 +124,10 @@ type obj = (string * CicAst.term) list type ('term,'obj) command = + | Default of loc * string * UriManager.uri list + | Include of loc * string | Set of loc * string * string + | Drop of loc | Qed of loc (** name. * Name is needed when theorem was started without providing a name @@ -135,15 +139,14 @@ type ('term,'obj) command = type ('term, 'ident) tactical = | Tactic of loc * ('term, 'ident) tactic - | Fail of loc | Do of loc * int * ('term, 'ident) tactical - | IdTac of loc | Repeat of loc * ('term, 'ident) tactical | Seq of loc * ('term, 'ident) tactical list (* sequential composition *) | Then of loc * ('term, 'ident) tactical * ('term, 'ident) tactical list - | Tries of loc * ('term, 'ident) tactical list + | First of loc * ('term, 'ident) tactical list (* try a sequence of loc * tacticals until one succeeds, fail otherwise *) | Try of loc * ('term, 'ident) tactical (* try a tactical and mask failures *) + | Solve of loc * ('term, 'ident) tactical list type ('term, 'obj, 'ident) code =