package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=051f7bf702ff0a3b370449728921e5a95e18bc2b31b8eb949d48422888c98af4
doc/rocq-runtime.proofs/Refine/index.html
Module RefineSource
The primitive refine tactic used to fill the holes in partial proofs. This is the recommended way to write tactics when the proof term is easy to write down. Note that this is not the user-level refine tactic defined in Ltac which is actually based on the one below.
The refine tactic
Refinement primitives
val refine :
typecheck:bool ->
(Evd.evar_map -> Evd.evar_map * EConstr.t) ->
unit Proofview.tacticIn refine ~typecheck t, t is a term with holes under some evar_map context. The term t is used as a partial solution for the current goal (refine is a goal-dependent tactic), the new holes created by t become the new subgoals. Exceptions raised during the interpretation of t are caught and result in tactic failures. If typecheck is true t is type-checked beforehand. Shelved evars and goals are all marked as unresolvable for typeclasses.
val refine_with_principal :
typecheck:bool ->
(Evd.evar_map -> Evd.evar_map * EConstr.t * Evar.t option) ->
unit Proofview.tacticLike refine, but if the Evar.t option is Some ev then ev inherits properties (the name) of the goal.
val generic_refine :
typecheck:bool ->
('a * EConstr.t * Evar.t option) Proofview.tactic ->
Proofview.Goal.t ->
'a Proofview.tacticThe general version of refine.
Unification constraint handling
Solve any remaining unification problems, applying heuristics.