module System.Endian
( Endianness(..)
, getSystemEndianness
, fromLE32
, fromLE64
, fromLE16
, toLE32
, toLE64
, toLE16
, fromBE32
, fromBE64
, fromBE16
, toBE32
, toBE64
, toBE16
) where
#include "MachDeps.h"
import Foreign.C.Types
import Data.Word
data Endianness = LittleEndian
| BigEndian
deriving (Show,Eq)
getSystemEndianness :: Endianness
#ifdef WORDS_BIGENDIAN
getSystemEndianness = BigEndian
#else
getSystemEndianness = LittleEndian
#endif
fromBE64 :: Word64 -> Word64
fromBE64 = if getSystemEndianness == BigEndian then id else swap64
fromLE64 :: Word64 -> Word64
fromLE64 = if getSystemEndianness == LittleEndian then id else swap64
fromBE32 :: Word32 -> Word32
fromBE32 = if getSystemEndianness == BigEndian then id else swap32
fromLE32 :: Word32 -> Word32
fromLE32 = if getSystemEndianness == LittleEndian then id else swap32
fromBE16 :: Word16 -> Word16
fromBE16 = if getSystemEndianness == BigEndian then id else swap16
fromLE16 :: Word16 -> Word16
fromLE16 = if getSystemEndianness == LittleEndian then id else swap16
toBE64 :: Word64 -> Word64
toBE64 = fromBE64
toLE64 :: Word64 -> Word64
toLE64 = fromLE64
toBE32 :: Word32 -> Word32
toBE32 = fromBE32
toLE32 :: Word32 -> Word32
toLE32 = fromLE32
toBE16 :: Word16 -> Word16
toBE16 = fromBE16
toLE16 :: Word16 -> Word16
toLE16 = fromLE16
#if MIN_VERSION_base(4,7,0)
swap16 :: Word16 -> Word16
swap16 = byteSwap16
swap32 :: Word32 -> Word32
swap32 = byteSwap32
swap64 :: Word64 -> Word64
swap64 = byteSwap64
#else
swap16 :: Word16 -> Word16
swap16 = fromIntegral . c_swap16 . fromIntegral
swap32 :: Word32 -> Word32
swap32 = fromIntegral . c_swap32 . fromIntegral
swap64 :: Word64 -> Word64
swap64 = fromIntegral . c_swap64 . fromIntegral
foreign import ccall unsafe "bitfn_swap16" c_swap16 :: CUShort -> CUShort
foreign import ccall unsafe "bitfn_swap32" c_swap32 :: CUInt -> CUInt
foreign import ccall unsafe "bitfn_swap64" c_swap64 :: CULLong -> CULLong
#endif