{- | Copyright : Will Thompson, Iñaki García Etxebarria and Jonas Platte License : LGPL-2.1 Maintainer : Iñaki García Etxebarria (garetxe@gmail.com) The #GSequenceIter struct is an opaque data type representing an iterator pointing into a #GSequence. -} module GI.GLib.Structs.SequenceIter ( -- * Exported types SequenceIter(..) , noSequenceIter , -- * Methods -- ** sequenceIterCompare sequenceIterCompare , -- ** sequenceIterGetPosition sequenceIterGetPosition , -- ** sequenceIterIsBegin sequenceIterIsBegin , -- ** sequenceIterIsEnd sequenceIterIsEnd , ) where import Prelude () import Data.GI.Base.ShortPrelude import qualified Data.Text as T import qualified Data.ByteString.Char8 as B import qualified Data.Map as Map import GI.GLib.Types import GI.GLib.Callbacks newtype SequenceIter = SequenceIter (ForeignPtr SequenceIter) noSequenceIter :: Maybe SequenceIter noSequenceIter = Nothing -- method SequenceIter::compare -- method type : OrdinaryMethod -- Args : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing},Arg {argName = "b", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- Lengths : [] -- hInArgs : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing},Arg {argName = "b", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- returnType : TBasicType TInt32 -- throws : False -- Skip return : False foreign import ccall "g_sequence_iter_compare" g_sequence_iter_compare :: Ptr SequenceIter -> -- _obj : TInterface "GLib" "SequenceIter" Ptr SequenceIter -> -- b : TInterface "GLib" "SequenceIter" IO Int32 sequenceIterCompare :: (MonadIO m) => SequenceIter -> -- _obj SequenceIter -> -- b m Int32 sequenceIterCompare _obj b = liftIO $ do let _obj' = unsafeManagedPtrGetPtr _obj let b' = unsafeManagedPtrGetPtr b result <- g_sequence_iter_compare _obj' b' touchManagedPtr _obj touchManagedPtr b return result -- method SequenceIter::get_position -- method type : OrdinaryMethod -- Args : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- Lengths : [] -- hInArgs : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- returnType : TBasicType TInt32 -- throws : False -- Skip return : False foreign import ccall "g_sequence_iter_get_position" g_sequence_iter_get_position :: Ptr SequenceIter -> -- _obj : TInterface "GLib" "SequenceIter" IO Int32 sequenceIterGetPosition :: (MonadIO m) => SequenceIter -> -- _obj m Int32 sequenceIterGetPosition _obj = liftIO $ do let _obj' = unsafeManagedPtrGetPtr _obj result <- g_sequence_iter_get_position _obj' touchManagedPtr _obj return result -- method SequenceIter::is_begin -- method type : OrdinaryMethod -- Args : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- Lengths : [] -- hInArgs : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- returnType : TBasicType TBoolean -- throws : False -- Skip return : False foreign import ccall "g_sequence_iter_is_begin" g_sequence_iter_is_begin :: Ptr SequenceIter -> -- _obj : TInterface "GLib" "SequenceIter" IO CInt sequenceIterIsBegin :: (MonadIO m) => SequenceIter -> -- _obj m Bool sequenceIterIsBegin _obj = liftIO $ do let _obj' = unsafeManagedPtrGetPtr _obj result <- g_sequence_iter_is_begin _obj' let result' = (/= 0) result touchManagedPtr _obj return result' -- method SequenceIter::is_end -- method type : OrdinaryMethod -- Args : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- Lengths : [] -- hInArgs : [Arg {argName = "_obj", argType = TInterface "GLib" "SequenceIter", direction = DirectionIn, mayBeNull = False, argScope = ScopeTypeInvalid, argClosure = -1, argDestroy = -1, transfer = TransferNothing}] -- returnType : TBasicType TBoolean -- throws : False -- Skip return : False foreign import ccall "g_sequence_iter_is_end" g_sequence_iter_is_end :: Ptr SequenceIter -> -- _obj : TInterface "GLib" "SequenceIter" IO CInt sequenceIterIsEnd :: (MonadIO m) => SequenceIter -> -- _obj m Bool sequenceIterIsEnd _obj = liftIO $ do let _obj' = unsafeManagedPtrGetPtr _obj result <- g_sequence_iter_is_end _obj' let result' = (/= 0) result touchManagedPtr _obj return result'