module Bindings.GLib.DataTypes.Arrays 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.Fundamentals
import Bindings.GLib.DataTypes.DoublyLinkedLists
data C'GArray = C'GArray{
c'GArray'data :: Ptr C'gchar
,
c'GArray'len :: C'guint
} deriving (Eq,Show)
instance Storable C'GArray where
sizeOf _ = 8
alignment = sizeOf
peek p = do
v0 <- peekByteOff p 0
v1 <- peekByteOff p 4
return $ C'GArray v0 v1
poke p (C'GArray v0 v1) = do
pokeByteOff p 0 v0
pokeByteOff p 4 v1
return ()
foreign import ccall "g_array_new" c'g_array_new
:: C'gboolean -> C'gboolean -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_new" p'g_array_new
:: FunPtr (C'gboolean -> C'gboolean -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_sized_new" c'g_array_sized_new
:: C'gboolean -> C'gboolean -> C'guint -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_sized_new" p'g_array_sized_new
:: FunPtr (C'gboolean -> C'gboolean -> C'guint -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_ref" c'g_array_ref
:: Ptr C'GArray -> IO (Ptr C'GArray)
foreign import ccall "&g_array_ref" p'g_array_ref
:: FunPtr (Ptr C'GArray -> IO (Ptr C'GArray))
foreign import ccall "g_array_unref" c'g_array_unref
:: Ptr C'GArray -> IO ()
foreign import ccall "&g_array_unref" p'g_array_unref
:: FunPtr (Ptr C'GArray -> IO ())
foreign import ccall "g_array_get_element_size" c'g_array_get_element_size
:: Ptr C'GArray -> IO C'guint
foreign import ccall "&g_array_get_element_size" p'g_array_get_element_size
:: FunPtr (Ptr C'GArray -> IO C'guint)
foreign import ccall "g_array_append_vals" c'g_array_append_vals
:: Ptr C'GArray -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_append_vals" p'g_array_append_vals
:: FunPtr (Ptr C'GArray -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_prepend_vals" c'g_array_prepend_vals
:: Ptr C'GArray -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_prepend_vals" p'g_array_prepend_vals
:: FunPtr (Ptr C'GArray -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_insert_vals" c'g_array_insert_vals
:: Ptr C'GArray -> C'guint -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_insert_vals" p'g_array_insert_vals
:: FunPtr (Ptr C'GArray -> C'guint -> C'gconstpointer -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_remove_index" c'g_array_remove_index
:: Ptr C'GArray -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_remove_index" p'g_array_remove_index
:: FunPtr (Ptr C'GArray -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_remove_index_fast" c'g_array_remove_index_fast
:: Ptr C'GArray -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_remove_index_fast" p'g_array_remove_index_fast
:: FunPtr (Ptr C'GArray -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_remove_range" c'g_array_remove_range
:: Ptr C'GArray -> C'guint -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_remove_range" p'g_array_remove_range
:: FunPtr (Ptr C'GArray -> C'guint -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_sort" c'g_array_sort
:: Ptr C'GArray -> C'GCompareFunc -> IO ()
foreign import ccall "&g_array_sort" p'g_array_sort
:: FunPtr (Ptr C'GArray -> C'GCompareFunc -> IO ())
foreign import ccall "g_array_sort_with_data" c'g_array_sort_with_data
:: Ptr C'GArray -> C'GCompareDataFunc -> C'gpointer -> IO ()
foreign import ccall "&g_array_sort_with_data" p'g_array_sort_with_data
:: FunPtr (Ptr C'GArray -> C'GCompareDataFunc -> C'gpointer -> IO ())
foreign import ccall "g_array_set_size" c'g_array_set_size
:: Ptr C'GArray -> C'guint -> IO (Ptr C'GArray)
foreign import ccall "&g_array_set_size" p'g_array_set_size
:: FunPtr (Ptr C'GArray -> C'guint -> IO (Ptr C'GArray))
foreign import ccall "g_array_free" c'g_array_free
:: Ptr C'GArray -> C'gboolean -> IO (Ptr C'gchar)
foreign import ccall "&g_array_free" p'g_array_free
:: FunPtr (Ptr C'GArray -> C'gboolean -> IO (Ptr C'gchar))