#define ENABLE_OVERLOADING (MIN_VERSION_haskell_gi_overloading(1,0,0) \
&& !defined(__HADDOCK_VERSION__))
module GI.Poppler.Structs.LayersIter
(
LayersIter(..) ,
noLayersIter ,
#if ENABLE_OVERLOADING
LayersIterCopyMethodInfo ,
#endif
layersIterCopy ,
#if ENABLE_OVERLOADING
LayersIterFreeMethodInfo ,
#endif
layersIterFree ,
#if ENABLE_OVERLOADING
LayersIterGetChildMethodInfo ,
#endif
layersIterGetChild ,
#if ENABLE_OVERLOADING
LayersIterGetLayerMethodInfo ,
#endif
layersIterGetLayer ,
#if ENABLE_OVERLOADING
LayersIterGetTitleMethodInfo ,
#endif
layersIterGetTitle ,
layersIterNew ,
#if ENABLE_OVERLOADING
LayersIterNextMethodInfo ,
#endif
layersIterNext ,
) where
import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P
import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GValue as B.GValue
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.GI.Base.Properties as B.Properties
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GHC.OverloadedLabels as OL
import {-# SOURCE #-} qualified GI.Poppler.Objects.Document as Poppler.Document
import {-# SOURCE #-} qualified GI.Poppler.Objects.Layer as Poppler.Layer
newtype LayersIter = LayersIter (ManagedPtr LayersIter)
foreign import ccall "poppler_layers_iter_get_type" c_poppler_layers_iter_get_type ::
IO GType
instance BoxedObject LayersIter where
boxedType _ = c_poppler_layers_iter_get_type
noLayersIter :: Maybe LayersIter
noLayersIter = Nothing
#if ENABLE_OVERLOADING
instance O.HasAttributeList LayersIter
type instance O.AttributeList LayersIter = LayersIterAttributeList
type LayersIterAttributeList = ('[ ] :: [(Symbol, *)])
#endif
foreign import ccall "poppler_layers_iter_new" poppler_layers_iter_new ::
Ptr Poppler.Document.Document ->
IO (Ptr LayersIter)
layersIterNew ::
(B.CallStack.HasCallStack, MonadIO m, Poppler.Document.IsDocument a) =>
a
-> m LayersIter
layersIterNew document = liftIO $ do
document' <- unsafeManagedPtrCastPtr document
result <- poppler_layers_iter_new document'
checkUnexpectedReturnNULL "layersIterNew" result
result' <- (wrapBoxed LayersIter) result
touchManagedPtr document
return result'
#if ENABLE_OVERLOADING
#endif
foreign import ccall "poppler_layers_iter_copy" poppler_layers_iter_copy ::
Ptr LayersIter ->
IO (Ptr LayersIter)
layersIterCopy ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m LayersIter
layersIterCopy iter = liftIO $ do
iter' <- unsafeManagedPtrGetPtr iter
result <- poppler_layers_iter_copy iter'
checkUnexpectedReturnNULL "layersIterCopy" result
result' <- (wrapBoxed LayersIter) result
touchManagedPtr iter
return result'
#if ENABLE_OVERLOADING
data LayersIterCopyMethodInfo
instance (signature ~ (m LayersIter), MonadIO m) => O.MethodInfo LayersIterCopyMethodInfo LayersIter signature where
overloadedMethod _ = layersIterCopy
#endif
foreign import ccall "poppler_layers_iter_free" poppler_layers_iter_free ::
Ptr LayersIter ->
IO ()
layersIterFree ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m ()
layersIterFree iter = liftIO $ do
iter' <- unsafeManagedPtrGetPtr iter
poppler_layers_iter_free iter'
touchManagedPtr iter
return ()
#if ENABLE_OVERLOADING
data LayersIterFreeMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.MethodInfo LayersIterFreeMethodInfo LayersIter signature where
overloadedMethod _ = layersIterFree
#endif
foreign import ccall "poppler_layers_iter_get_child" poppler_layers_iter_get_child ::
Ptr LayersIter ->
IO (Ptr LayersIter)
layersIterGetChild ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m LayersIter
layersIterGetChild parent = liftIO $ do
parent' <- unsafeManagedPtrGetPtr parent
result <- poppler_layers_iter_get_child parent'
checkUnexpectedReturnNULL "layersIterGetChild" result
result' <- (wrapBoxed LayersIter) result
touchManagedPtr parent
return result'
#if ENABLE_OVERLOADING
data LayersIterGetChildMethodInfo
instance (signature ~ (m LayersIter), MonadIO m) => O.MethodInfo LayersIterGetChildMethodInfo LayersIter signature where
overloadedMethod _ = layersIterGetChild
#endif
foreign import ccall "poppler_layers_iter_get_layer" poppler_layers_iter_get_layer ::
Ptr LayersIter ->
IO (Ptr Poppler.Layer.Layer)
layersIterGetLayer ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m Poppler.Layer.Layer
layersIterGetLayer iter = liftIO $ do
iter' <- unsafeManagedPtrGetPtr iter
result <- poppler_layers_iter_get_layer iter'
checkUnexpectedReturnNULL "layersIterGetLayer" result
result' <- (wrapObject Poppler.Layer.Layer) result
touchManagedPtr iter
return result'
#if ENABLE_OVERLOADING
data LayersIterGetLayerMethodInfo
instance (signature ~ (m Poppler.Layer.Layer), MonadIO m) => O.MethodInfo LayersIterGetLayerMethodInfo LayersIter signature where
overloadedMethod _ = layersIterGetLayer
#endif
foreign import ccall "poppler_layers_iter_get_title" poppler_layers_iter_get_title ::
Ptr LayersIter ->
IO CString
layersIterGetTitle ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m T.Text
layersIterGetTitle iter = liftIO $ do
iter' <- unsafeManagedPtrGetPtr iter
result <- poppler_layers_iter_get_title iter'
checkUnexpectedReturnNULL "layersIterGetTitle" result
result' <- cstringToText result
freeMem result
touchManagedPtr iter
return result'
#if ENABLE_OVERLOADING
data LayersIterGetTitleMethodInfo
instance (signature ~ (m T.Text), MonadIO m) => O.MethodInfo LayersIterGetTitleMethodInfo LayersIter signature where
overloadedMethod _ = layersIterGetTitle
#endif
foreign import ccall "poppler_layers_iter_next" poppler_layers_iter_next ::
Ptr LayersIter ->
IO CInt
layersIterNext ::
(B.CallStack.HasCallStack, MonadIO m) =>
LayersIter
-> m Bool
layersIterNext iter = liftIO $ do
iter' <- unsafeManagedPtrGetPtr iter
result <- poppler_layers_iter_next iter'
let result' = (/= 0) result
touchManagedPtr iter
return result'
#if ENABLE_OVERLOADING
data LayersIterNextMethodInfo
instance (signature ~ (m Bool), MonadIO m) => O.MethodInfo LayersIterNextMethodInfo LayersIter signature where
overloadedMethod _ = layersIterNext
#endif
#if ENABLE_OVERLOADING
type family ResolveLayersIterMethod (t :: Symbol) (o :: *) :: * where
ResolveLayersIterMethod "copy" o = LayersIterCopyMethodInfo
ResolveLayersIterMethod "free" o = LayersIterFreeMethodInfo
ResolveLayersIterMethod "next" o = LayersIterNextMethodInfo
ResolveLayersIterMethod "getChild" o = LayersIterGetChildMethodInfo
ResolveLayersIterMethod "getLayer" o = LayersIterGetLayerMethodInfo
ResolveLayersIterMethod "getTitle" o = LayersIterGetTitleMethodInfo
ResolveLayersIterMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveLayersIterMethod t LayersIter, O.MethodInfo info LayersIter p) => OL.IsLabel t (LayersIter -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#else
fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
#endif