37 lines
956 B
Lean4
37 lines
956 B
Lean4
|
|
import Spa.Lattice.FiniteMap
|
|||
|
|
import Spa.Lattice.AboveBelow
|
|||
|
|
|
|||
|
|
namespace Spa
|
|||
|
|
|
|||
|
|
class Showable (α : Type*) where
|
|||
|
|
show' : α → String
|
|||
|
|
|
|||
|
|
export Showable (show')
|
|||
|
|
|
|||
|
|
instance : Showable String := ⟨fun s => "\"" ++ s ++ "\""⟩
|
|||
|
|
|
|||
|
|
instance : Showable ℕ := ⟨toString⟩
|
|||
|
|
|
|||
|
|
instance : Showable ℤ := ⟨toString⟩
|
|||
|
|
|
|||
|
|
instance {n : ℕ} : Showable (Fin n) := ⟨fun i => toString i.val⟩
|
|||
|
|
|
|||
|
|
instance {α β : Type*} [Showable α] [Showable β] : Showable (α × β) :=
|
|||
|
|
⟨fun p => "(" ++ show' p.1 ++ ", " ++ show' p.2 ++ ")"⟩
|
|||
|
|
|
|||
|
|
instance : Showable PUnit := ⟨fun _ => "()"⟩
|
|||
|
|
|
|||
|
|
instance {α : Type*} [Showable α] : Showable (AboveBelow α) :=
|
|||
|
|
⟨fun
|
|||
|
|
| .bot => "⊥"
|
|||
|
|
| .top => "⊤"
|
|||
|
|
| .mk x => show' x⟩
|
|||
|
|
|
|||
|
|
instance {α β : Type*} {ks : List α} [Showable α] [Showable β] :
|
|||
|
|
Showable (FiniteMap α β ks) :=
|
|||
|
|
⟨fun fm =>
|
|||
|
|
"{" ++ fm.val.foldr (fun p rest => show' p.1 ++ " ↦ " ++ show' p.2 ++ ", " ++ rest) ""
|
|||
|
|
++ "}"⟩
|
|||
|
|
|
|||
|
|
end Spa
|