{-# LANGUAGE TypeApplications #-}
#if !defined(__HADDOCK_VERSION__)
#define ENABLE_OVERLOADING
#endif
module GI.GLib.Structs.MarkupParseContext
(
MarkupParseContext(..) ,
#if defined(ENABLE_OVERLOADING)
ResolveMarkupParseContextMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
MarkupParseContextEndParseMethodInfo ,
#endif
markupParseContextEndParse ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextFreeMethodInfo ,
#endif
markupParseContextFree ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextGetElementMethodInfo ,
#endif
markupParseContextGetElement ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextGetElementStackMethodInfo,
#endif
markupParseContextGetElementStack ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextGetOffsetMethodInfo ,
#endif
markupParseContextGetOffset ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextGetPositionMethodInfo ,
#endif
markupParseContextGetPosition ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextGetUserDataMethodInfo ,
#endif
markupParseContextGetUserData ,
markupParseContextNew ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextParseMethodInfo ,
#endif
markupParseContextParse ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextPopMethodInfo ,
#endif
markupParseContextPop ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextPushMethodInfo ,
#endif
markupParseContextPush ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextRefMethodInfo ,
#endif
markupParseContextRef ,
#if defined(ENABLE_OVERLOADING)
MarkupParseContextUnrefMethodInfo ,
#endif
markupParseContextUnref ,
) 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.BasicTypes as B.Types
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GArray as B.GArray
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GHashTable as B.GHT
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.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
import qualified Data.Coerce as Coerce
import qualified Data.Text as T
import qualified Data.Kind as DK
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 qualified GHC.Records as R
import qualified Data.Word as DW
import qualified Data.Int as DI
import qualified System.Posix.Types as SPT
import qualified Foreign.C.Types as FCT
#if MIN_VERSION_base(4,18,0)
import qualified GI.GLib.Callbacks as GLib.Callbacks
import {-# SOURCE #-} qualified GI.GLib.Flags as GLib.Flags
import {-# SOURCE #-} qualified GI.GLib.Structs.MarkupParser as GLib.MarkupParser
#else
import qualified GI.GLib.Callbacks as GLib.Callbacks
import {-# SOURCE #-} qualified GI.GLib.Flags as GLib.Flags
import {-# SOURCE #-} qualified GI.GLib.Structs.MarkupParser as GLib.MarkupParser
#endif
newtype MarkupParseContext = MarkupParseContext (SP.ManagedPtr MarkupParseContext)
deriving (MarkupParseContext -> MarkupParseContext -> Bool
(MarkupParseContext -> MarkupParseContext -> Bool)
-> (MarkupParseContext -> MarkupParseContext -> Bool)
-> Eq MarkupParseContext
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: MarkupParseContext -> MarkupParseContext -> Bool
== :: MarkupParseContext -> MarkupParseContext -> Bool
$c/= :: MarkupParseContext -> MarkupParseContext -> Bool
/= :: MarkupParseContext -> MarkupParseContext -> Bool
Eq)
instance SP.ManagedPtrNewtype MarkupParseContext where
toManagedPtr :: MarkupParseContext -> ManagedPtr MarkupParseContext
toManagedPtr (MarkupParseContext ManagedPtr MarkupParseContext
p) = ManagedPtr MarkupParseContext
p
foreign import ccall "g_markup_parse_context_get_type" c_g_markup_parse_context_get_type ::
IO GType
type instance O.ParentTypes MarkupParseContext = '[]
instance O.HasParentTypes MarkupParseContext
instance B.Types.TypedObject MarkupParseContext where
glibType :: IO GType
glibType = IO GType
c_g_markup_parse_context_get_type
instance B.Types.GBoxed MarkupParseContext
instance B.GValue.IsGValue (Maybe MarkupParseContext) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_g_markup_parse_context_get_type
gvalueSet_ :: Ptr GValue -> Maybe MarkupParseContext -> IO ()
gvalueSet_ Ptr GValue
gv Maybe MarkupParseContext
P.Nothing = Ptr GValue -> Ptr MarkupParseContext -> IO ()
forall a. Ptr GValue -> Ptr a -> IO ()
B.GValue.set_boxed Ptr GValue
gv (Ptr MarkupParseContext
forall a. Ptr a
FP.nullPtr :: FP.Ptr MarkupParseContext)
gvalueSet_ Ptr GValue
gv (P.Just MarkupParseContext
obj) = MarkupParseContext -> (Ptr MarkupParseContext -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr MarkupParseContext
obj (Ptr GValue -> Ptr MarkupParseContext -> IO ()
forall a. Ptr GValue -> Ptr a -> IO ()
B.GValue.set_boxed Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe MarkupParseContext)
gvalueGet_ Ptr GValue
gv = do
ptr <- Ptr GValue -> IO (Ptr MarkupParseContext)
forall b. Ptr GValue -> IO (Ptr b)
B.GValue.get_boxed Ptr GValue
gv :: IO (Ptr MarkupParseContext)
if ptr /= FP.nullPtr
then P.Just <$> B.ManagedPtr.newBoxed MarkupParseContext ptr
else return P.Nothing
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList MarkupParseContext
type instance O.AttributeList MarkupParseContext = MarkupParseContextAttributeList
type MarkupParseContextAttributeList = ('[ ] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "g_markup_parse_context_new" g_markup_parse_context_new ::
Ptr GLib.MarkupParser.MarkupParser ->
CUInt ->
Ptr () ->
FunPtr GLib.Callbacks.C_DestroyNotify ->
IO (Ptr MarkupParseContext)
markupParseContextNew ::
(B.CallStack.HasCallStack, MonadIO m) =>
GLib.MarkupParser.MarkupParser
-> [GLib.Flags.MarkupParseFlags]
-> Ptr ()
-> GLib.Callbacks.DestroyNotify
-> m MarkupParseContext
markupParseContextNew :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParser
-> [MarkupParseFlags]
-> Ptr ()
-> DestroyNotify
-> m MarkupParseContext
markupParseContextNew MarkupParser
parser [MarkupParseFlags]
flags Ptr ()
userData DestroyNotify
userDataDnotify = IO MarkupParseContext -> m MarkupParseContext
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO MarkupParseContext -> m MarkupParseContext)
-> IO MarkupParseContext -> m MarkupParseContext
forall a b. (a -> b) -> a -> b
$ do
parser' <- MarkupParser -> IO (Ptr MarkupParser)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParser
parser
let flags' = [MarkupParseFlags] -> CUInt
forall b a. (Num b, IsGFlag a) => [a] -> b
gflagsToWord [MarkupParseFlags]
flags
ptruserDataDnotify <- callocMem :: IO (Ptr (FunPtr GLib.Callbacks.C_DestroyNotify))
userDataDnotify' <- GLib.Callbacks.mk_DestroyNotify (GLib.Callbacks.wrap_DestroyNotify (Just ptruserDataDnotify) userDataDnotify)
poke ptruserDataDnotify userDataDnotify'
result <- g_markup_parse_context_new parser' flags' userData userDataDnotify'
checkUnexpectedReturnNULL "markupParseContextNew" result
result' <- (wrapBoxed MarkupParseContext) result
touchManagedPtr parser
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "g_markup_parse_context_end_parse" g_markup_parse_context_end_parse ::
Ptr MarkupParseContext ->
Ptr (Ptr GError) ->
IO CInt
markupParseContextEndParse ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m ()
markupParseContextEndParse :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m ()
markupParseContextEndParse MarkupParseContext
context = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
onException (do
_ <- propagateGError $ g_markup_parse_context_end_parse context'
touchManagedPtr context
return ()
) (do
return ()
)
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextEndParseMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.OverloadedMethod MarkupParseContextEndParseMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextEndParse
instance O.OverloadedMethodInfo MarkupParseContextEndParseMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextEndParse",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextEndParse"
})
#endif
foreign import ccall "g_markup_parse_context_free" g_markup_parse_context_free ::
Ptr MarkupParseContext ->
IO ()
markupParseContextFree ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m ()
markupParseContextFree :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m ()
markupParseContextFree MarkupParseContext
context = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
g_markup_parse_context_free context'
touchManagedPtr context
return ()
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextFreeMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.OverloadedMethod MarkupParseContextFreeMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextFree
instance O.OverloadedMethodInfo MarkupParseContextFreeMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextFree",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextFree"
})
#endif
foreign import ccall "g_markup_parse_context_get_element" g_markup_parse_context_get_element ::
Ptr MarkupParseContext ->
IO CString
markupParseContextGetElement ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m T.Text
markupParseContextGetElement :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m Text
markupParseContextGetElement MarkupParseContext
context = IO Text -> m Text
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Text -> m Text) -> IO Text -> m Text
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_get_element context'
checkUnexpectedReturnNULL "markupParseContextGetElement" result
result' <- cstringToText result
touchManagedPtr context
return result'
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextGetElementMethodInfo
instance (signature ~ (m T.Text), MonadIO m) => O.OverloadedMethod MarkupParseContextGetElementMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextGetElement
instance O.OverloadedMethodInfo MarkupParseContextGetElementMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextGetElement",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextGetElement"
})
#endif
foreign import ccall "g_markup_parse_context_get_element_stack" g_markup_parse_context_get_element_stack ::
Ptr MarkupParseContext ->
IO (Ptr (GSList CString))
markupParseContextGetElementStack ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m [T.Text]
markupParseContextGetElementStack :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m [Text]
markupParseContextGetElementStack MarkupParseContext
context = IO [Text] -> m [Text]
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO [Text] -> m [Text]) -> IO [Text] -> m [Text]
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_get_element_stack context'
result' <- unpackGSList result
result'' <- mapM cstringToText result'
touchManagedPtr context
return result''
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextGetElementStackMethodInfo
instance (signature ~ (m [T.Text]), MonadIO m) => O.OverloadedMethod MarkupParseContextGetElementStackMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextGetElementStack
instance O.OverloadedMethodInfo MarkupParseContextGetElementStackMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextGetElementStack",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextGetElementStack"
})
#endif
foreign import ccall "g_markup_parse_context_get_offset" g_markup_parse_context_get_offset ::
Ptr MarkupParseContext ->
IO FCT.CSize
markupParseContextGetOffset ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m FCT.CSize
markupParseContextGetOffset :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m CSize
markupParseContextGetOffset MarkupParseContext
context = IO CSize -> m CSize
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO CSize -> m CSize) -> IO CSize -> m CSize
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_get_offset context'
touchManagedPtr context
return result
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextGetOffsetMethodInfo
instance (signature ~ (m FCT.CSize), MonadIO m) => O.OverloadedMethod MarkupParseContextGetOffsetMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextGetOffset
instance O.OverloadedMethodInfo MarkupParseContextGetOffsetMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextGetOffset",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextGetOffset"
})
#endif
foreign import ccall "g_markup_parse_context_get_position" g_markup_parse_context_get_position ::
Ptr MarkupParseContext ->
Ptr Int32 ->
Ptr Int32 ->
IO ()
markupParseContextGetPosition ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m ((Int32, Int32))
markupParseContextGetPosition :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m (Int32, Int32)
markupParseContextGetPosition MarkupParseContext
context = IO (Int32, Int32) -> m (Int32, Int32)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Int32, Int32) -> m (Int32, Int32))
-> IO (Int32, Int32) -> m (Int32, Int32)
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
lineNumber <- allocMem :: IO (Ptr Int32)
charNumber <- allocMem :: IO (Ptr Int32)
g_markup_parse_context_get_position context' lineNumber charNumber
lineNumber' <- peek lineNumber
charNumber' <- peek charNumber
touchManagedPtr context
freeMem lineNumber
freeMem charNumber
return (lineNumber', charNumber')
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextGetPositionMethodInfo
instance (signature ~ (m ((Int32, Int32))), MonadIO m) => O.OverloadedMethod MarkupParseContextGetPositionMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextGetPosition
instance O.OverloadedMethodInfo MarkupParseContextGetPositionMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextGetPosition",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextGetPosition"
})
#endif
foreign import ccall "g_markup_parse_context_get_user_data" g_markup_parse_context_get_user_data ::
Ptr MarkupParseContext ->
IO (Ptr ())
markupParseContextGetUserData ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m (Ptr ())
markupParseContextGetUserData :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m (Ptr ())
markupParseContextGetUserData MarkupParseContext
context = IO (Ptr ()) -> m (Ptr ())
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Ptr ()) -> m (Ptr ())) -> IO (Ptr ()) -> m (Ptr ())
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_get_user_data context'
touchManagedPtr context
return result
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextGetUserDataMethodInfo
instance (signature ~ (m (Ptr ())), MonadIO m) => O.OverloadedMethod MarkupParseContextGetUserDataMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextGetUserData
instance O.OverloadedMethodInfo MarkupParseContextGetUserDataMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextGetUserData",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextGetUserData"
})
#endif
foreign import ccall "g_markup_parse_context_parse" g_markup_parse_context_parse ::
Ptr MarkupParseContext ->
CString ->
DI.Int64 ->
Ptr (Ptr GError) ->
IO CInt
markupParseContextParse ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> T.Text
-> DI.Int64
-> m ()
markupParseContextParse :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> Text -> Int64 -> m ()
markupParseContextParse MarkupParseContext
context Text
text Int64
textLen = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
text' <- textToCString text
onException (do
_ <- propagateGError $ g_markup_parse_context_parse context' text' textLen
touchManagedPtr context
freeMem text'
return ()
) (do
freeMem text'
)
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextParseMethodInfo
instance (signature ~ (T.Text -> DI.Int64 -> m ()), MonadIO m) => O.OverloadedMethod MarkupParseContextParseMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextParse
instance O.OverloadedMethodInfo MarkupParseContextParseMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextParse",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextParse"
})
#endif
foreign import ccall "g_markup_parse_context_pop" g_markup_parse_context_pop ::
Ptr MarkupParseContext ->
IO (Ptr ())
markupParseContextPop ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m (Ptr ())
markupParseContextPop :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m (Ptr ())
markupParseContextPop MarkupParseContext
context = IO (Ptr ()) -> m (Ptr ())
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Ptr ()) -> m (Ptr ())) -> IO (Ptr ()) -> m (Ptr ())
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_pop context'
touchManagedPtr context
return result
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextPopMethodInfo
instance (signature ~ (m (Ptr ())), MonadIO m) => O.OverloadedMethod MarkupParseContextPopMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextPop
instance O.OverloadedMethodInfo MarkupParseContextPopMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextPop",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextPop"
})
#endif
foreign import ccall "g_markup_parse_context_push" g_markup_parse_context_push ::
Ptr MarkupParseContext ->
Ptr GLib.MarkupParser.MarkupParser ->
Ptr () ->
IO ()
markupParseContextPush ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> GLib.MarkupParser.MarkupParser
-> Ptr ()
-> m ()
markupParseContextPush :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> MarkupParser -> Ptr () -> m ()
markupParseContextPush MarkupParseContext
context MarkupParser
parser Ptr ()
userData = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
parser' <- unsafeManagedPtrGetPtr parser
g_markup_parse_context_push context' parser' userData
touchManagedPtr context
touchManagedPtr parser
return ()
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextPushMethodInfo
instance (signature ~ (GLib.MarkupParser.MarkupParser -> Ptr () -> m ()), MonadIO m) => O.OverloadedMethod MarkupParseContextPushMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextPush
instance O.OverloadedMethodInfo MarkupParseContextPushMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextPush",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextPush"
})
#endif
foreign import ccall "g_markup_parse_context_ref" g_markup_parse_context_ref ::
Ptr MarkupParseContext ->
IO (Ptr MarkupParseContext)
markupParseContextRef ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m MarkupParseContext
markupParseContextRef :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m MarkupParseContext
markupParseContextRef MarkupParseContext
context = IO MarkupParseContext -> m MarkupParseContext
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO MarkupParseContext -> m MarkupParseContext)
-> IO MarkupParseContext -> m MarkupParseContext
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
result <- g_markup_parse_context_ref context'
checkUnexpectedReturnNULL "markupParseContextRef" result
result' <- (wrapBoxed MarkupParseContext) result
touchManagedPtr context
return result'
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextRefMethodInfo
instance (signature ~ (m MarkupParseContext), MonadIO m) => O.OverloadedMethod MarkupParseContextRefMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextRef
instance O.OverloadedMethodInfo MarkupParseContextRefMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextRef",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextRef"
})
#endif
foreign import ccall "g_markup_parse_context_unref" g_markup_parse_context_unref ::
Ptr MarkupParseContext ->
IO ()
markupParseContextUnref ::
(B.CallStack.HasCallStack, MonadIO m) =>
MarkupParseContext
-> m ()
markupParseContextUnref :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
MarkupParseContext -> m ()
markupParseContextUnref MarkupParseContext
context = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
context' <- MarkupParseContext -> IO (Ptr MarkupParseContext)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr MarkupParseContext
context
g_markup_parse_context_unref context'
touchManagedPtr context
return ()
#if defined(ENABLE_OVERLOADING)
data MarkupParseContextUnrefMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.OverloadedMethod MarkupParseContextUnrefMethodInfo MarkupParseContext signature where
overloadedMethod = markupParseContextUnref
instance O.OverloadedMethodInfo MarkupParseContextUnrefMethodInfo MarkupParseContext where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.GLib.Structs.MarkupParseContext.markupParseContextUnref",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-glib-2.0.30/docs/GI-GLib-Structs-MarkupParseContext.html#v:markupParseContextUnref"
})
#endif
#if defined(ENABLE_OVERLOADING)
type family ResolveMarkupParseContextMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveMarkupParseContextMethod "endParse" o = MarkupParseContextEndParseMethodInfo
ResolveMarkupParseContextMethod "free" o = MarkupParseContextFreeMethodInfo
ResolveMarkupParseContextMethod "parse" o = MarkupParseContextParseMethodInfo
ResolveMarkupParseContextMethod "pop" o = MarkupParseContextPopMethodInfo
ResolveMarkupParseContextMethod "push" o = MarkupParseContextPushMethodInfo
ResolveMarkupParseContextMethod "ref" o = MarkupParseContextRefMethodInfo
ResolveMarkupParseContextMethod "unref" o = MarkupParseContextUnrefMethodInfo
ResolveMarkupParseContextMethod "getElement" o = MarkupParseContextGetElementMethodInfo
ResolveMarkupParseContextMethod "getElementStack" o = MarkupParseContextGetElementStackMethodInfo
ResolveMarkupParseContextMethod "getOffset" o = MarkupParseContextGetOffsetMethodInfo
ResolveMarkupParseContextMethod "getPosition" o = MarkupParseContextGetPositionMethodInfo
ResolveMarkupParseContextMethod "getUserData" o = MarkupParseContextGetUserDataMethodInfo
ResolveMarkupParseContextMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveMarkupParseContextMethod t MarkupParseContext, O.OverloadedMethod info MarkupParseContext p) => OL.IsLabel t (MarkupParseContext -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod @info
#else
fromLabel _ = O.overloadedMethod @info
#endif
#if MIN_VERSION_base(4,13,0)
instance (info ~ ResolveMarkupParseContextMethod t MarkupParseContext, O.OverloadedMethod info MarkupParseContext p, R.HasField t MarkupParseContext p) => R.HasField t MarkupParseContext p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveMarkupParseContextMethod t MarkupParseContext, O.OverloadedMethodInfo info MarkupParseContext) => OL.IsLabel t (O.MethodProxy info MarkupParseContext) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif