module Bindings.APR.Allocator.Types where
import Foreign.Ptr (Ptr,FunPtr,plusPtr)
import Foreign.Ptr (wordPtrToPtr,castPtrToFunPtr)
import Foreign.Storable
import Foreign.C.Types
import Foreign.C.String (CString,CStringLen,CWString,CWStringLen)
import Foreign.Marshal.Alloc (alloca)
import Foreign.Marshal.Array (peekArray,pokeArray)
import Data.Int
import Data.Word
import Bindings.APR
data C'apr_allocator_t = C'apr_allocator_t
data C'apr_memnode_t = C'apr_memnode_t{
c'apr_memnode_t'next :: Ptr C'apr_memnode_t
,
c'apr_memnode_t'ref :: Ptr (Ptr C'apr_memnode_t)
,
c'apr_memnode_t'index :: C'apr_uint32_t
,
c'apr_memnode_t'free_index :: C'apr_uint32_t
,
c'apr_memnode_t'first_avail :: Ptr CChar
,
c'apr_memnode_t'endp :: Ptr CChar
} deriving (Eq,Show)
instance Storable C'apr_memnode_t where
sizeOf _ = 24
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
v4 <- peekByteOff p 16
v5 <- peekByteOff p 20
return $ C'apr_memnode_t v0 v1 v2 v3 v4 v5
poke p (C'apr_memnode_t v0 v1 v2 v3 v4 v5) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
pokeByteOff p 16 v4
pokeByteOff p 20 v5
return ()