module Bindings.APR.Version 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
c'APR_MAJOR_VERSION = 1
c'APR_MAJOR_VERSION :: (Num a) => a
c'APR_MINOR_VERSION = 4
c'APR_MINOR_VERSION :: (Num a) => a
c'APR_PATCH_VERSION = 2
c'APR_PATCH_VERSION :: (Num a) => a
foreign import ccall "inline_APR_VERSION_AT_LEAST" c'APR_VERSION_AT_LEAST
:: CInt -> CInt -> CInt -> IO CInt
foreign import ccall "array_APR_VERSION_STRING" c'APR_VERSION_STRING
:: Ptr (CChar)
data C'apr_version_t = C'apr_version_t{
c'apr_version_t'major :: CInt
,
c'apr_version_t'minor :: CInt
,
c'apr_version_t'patch :: CInt
,
c'apr_version_t'is_dev :: CInt
} deriving (Eq,Show)
instance Storable C'apr_version_t where
sizeOf _ = 16
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
v2 <- peekByteOff p 8
v3 <- peekByteOff p 12
return $ C'apr_version_t v0 v1 v2 v3
poke p (C'apr_version_t v0 v1 v2 v3) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
pokeByteOff p 8 v2
pokeByteOff p 12 v3
return ()
foreign import ccall "apr_version" c'apr_version
:: Ptr C'apr_version_t -> IO ()
foreign import ccall "&apr_version" p'apr_version
:: FunPtr (Ptr C'apr_version_t -> IO ())
foreign import ccall "apr_version_string" c'apr_version_string
:: IO (Ptr CChar)
foreign import ccall "&apr_version_string" p'apr_version_string
:: FunPtr (IO (Ptr CChar))