1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
|
(************************************************************************)
(* * The Coq Proof Assistant / The Coq Development Team *)
(* v * Copyright INRIA, CNRS and contributors *)
(* <O___,, * (see version control and CREDITS file for authors & dates) *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)
open Ssrast
(* Adaptor DB (Hint View) *)
module AdaptorDb : sig
type kind = Forward | Backward | Equivalence
val get : kind -> Glob_term.glob_constr list
val declare : kind -> Glob_term.glob_constr list -> unit
end
(* Apply views to the top of the stack (intro pattern). If clear_if_id is
* true (default false) then views that happen to be a variable are considered
* as to be cleared (see the to_clear argument to the continuation)
*
* returns true if the last view was a tactic *)
val tclIPAT_VIEWS
: views:ast_closure_term list
-> ?clear_if_id:bool
-> conclusion:(to_clear:Names.Id.t list -> unit Proofview.tactic)
-> unit
-> bool Proofview.tactic
(* Apply views to a given subject (as if was the top of the stack), then
call conclusion on the obtained term (something like [v2 (v1 subject)]).
The term being passed to conclusion is abstracted over non-resolved evars:
if [simple_types] then all unnecessary dependencies among the abstracted
evars are pruned *)
val tclWITH_FWD_VIEWS :
simple_types:bool ->
subject:EConstr.t ->
views:ast_closure_term list ->
conclusion:(EConstr.t -> unit Proofview.tactic) ->
unit Proofview.tactic
|