Skip to content

Commit

Permalink
fix: derive BEq on structure with Prop-fields (#3191)
Browse files Browse the repository at this point in the history
Closes #3140

---------

Co-authored-by: Joachim Breitner <[email protected]>
  • Loading branch information
arthur-adjedj and nomeata authored Jan 18, 2024
1 parent 628633d commit a2ed4db
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 3 deletions.
5 changes: 4 additions & 1 deletion src/Lean/Elab/Deriving/BEq.lean
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,10 @@ where
let b := mkIdent (← mkFreshUserName `b)
ctorArgs1 := ctorArgs1.push a
ctorArgs2 := ctorArgs2.push b
if (← inferType x).isAppOf indVal.name then
let xType ← inferType x
if (← isProp xType) then
continue
if xType.isAppOf indVal.name then
rhs ← `($rhs && $(mkIdent auxFunName):ident $a:ident $b:ident)
else
rhs ← `($rhs && $a:ident == $b:ident)
Expand Down
5 changes: 3 additions & 2 deletions src/Lean/Elab/Deriving/DecEq.lean
Original file line number Diff line number Diff line change
Expand Up @@ -67,11 +67,12 @@ where
let b := mkIdent (← mkFreshUserName `b)
ctorArgs1 := ctorArgs1.push a
ctorArgs2 := ctorArgs2.push b
let xType ← inferType x
let indValNum :=
ctx.typeInfos.findIdx?
((← inferType x).isAppOf ∘ ConstantVal.name ∘ InductiveVal.toConstantVal)
(xType.isAppOf ∘ ConstantVal.name ∘ InductiveVal.toConstantVal)
let recField := indValNum.map (ctx.auxFunNames[·]!)
let isProof := (← inferType (← inferType x)).isProp
let isProof isProp xType
todo := todo.push (a, b, recField, isProof)
patterns := patterns.push (← `(@$(mkIdent ctorName₁):ident $ctorArgs1:term*))
patterns := patterns.push (← `(@$(mkIdent ctorName₁):ident $ctorArgs2:term*))
Expand Down
11 changes: 11 additions & 0 deletions tests/lean/3140.lean
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
/- Verify that `deriving BEq` works on structures with `Prop`-fields.-/

structure S where
foo : Nat
p : True
Bar : Nat
deriving BEq

#eval (⟨1,⟨⟩,2⟩ : S) == ⟨1,⟨⟩,3-- false
#eval (⟨1,⟨⟩,2⟩ : S) == ⟨2,⟨⟩,2-- false
#eval (⟨1,⟨⟩,2⟩ : S) == ⟨1,⟨⟩,2-- true
3 changes: 3 additions & 0 deletions tests/lean/3140.lean.expected.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
false
false
true

0 comments on commit a2ed4db

Please sign in to comment.