module Bindings.GObject.Varargs 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.GLib
data C'GTypeCValue = C'GTypeCValue{
c'GTypeCValue'v_int :: C'gint,
c'GTypeCValue'v_long :: C'glong,
c'GTypeCValue'v_int64 :: C'gint64,
c'GTypeCValue'v_double :: C'gdouble,
c'GTypeCValue'v_pointer :: C'gpointer
} deriving (Eq,Show)
p'GTypeCValue'v_int p = plusPtr p 0
p'GTypeCValue'v_int :: Ptr (C'GTypeCValue) -> Ptr (C'gint)
p'GTypeCValue'v_long p = plusPtr p 0
p'GTypeCValue'v_long :: Ptr (C'GTypeCValue) -> Ptr (C'glong)
p'GTypeCValue'v_int64 p = plusPtr p 0
p'GTypeCValue'v_int64 :: Ptr (C'GTypeCValue) -> Ptr (C'gint64)
p'GTypeCValue'v_double p = plusPtr p 0
p'GTypeCValue'v_double :: Ptr (C'GTypeCValue) -> Ptr (C'gdouble)
p'GTypeCValue'v_pointer p = plusPtr p 0
p'GTypeCValue'v_pointer :: Ptr (C'GTypeCValue) -> Ptr (C'gpointer)
instance Storable C'GTypeCValue where
sizeOf _ = 8
alignment _ = 4
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 0
v2 <- peekByteOff p 0
v3 <- peekByteOff p 0
v4 <- peekByteOff p 0
return $ C'GTypeCValue v0 v1 v2 v3 v4
poke p (C'GTypeCValue v0 v1 v2 v3 v4) = do
pokeByteOff p 0 v0
pokeByteOff p 0 v1
pokeByteOff p 0 v2
pokeByteOff p 0 v3
pokeByteOff p 0 v4
return ()
c'G_VALUE_COLLECT_FORMAT_MAX_LENGTH = 8
c'G_VALUE_COLLECT_FORMAT_MAX_LENGTH :: (Num a) => a