{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE DefaultSignatures #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE MultiParamTypeClasses #-}
module Std.Data.PrimArray.Cast
( Cast(..)
) where
import GHC.Prim
import GHC.Types
import GHC.Int
import GHC.Word
import GHC.IntWord64
import GHC.Float
import Data.Coerce
#include "MachDeps.h"
class Cast source destination where
cast :: source -> destination
instance {-# INCOHERENT #-} Coercible a b => Cast a b where
cast = coerce
instance Cast Int8 Word8 where
cast (I8# i) = W8# (narrow8Word# (int2Word# i))
instance Cast Int16 Word16 where
cast (I16# i) = W16# (narrow16Word# (int2Word# i))
instance Cast Int32 Word32 where
cast (I32# i) = W32# (narrow32Word# (int2Word# i))
instance Cast Int64 Word64 where
#if WORD_SIZE_IN_BITS < 64
cast (I64# i) = W64# (int64ToWord64# i)
#else
cast (I64# i) = W64# (int2Word# i)
#endif
instance Cast Int Word where
cast (I# i) = W# (int2Word# i)
instance Cast Word8 Int8 where
cast (W8# i) = I8# (narrow8Int# (word2Int# i))
instance Cast Word16 Int16 where
cast (W16# i) = I16# (narrow16Int# (word2Int# i))
instance Cast Word32 Int32 where
cast (W32# i) = I32# (narrow32Int# (word2Int# i))
instance Cast Word64 Int64 where
#if WORD_SIZE_IN_BITS < 64
cast (W64# i) = I64# (word64ToInt64# i)
#else
cast (W64# i) = I64# (word2Int# i)
#endif
instance Cast Word Int where
cast (W# w) = I# (word2Int# w)
instance Cast Word64 Double where
cast = castWord64ToDouble
instance Cast Word32 Float where
cast = castWord32ToFloat
instance Cast Double Word64 where
cast = castDoubleToWord64
instance Cast Float Word32 where
cast = castFloatToWord32
instance Cast Int64 Double where
cast = castWord64ToDouble . cast
instance Cast Int32 Float where
cast = castWord32ToFloat . cast
instance Cast Double Int64 where
cast = cast . castDoubleToWord64
instance Cast Float Int32 where
cast = cast . castFloatToWord32