{-# LANGUAGE MagicHash #-} module Basement.Types.Ptr ( Addr(..) , addrPlus , addrPlusSz , addrPlusCSz , Ptr(..) , ptrPlus , ptrPlusSz , ptrPlusCSz , castPtr ) where import Basement.Compat.Base import Basement.Compat.C.Types import Basement.Types.OffsetSize import GHC.Ptr import GHC.Prim import GHC.Types data Addr = Addr Addr# deriving (Addr -> Addr -> Bool (Addr -> Addr -> Bool) -> (Addr -> Addr -> Bool) -> Eq Addr forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a $c== :: Addr -> Addr -> Bool == :: Addr -> Addr -> Bool $c/= :: Addr -> Addr -> Bool /= :: Addr -> Addr -> Bool Eq,Eq Addr Eq Addr => (Addr -> Addr -> Ordering) -> (Addr -> Addr -> Bool) -> (Addr -> Addr -> Bool) -> (Addr -> Addr -> Bool) -> (Addr -> Addr -> Bool) -> (Addr -> Addr -> Addr) -> (Addr -> Addr -> Addr) -> Ord Addr Addr -> Addr -> Bool Addr -> Addr -> Ordering Addr -> Addr -> Addr forall a. Eq a => (a -> a -> Ordering) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> Bool) -> (a -> a -> a) -> (a -> a -> a) -> Ord a $ccompare :: Addr -> Addr -> Ordering compare :: Addr -> Addr -> Ordering $c< :: Addr -> Addr -> Bool < :: Addr -> Addr -> Bool $c<= :: Addr -> Addr -> Bool <= :: Addr -> Addr -> Bool $c> :: Addr -> Addr -> Bool > :: Addr -> Addr -> Bool $c>= :: Addr -> Addr -> Bool >= :: Addr -> Addr -> Bool $cmax :: Addr -> Addr -> Addr max :: Addr -> Addr -> Addr $cmin :: Addr -> Addr -> Addr min :: Addr -> Addr -> Addr Ord) addrPlus :: Addr -> Offset Word8 -> Addr addrPlus :: Addr -> Offset Word8 -> Addr addrPlus (Addr Addr# addr) (Offset (I# Int# i)) = Addr# -> Addr Addr (Addr# -> Int# -> Addr# plusAddr# Addr# addr Int# i) addrPlusSz :: Addr -> CountOf Word8 -> Addr addrPlusSz :: Addr -> CountOf Word8 -> Addr addrPlusSz (Addr Addr# addr) (CountOf (I# Int# i)) = Addr# -> Addr Addr (Addr# -> Int# -> Addr# plusAddr# Addr# addr Int# i) addrPlusCSz :: Addr -> CSize -> Addr addrPlusCSz :: Addr -> CSize -> Addr addrPlusCSz Addr addr = Addr -> CountOf Word8 -> Addr addrPlusSz Addr addr (CountOf Word8 -> Addr) -> (CSize -> CountOf Word8) -> CSize -> Addr forall b c a. (b -> c) -> (a -> b) -> a -> c forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k). Category cat => cat b c -> cat a b -> cat a c . CSize -> CountOf Word8 sizeOfCSize ptrPlus :: Ptr a -> Offset Word8 -> Ptr a ptrPlus :: forall a. Ptr a -> Offset Word8 -> Ptr a ptrPlus (Ptr Addr# addr) (Offset (I# Int# i)) = Addr# -> Ptr a forall a. Addr# -> Ptr a Ptr (Addr# -> Int# -> Addr# plusAddr# Addr# addr Int# i) ptrPlusSz :: Ptr a -> CountOf Word8 -> Ptr a ptrPlusSz :: forall a. Ptr a -> CountOf Word8 -> Ptr a ptrPlusSz (Ptr Addr# addr) (CountOf (I# Int# i)) = Addr# -> Ptr a forall a. Addr# -> Ptr a Ptr (Addr# -> Int# -> Addr# plusAddr# Addr# addr Int# i) ptrPlusCSz :: Ptr a -> CSize -> Ptr a ptrPlusCSz :: forall a. Ptr a -> CSize -> Ptr a ptrPlusCSz Ptr a ptr = Ptr a -> CountOf Word8 -> Ptr a forall a. Ptr a -> CountOf Word8 -> Ptr a ptrPlusSz Ptr a ptr (CountOf Word8 -> Ptr a) -> (CSize -> CountOf Word8) -> CSize -> Ptr a forall b c a. (b -> c) -> (a -> b) -> a -> c forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k). Category cat => cat b c -> cat a b -> cat a c . CSize -> CountOf Word8 sizeOfCSize