{-# LANGUAGE DataKinds #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE InstanceSigs #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE StandaloneKindSignatures #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
{-# OPTIONS_GHC -Wno-orphans #-}
module Data.Proxy.Singletons (
Sing, SProxy(..)
, AsProxyTypeOf, sAsProxyTypeOf
, ProxySym0
, AsProxyTypeOfSym0, AsProxyTypeOfSym1, AsProxyTypeOfSym2
) where
import Control.Applicative
import Control.Monad
import Control.Monad.Singletons.Internal
import Data.Eq.Singletons
import Data.Kind
import Data.Monoid.Singletons
import Data.Ord.Singletons
import Data.Proxy
import Data.Semigroup (Semigroup(..))
import Data.Semigroup.Singletons.Internal
import Data.Singletons.Decide
import Data.Singletons
import Data.Singletons.Base.Enum
import Data.Singletons.Base.Instances
import Data.Singletons.TH
import Data.Type.Coercion
import Data.Type.Equality hiding (type (==))
import GHC.Base.Singletons
import GHC.Num.Singletons
import GHC.TypeLits.Singletons.Internal
import Text.Show.Singletons
type SProxy :: Proxy t -> Type
data SProxy :: Proxy t -> Type where
SProxy :: forall t. SProxy ('Proxy @t)
type instance Sing = SProxy
instance SingKind (Proxy t) where
type Demote (Proxy t) = Proxy t
fromSing :: forall (a :: Proxy t). Sing a -> Demote (Proxy t)
fromSing Sing a
SProxy a
SProxy = Demote (Proxy t)
forall {k} (t :: k). Proxy t
Proxy
toSing :: Demote (Proxy t) -> SomeSing (Proxy t)
toSing Proxy t
Demote (Proxy t)
Proxy = Sing 'Proxy -> SomeSing (Proxy t)
forall k (a :: k). Sing a -> SomeSing k
SomeSing Sing 'Proxy
forall {k} (t :: k). SProxy 'Proxy
SProxy
instance SingI 'Proxy where
sing :: Sing 'Proxy
sing = Sing 'Proxy
forall {k} (t :: k). SProxy 'Proxy
SProxy
type ProxySym0 :: Proxy t
type family ProxySym0 where
ProxySym0 = 'Proxy
instance SDecide (Proxy t) where
Sing a
SProxy a
SProxy %~ :: forall (a :: Proxy t) (b :: Proxy t).
Sing a -> Sing b -> Decision (a :~: b)
%~ Sing b
SProxy b
SProxy = (a :~: b) -> Decision (a :~: b)
forall a. a -> Decision a
Proved a :~: b
forall {k} (a :: k). a :~: a
Refl
instance TestEquality SProxy where
testEquality :: forall (a :: Proxy t) (b :: Proxy t).
SProxy a -> SProxy b -> Maybe (a :~: b)
testEquality = SProxy a -> SProxy b -> Maybe (a :~: b)
forall k (a :: k) (b :: k).
SDecide k =>
Sing a -> Sing b -> Maybe (a :~: b)
decideEquality
instance TestCoercion SProxy where
testCoercion :: forall (a :: Proxy t) (b :: Proxy t).
SProxy a -> SProxy b -> Maybe (Coercion a b)
testCoercion = SProxy a -> SProxy b -> Maybe (Coercion a b)
forall k (a :: k) (b :: k).
SDecide k =>
Sing a -> Sing b -> Maybe (Coercion a b)
decideCoercion
instance Show (SProxy z) where
showsPrec :: Int -> SProxy z -> ShowS
showsPrec Int
_ SProxy z
_ = String -> ShowS
showString String
"SProxy"
$