Skip to content

Commit

Permalink
fix: make sure anonymous dot notation works with type synonyms
Browse files Browse the repository at this point in the history
When resolving anonymous dot notation (`.ident x y z`), it would reduce the expected type to whnf. Now, it unfolds definitions step-by-step, even if the type synonym is for a pi type like so
```lean
def Foo : Prop := ∀ a : Nat, a = a
protected theorem Foo.intro : Foo := sorry
example : Foo := .intro
```
  • Loading branch information
kmill committed Jul 24, 2024
1 parent 5938dbb commit 37b87c6
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 2 deletions.
13 changes: 11 additions & 2 deletions src/Lean/Elab/App.lean
Original file line number Diff line number Diff line change
Expand Up @@ -1354,9 +1354,17 @@ private partial def resolveDotName (id : Syntax) (expectedType? : Option Expr) :
tryPostponeIfNoneOrMVar expectedType?
let some expectedType := expectedType?
| throwError "invalid dotted identifier notation, expected type must be known"
forallTelescopeReducing expectedType fun _ resultType => do
withForallBody expectedType fun resultType => do
go resultType expectedType #[]
where
/-- A weak version of forallTelescopeReducing that only uses whnfCore. -/
withForallBody {α} (type : Expr) (k : Expr → TermElabM α) : TermElabM α :=
forallTelescope type fun _ body => do
let body ← whnfCore body
if body.isForall then
withForallBody body k
else
k body
go (resultType : Expr) (expectedType : Expr) (previousExceptions : Array Exception) : TermElabM Name := do
let resultType ← instantiateMVars resultType
let resultTypeFn := resultType.cleanupAnnotations.getAppFn
Expand All @@ -1372,7 +1380,8 @@ where
| ex@(.error ..) =>
match (← unfoldDefinition? resultType) with
| some resultType =>
go (← whnfCore resultType) expectedType (previousExceptions.push ex)
withForallBody resultType fun resultType => do
go resultType expectedType (previousExceptions.push ex)
| none =>
previousExceptions.forM fun ex => logException ex
throw ex
Expand Down
8 changes: 8 additions & 0 deletions tests/lean/run/4761.lean
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
/-!
# Make sure "anonymous dot notation" works with type synonyms.
-/

def Foo : Prop := ∀ a : Nat, a = a

protected theorem Foo.intro : Foo := sorry
example : Foo := .intro

0 comments on commit 37b87c6

Please sign in to comment.