package coq-core
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=64b49dbc3205477bd7517642c0b9cbb6
    
    
  sha512=02fb5b4fb575af79e092492cbec6dc0d15a1d74a07f827f657a72d4e6066532630e5a6d15be4acdb73314bd40b9a321f9ea0584e0ccfe51fd3a56353bd30db9b
    
    
  doc/ltac2_plugin/Ltac2_plugin/Tac2externals/index.html
Module Ltac2_plugin.Tac2externalsSource
Interface for defining external tactics via a high-level spec.
Type ('v,'f) spec represents a high-level Ltac2 tactic specification. It indicates how to turn a value of type 'f into an Ltac2 tactic, which may involve converting between OCaml and Ltac2 value representations, and also lifting a pure function to the tactic monad. The type parameter 'v gives the type of value produced by interpreting the specification.
tac r is the specification of a tactic (in the tactic monad sense) whose return type is specified (and converted into an Ltac2 value) via r.
val tac' : 
  ('r -> Tac2ffi.valexpr) ->
  (Tac2ffi.valexpr Proofview.tactic, 'r Proofview.tactic) spectac' is similar to tac, but only needs a conversion function.
ret r is the specification of a pure tactic (i.e., a tactic defined as a pure OCaml value, not needing the tactic monad) whose return type is given by r (see tac).
ret' is similar to ret, but only needs a conversion function.
val eret : 
  'r Tac2ffi.repr ->
  (Tac2ffi.valexpr Proofview.tactic, Environ.env -> Evd.evar_map -> 'r) speceret is similar to ret, but for tactics that can be implemented with a pure OCaml value, provided extra arguments env and sigma, computed via tclENV and tclEVARMAP.
val eret' : 
  ('r -> Tac2ffi.valexpr) ->
  (Tac2ffi.valexpr Proofview.tactic, Environ.env -> Evd.evar_map -> 'r) speceret' is similar to eret, but only needs a conversion function.
gret is similar to ret, but for tactics that can be implemented with a pure OCaml value, provided the current goal g as extra argument. A fatal error is produced when there is not exactly one goal in focus at the point of using an Ltac2 value defined with this specification. Indeed, the value of g is computed using Goal.enter_one.
val gret' : 
  ('r -> Tac2ffi.valexpr) ->
  (Tac2ffi.valexpr Proofview.tactic, Proofview.Goal.t -> 'r) specgret' is similar to gret, but only needs a conversion function.
r @-> s extends the specification s with a closure argument whose type is specified by (and converted from an Ltac2 value via) r.
val (@-->) : 
  (Tac2ffi.valexpr -> 'a) ->
  ('t, 'f) spec ->
  (Tac2ffi.valexpr -> 't, 'a -> 'f) spec(@-->) is similar to (@->), but only needs a conversion function.
define tac s f defines an external tactic tac by interpreting f with the specification s. The Invalid_argument exception is raised when the given s does not produce a "pure" tactic, that is, something that can be turned into an Ltac2 value (i.e., a closure, or a pure value).