Module Refine
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.tactic
- In - refine ~typecheck t,- tis a term with holes under some- evar_mapcontext. The term- tis used as a partial solution for the current goal (refine is a goal-dependent tactic), the new holes created by- tbecome the new subgoals. Exceptions raised during the interpretation of- tare caught and result in tactic failures. If- typecheckis- true- tis type-checked beforehand. Shelved evars and goals are all marked as unresolvable for typeclasses.
- val generic_refine : typecheck:bool -> ('a * EConstr.t) Proofview.tactic -> Proofview.Goal.t -> 'a Proofview.tactic
- The general version of refine. 
Unification constraint handling
- val solve_constraints : unit Proofview.tactic
- Solve any remaining unification problems, applying heuristics.