{-# LANGUAGE DataKinds #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE StandaloneKindSignatures #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE ScopedTypeVariables #-}
module Data.Some.Constraint where
import Data.Kind
type AllC :: forall k. [k -> Constraint] -> k -> Constraint
type family AllC cs k :: Constraint where
AllC '[] k = ()
AllC (c ': cs) k = (c k, AllC cs k)
data Somes cs where
Some :: forall
(cs :: [Type -> Constraint])
(a :: Type).
AllC cs a => a -> Somes cs
type Some c = Somes '[c]
data Somes1 csf csa where
Some1 :: forall
k
(csf :: [(k -> Type) -> Constraint])
(csa :: [k -> Constraint])
(f :: k -> Type)
(a :: k).
(AllC csf f, AllC csa a) => f a -> Somes1 csf csa
type Some1 cf ca = Somes1 '[cf] '[ca]
instance {-# OVERLAPPING #-} Show (Somes (Show ': cs)) where
showsPrec :: Int -> Somes (Show : cs) -> ShowS
showsPrec Int
d (Some a
x) = Bool -> ShowS -> ShowS
showParen (Int
d Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
> Int
10) (ShowS -> ShowS) -> ShowS -> ShowS
forall a b. (a -> b) -> a -> b
$ String -> ShowS
showString String
"Some " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> a -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
11 a
x
instance {-# OVERLAPPABLE #-} Show (Somes cs) => Show (Somes (c ': cs)) where
showsPrec :: Int -> Somes (c : cs) -> ShowS
showsPrec Int
d (Some a
x) = Int -> Somes cs -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (forall (cs :: [* -> Constraint]) a. AllC cs a => a -> Somes cs
Some @cs a
x)