]> matita.cs.unibo.it Git - helm.git/blob - components/tactics/primitiveTactics.mli
tagged 0.5.0-rc1
[helm.git] / 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 (* ALB, needed by the new paramodulation... *)
46 val apply_with_subst:
47   term:Cic.term -> ?subst:Cic.substitution -> ?maxmeta:int -> ProofEngineTypes.proof * int ->
48   Cic.substitution * (ProofEngineTypes.proof * int list) * int
49
50 (* not a real tactic *)
51 val apply_tac_verbose :
52   term:Cic.term ->
53   ProofEngineTypes.proof * int ->
54   (Cic.term -> Cic.term) * (ProofEngineTypes.proof * int list)
55
56 val apply_tac:
57   term: Cic.term -> ProofEngineTypes.tactic
58 val exact_tac:
59   term: Cic.term -> ProofEngineTypes.tactic
60 val intros_tac:
61   ?howmany:int ->
62   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type -> unit ->
63    ProofEngineTypes.tactic
64 val cut_tac:
65   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
66   Cic.term ->
67    ProofEngineTypes.tactic 
68 val letin_tac:
69   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
70   Cic.term ->
71    ProofEngineTypes.tactic 
72
73 val elim_intros_simpl_tac:
74   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
75   ?depth:int -> ?using:Cic.term -> 
76   ?pattern:ProofEngineTypes.lazy_pattern -> Cic.term ->
77   ProofEngineTypes.tactic 
78 val elim_intros_tac:
79   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
80   ?depth:int -> ?using:Cic.term -> 
81   ?pattern:ProofEngineTypes.lazy_pattern -> Cic.term ->
82   ProofEngineTypes.tactic 
83
84 val cases_intros_tac:
85   ?howmany:int ->
86   ?mk_fresh_name_callback:ProofEngineTypes.mk_fresh_name_type ->
87   Cic.term -> ProofEngineTypes.tactic 
88
89 (* FG *)
90
91 val mk_predicate_for_elim: 
92  context:Cic.context -> metasenv:Cic.metasenv -> 
93  ugraph:CicUniv.universe_graph -> goal:Cic.term -> 
94  arg:Cic.term -> using:Cic.term -> cpattern:Cic.term -> args_no:int -> 
95  Cic.metasenv * Cic.term * Cic.term * Cic.term list