lean4-htt/tests/lean/run/derivingNonempty.lean
Sebastian Ullrich 467d905709
fix: more deriving handlers under the module system (#9647)
This PR fixes further deriving handlers to apply visibilities correctly
2025-07-31 15:00:58 +00:00

65 lines
1.2 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

module
inductive Foo (α : Type u) (β : Type v) where
| mk₁ : α → Foo α β
| mk₂ : List β → Foo α β
deriving instance Nonempty for Foo
def ex1 [Nonempty α] : Nonempty (Foo α β) :=
inferInstance
inductive Bla (α : Type u) (β : Type v) where
| mk₁ : α → Bla α β
| mk₂ : β → Bla α β
deriving instance Nonempty for Bla
def ex2 [Nonempty α] : Nonempty (Bla α β) :=
inferInstance
structure Point (α : Type) where
x : α
y : α
deriving Nonempty
def ex3 [Nonempty α] : Nonempty (Point α) :=
inferInstance
inductive Lst (α : Type) where
| nil
| cons : α → Lst α → Lst α
deriving Nonempty
def ex4 : Nonempty (Lst α) :=
inferInstance
mutual
inductive FooLst (α : Type) where
| nil
| cons : Boo α → FooLst α → FooLst α
deriving Nonempty
inductive Boo (α : Type) where
| node : FooLst α → Boo α
deriving Nonempty
end
def ex5 : Nonempty (Boo α) :=
inferInstance
/-! Public structures with private fields should yield public opaque instances. -/
public structure PrivField where
private a : Nat
deriving Nonempty
/--
info: theorem instNonemptyPrivField : Nonempty PrivField :=
<not imported>
-/
#guard_msgs in
#with_exporting
#print instNonemptyPrivField