module GI.Poppler.Structs.LayersIter
(
LayersIter(..) ,
noLayersIter ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
LayersIterCopyMethodInfo ,
#endif
layersIterCopy ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
LayersIterFreeMethodInfo ,
#endif
layersIterFree ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
LayersIterGetChildMethodInfo ,
#endif
layersIterGetChild ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
LayersIterGetLayerMethodInfo ,
#endif
layersIterGetLayer ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
LayersIterGetTitleMethodInfo ,
#endif
layersIterGetTitle ,
layersIterNew ,
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
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 GI.Poppler.Objects.Document as Poppler.Document
import 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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
#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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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 defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
data LayersIterNextMethodInfo
instance (signature ~ (m Bool), MonadIO m) => O.MethodInfo LayersIterNextMethodInfo LayersIter signature where
overloadedMethod _ = layersIterNext
#endif
#if defined(ENABLE_OVERLOADING) && !defined(__HADDOCK_VERSION__)
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) => O.IsLabelProxy t (LayersIter -> p) where
fromLabelProxy _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#if MIN_VERSION_base(4,9,0)
instance (info ~ ResolveLayersIterMethod t LayersIter, O.MethodInfo info LayersIter p) => O.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
#endif