module Data.TypeRep.Types.Basic.Typeable where
import Language.Syntactic
import Data.TypeRep.Representation
import Data.TypeRep.TH
import Data.TypeRep.Types.Basic
instance (BoolType   :<: t) => Typeable t Bool   where typeRep' = boolType
instance (CharType   :<: t) => Typeable t Char   where typeRep' = charType
instance (IntType    :<: t) => Typeable t Int    where typeRep' = intType
instance (FloatType  :<: t) => Typeable t Float  where typeRep' = floatType
instance (DoubleType :<: t) => Typeable t Double where typeRep' = doubleType
instance (ListType :<: t, Typeable t a)               => Typeable t [a]      where typeRep' = listType typeRep'
instance (FunType  :<: t, Typeable t a, Typeable t b) => Typeable t (a -> b) where typeRep' = funType typeRep' typeRep'
deriveWitnessTypeable ''BoolType
deriveWitnessTypeable ''CharType
deriveWitnessTypeable ''IntType
deriveWitnessTypeable ''FloatType
deriveWitnessTypeable ''DoubleType
deriveWitnessTypeable ''ListType
deriveWitnessTypeable ''FunType
derivePWitnessTypeable ''BoolType
derivePWitnessTypeable ''CharType
derivePWitnessTypeable ''IntType
derivePWitnessTypeable ''FloatType
derivePWitnessTypeable ''DoubleType
derivePWitnessTypeable ''ListType
derivePWitnessTypeable ''FunType