This PR refines and clarifies the `meta` phase distinction in the module system. * `meta import A` without `public` now has the clarified meaning of "enable compile-time evaluation of declarations in or above `A` in the current module, but not downstream". This is now checked statically by enforcing that public meta defs, which therefore may be referenced from outside, can only use public meta imports, and that global evaluating attributes such as `@[term_parser]` can only be applied to public meta defs. * `meta def`s may no longer reference non-meta defs even when in the same module. This clarifies the meta distinction as well as improves locality of (new) error messages. * parser references in `syntax` are now also properly tracked as meta references. * A `meta import` of an `import` now properly loads only the `.ir` of the nested module for the purposes of execution instead of also making its declarations available for general elaboration. * `initialize` is now no longer being run on import under the module system, which is now covered by `meta initialize`.
36 lines
974 B
Text
36 lines
974 B
Text
module
|
|
public import Lean
|
|
public meta import Lean.Elab.Tactic
|
|
|
|
open Lean Meta Elab Tactic Try
|
|
|
|
-- Install a `TryTactic` handler for `assumption`
|
|
@[local try_tactic assumption]
|
|
meta def evalTryApply : TryTactic := fun tac => do
|
|
-- We just use the default implementation, but return a different tactic.
|
|
evalAssumption tac
|
|
`(tactic| (trace "worked"; assumption))
|
|
|
|
/--
|
|
info: Try this:
|
|
· trace "worked"; assumption
|
|
-/
|
|
#guard_msgs (info) in
|
|
example (h : False) : False := by
|
|
try? (max := 1) -- at most one solution
|
|
|
|
-- `try?` uses `evalAndSuggest` the attribute `[try_tactic]` is used to extend `evalAndSuggest`.
|
|
-- Let's define our own `try?` that uses `evalAndSuggest`
|
|
elab stx:"my_try?" : tactic => do
|
|
-- Things to try
|
|
let toTry ← `(tactic| attempt_all | assumption | apply True | rfl)
|
|
evalAndSuggest stx toTry
|
|
|
|
/--
|
|
info: Try these:
|
|
• · trace "worked"; assumption
|
|
• rfl
|
|
-/
|
|
#guard_msgs (info) in
|
|
example (a : Nat) (h : a = a) : a = a := by
|
|
my_try?
|