]> matita.cs.unibo.it Git - helm.git/blob - helm/software/components/tactics/primitiveTactics.mli
we tranlate an Automath book in an itermediate format where:
[helm.git] / helm / software / components / tactics / primitiveTactics.mli
1 (* Copyright (C) 2002, HELM Team.
2  * 
3  * This file is part of HELM, an Hypertextual, Electronic
4  * Library of Mathematics, developed at the Computer Science
5  * Department, University of Bologna, Italy.
6  * 
7  * HELM is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  * 
12  * HELM is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with HELM; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
20  * MA  02111-1307, USA.
21  * 
22  * For details, see the HELM World-Wide-Web page,
23  * http://cs.unibo.it/helm/.
24  *)
25
26 (**** useful only to implement tactics similar to apply ****)
27
28 val generalize_exp_named_subst_with_fresh_metas :
29   Cic.context ->
30   int ->
31   UriManager.uri ->
32   (UriManager.uri * Cic.term) list ->
33   int * Cic.metasenv *
34   Cic.term Cic.explicit_named_substitution *
35   Cic.term Cic.explicit_named_substitution
36
37 val classify_metas :
38   Cic.term ->
39   (Cic.term -> bool) ->
40   (Cic.context -> Cic.term -> Cic.term) ->
41   (Cic.term * Cic.context * Cic.term) list ->
42   (Cic.term * Cic.context * Cic.term) list *
43   (Cic.term * Cic.context * Cic.term) list
44
45 (* Not primitive, but useful for elim *)
46
47 exception AllSelectedTermsMustBeConvertible;;
48
49 val generalize_tac:
50  ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
51  ProofEngineTypes.lazy_pattern ->
52    ProofEngineTypes.tactic
53
54 (* ALB, needed by the new paramodulation... *)
55 val apply_with_subst:
56   term:Cic.term -> ?subst:Cic.substitution -> ?maxmeta:int -> ProofEngineTypes.proof * int ->
57   Cic.substitution * (ProofEngineTypes.proof * int list) * int
58
59 (* not a real tactic *)
60 val apply_tac_verbose :
61   term:Cic.term ->
62   ProofEngineTypes.proof * int ->
63   (Cic.term -> Cic.term) * (ProofEngineTypes.proof * int list)
64
65 val apply_tac:
66   term: Cic.term -> ProofEngineTypes.tactic
67 val exact_tac:
68   term: Cic.term -> ProofEngineTypes.tactic
69 val intros_tac:
70   ?howmany:int ->
71   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type -> unit ->
72    ProofEngineTypes.tactic
73 val cut_tac:
74   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
75   Cic.term ->
76    ProofEngineTypes.tactic 
77 val letin_tac:
78   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
79   Cic.term ->
80    ProofEngineTypes.tactic 
81
82 val elim_intros_simpl_tac:
83   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
84   ?depth:int -> ?using:Cic.term -> 
85   ?pattern:ProofEngineTypes.lazy_pattern -> Cic.term ->
86   ProofEngineTypes.tactic 
87 val elim_intros_tac:
88   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
89   ?depth:int -> ?using:Cic.term -> 
90   ?pattern:ProofEngineTypes.lazy_pattern -> Cic.term ->
91   ProofEngineTypes.tactic 
92
93 val cases_intros_tac:
94   ?howmany:int ->
95   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
96   ?pattern:ProofEngineTypes.lazy_pattern -> Cic.term ->
97   ProofEngineTypes.tactic 
98
99 (* FG *)
100
101 val mk_predicate_for_elim: 
102  context:Cic.context -> metasenv:Cic.metasenv -> 
103  ugraph:CicUniv.universe_graph -> goal:Cic.term -> 
104  arg:Cic.term -> using:Cic.term -> cpattern:Cic.term -> args_no:int -> 
105  Cic.metasenv * Cic.term * Cic.term * Cic.term list