lean4-htt/tests/lean/run/grind_usr.lean
Leonardo de Moura fc718eac88
feat: code action for grind parameters (#10472)
This PR adds a code action for `grind` parameters. We need to use
`set_option grind.param.codeAction true` to enable the option. The PR
also adds a modifier to instruct `grind` to use the "default" pattern
inference strategy.
2025-09-20 07:30:39 +00:00

79 lines
2 KiB
Text

module
public opaque f : Nat → Nat
/--
error: the modifier `usr` is only relevant in parameters for `grind only`
-/
#guard_msgs (error) in
@[grind usr]
public theorem fthm : f (f x) = f x := sorry
/-- trace: [grind.ematch.pattern] fthm: [f #0] -/
#guard_msgs (trace) in
set_option trace.grind.ematch.pattern true in
example : f (f (f x)) = f x := by
grind only [!←fthm]
/--
trace: [grind.ematch.instance] fthm: f (f x) = f x
[grind.ematch.instance] fthm: f (f (f x)) = f (f x)
[grind.ematch.instance] fthm: f (f (f (f x))) = f (f (f x))
-/
#guard_msgs (trace) in
set_option trace.grind.ematch.instance true in
example : f (f (f x)) = f x := by
grind only [!fthm]
/--
trace: [grind.ematch.instance] fthm: f (f x) = f x
[grind.ematch.instance] fthm: f (f (f x)) = f (f x)
-/
#guard_msgs (trace) in
-- should not instantiate anything using pattern `f (f #0)`
set_option trace.grind.ematch.instance true in
example : f x = x := by
fail_if_success grind only [!fthm]
sorry
/--
error: the modifier `usr` is only relevant in parameters for `grind only`
-/
#guard_msgs (error) in
example : f (f (f x)) = f x := by
grind [usr fthm]
/--
error: invalid use of `usr` modifier, `fthm` does not have patterns specified with the command `grind_pattern`
-/
#guard_msgs (error) in
example : f (f (f x)) = f x := by
grind only [usr fthm]
grind_pattern fthm => f (f x)
example : f (f (f x)) = f x := by
grind only [usr fthm]
#guard_msgs (trace) in
-- should not instantiate anything using pattern `f (f #0)`
set_option trace.grind.ematch.instance true in
example : f x = x := by
fail_if_success grind only [usr fthm]
sorry
/--
trace: [grind.ematch.instance] fthm: f (f x) = f x
[grind.ematch.instance] fthm: f (f (f x)) = f (f x)
-/
#guard_msgs (trace) in
set_option trace.grind.ematch.instance true in
example : f x = x := by
fail_if_success grind only [!fthm]
sorry
/--
error: the modifier `usr` is only relevant in parameters for `grind only`
-/
#guard_msgs (error) in
example : f (f (f x)) = f x := by
grind [usr fthm]