{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.WebKit2WebExtension.Interfaces.DOMXPathNSResolver
(
DOMXPathNSResolver(..) ,
IsDOMXPathNSResolver ,
toDOMXPathNSResolver ,
#if defined(ENABLE_OVERLOADING)
ResolveDOMXPathNSResolverMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
DOMXPathNSResolverLookupNamespaceUriMethodInfo,
#endif
dOMXPathNSResolverLookupNamespaceUri ,
) 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.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.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
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 qualified GI.GObject.Objects.Object as GObject.Object
newtype DOMXPathNSResolver = DOMXPathNSResolver (SP.ManagedPtr DOMXPathNSResolver)
deriving (DOMXPathNSResolver -> DOMXPathNSResolver -> Bool
(DOMXPathNSResolver -> DOMXPathNSResolver -> Bool)
-> (DOMXPathNSResolver -> DOMXPathNSResolver -> Bool)
-> Eq DOMXPathNSResolver
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DOMXPathNSResolver -> DOMXPathNSResolver -> Bool
$c/= :: DOMXPathNSResolver -> DOMXPathNSResolver -> Bool
== :: DOMXPathNSResolver -> DOMXPathNSResolver -> Bool
$c== :: DOMXPathNSResolver -> DOMXPathNSResolver -> Bool
Eq)
instance SP.ManagedPtrNewtype DOMXPathNSResolver where
toManagedPtr :: DOMXPathNSResolver -> ManagedPtr DOMXPathNSResolver
toManagedPtr (DOMXPathNSResolver ManagedPtr DOMXPathNSResolver
p) = ManagedPtr DOMXPathNSResolver
p
foreign import ccall "webkit_dom_xpath_ns_resolver_get_type"
c_webkit_dom_xpath_ns_resolver_get_type :: IO B.Types.GType
instance B.Types.TypedObject DOMXPathNSResolver where
glibType :: IO GType
glibType = IO GType
c_webkit_dom_xpath_ns_resolver_get_type
instance B.Types.GObject DOMXPathNSResolver
instance B.GValue.IsGValue DOMXPathNSResolver where
toGValue :: DOMXPathNSResolver -> IO GValue
toGValue DOMXPathNSResolver
o = do
GType
gtype <- IO GType
c_webkit_dom_xpath_ns_resolver_get_type
DOMXPathNSResolver
-> (Ptr DOMXPathNSResolver -> IO GValue) -> IO GValue
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr DOMXPathNSResolver
o (GType
-> (GValue -> Ptr DOMXPathNSResolver -> IO ())
-> Ptr DOMXPathNSResolver
-> IO GValue
forall a. GType -> (GValue -> a -> IO ()) -> a -> IO GValue
B.GValue.buildGValue GType
gtype GValue -> Ptr DOMXPathNSResolver -> IO ()
forall a. GObject a => GValue -> Ptr a -> IO ()
B.GValue.set_object)
fromGValue :: GValue -> IO DOMXPathNSResolver
fromGValue GValue
gv = do
Ptr DOMXPathNSResolver
ptr <- GValue -> IO (Ptr DOMXPathNSResolver)
forall b. GObject b => GValue -> IO (Ptr b)
B.GValue.get_object GValue
gv :: IO (Ptr DOMXPathNSResolver)
(ManagedPtr DOMXPathNSResolver -> DOMXPathNSResolver)
-> Ptr DOMXPathNSResolver -> IO DOMXPathNSResolver
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr DOMXPathNSResolver -> DOMXPathNSResolver
DOMXPathNSResolver Ptr DOMXPathNSResolver
ptr
class (SP.GObject o, O.IsDescendantOf DOMXPathNSResolver o) => IsDOMXPathNSResolver o
instance (SP.GObject o, O.IsDescendantOf DOMXPathNSResolver o) => IsDOMXPathNSResolver o
instance O.HasParentTypes DOMXPathNSResolver
type instance O.ParentTypes DOMXPathNSResolver = '[GObject.Object.Object]
toDOMXPathNSResolver :: (MonadIO m, IsDOMXPathNSResolver o) => o -> m DOMXPathNSResolver
toDOMXPathNSResolver :: o -> m DOMXPathNSResolver
toDOMXPathNSResolver = IO DOMXPathNSResolver -> m DOMXPathNSResolver
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO DOMXPathNSResolver -> m DOMXPathNSResolver)
-> (o -> IO DOMXPathNSResolver) -> o -> m DOMXPathNSResolver
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr DOMXPathNSResolver -> DOMXPathNSResolver)
-> o -> IO DOMXPathNSResolver
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
unsafeCastTo ManagedPtr DOMXPathNSResolver -> DOMXPathNSResolver
DOMXPathNSResolver
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList DOMXPathNSResolver
type instance O.AttributeList DOMXPathNSResolver = DOMXPathNSResolverAttributeList
type DOMXPathNSResolverAttributeList = ('[ ] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING)
#endif
#if defined(ENABLE_OVERLOADING)
type family ResolveDOMXPathNSResolverMethod (t :: Symbol) (o :: *) :: * where
ResolveDOMXPathNSResolverMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveDOMXPathNSResolverMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveDOMXPathNSResolverMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveDOMXPathNSResolverMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveDOMXPathNSResolverMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveDOMXPathNSResolverMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveDOMXPathNSResolverMethod "lookupNamespaceUri" o = DOMXPathNSResolverLookupNamespaceUriMethodInfo
ResolveDOMXPathNSResolverMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveDOMXPathNSResolverMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveDOMXPathNSResolverMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveDOMXPathNSResolverMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveDOMXPathNSResolverMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveDOMXPathNSResolverMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveDOMXPathNSResolverMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveDOMXPathNSResolverMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveDOMXPathNSResolverMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveDOMXPathNSResolverMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveDOMXPathNSResolverMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveDOMXPathNSResolverMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveDOMXPathNSResolverMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveDOMXPathNSResolverMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveDOMXPathNSResolverMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveDOMXPathNSResolverMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveDOMXPathNSResolverMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveDOMXPathNSResolverMethod t DOMXPathNSResolver, O.MethodInfo info DOMXPathNSResolver p) => OL.IsLabel t (DOMXPathNSResolver -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod @info
#else
fromLabel _ = O.overloadedMethod @info
#endif
#endif
foreign import ccall "webkit_dom_xpath_ns_resolver_lookup_namespace_uri" webkit_dom_xpath_ns_resolver_lookup_namespace_uri ::
Ptr DOMXPathNSResolver ->
CString ->
IO CString
{-# DEPRECATED dOMXPathNSResolverLookupNamespaceUri ["(Since version 2.22)","Use JavaScriptCore API instead"] #-}
dOMXPathNSResolverLookupNamespaceUri ::
(B.CallStack.HasCallStack, MonadIO m, IsDOMXPathNSResolver a) =>
a
-> T.Text
-> m T.Text
dOMXPathNSResolverLookupNamespaceUri :: a -> Text -> m Text
dOMXPathNSResolverLookupNamespaceUri a
resolver Text
prefix = IO Text -> m Text
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
Ptr DOMXPathNSResolver
resolver' <- a -> IO (Ptr DOMXPathNSResolver)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
resolver
CString
prefix' <- Text -> IO CString
textToCString Text
prefix
CString
result <- Ptr DOMXPathNSResolver -> CString -> IO CString
webkit_dom_xpath_ns_resolver_lookup_namespace_uri Ptr DOMXPathNSResolver
resolver' CString
prefix'
Text -> CString -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"dOMXPathNSResolverLookupNamespaceUri" CString
result
Text
result' <- HasCallStack => CString -> IO Text
CString -> IO Text
cstringToText CString
result
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
resolver
CString -> IO ()
forall a. Ptr a -> IO ()
freeMem CString
prefix'
Text -> IO Text
forall (m :: * -> *) a. Monad m => a -> m a
return Text
result'
#if defined(ENABLE_OVERLOADING)
data DOMXPathNSResolverLookupNamespaceUriMethodInfo
instance (signature ~ (T.Text -> m T.Text), MonadIO m, IsDOMXPathNSResolver a) => O.MethodInfo DOMXPathNSResolverLookupNamespaceUriMethodInfo a signature where
overloadedMethod = dOMXPathNSResolverLookupNamespaceUri
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList DOMXPathNSResolver = DOMXPathNSResolverSignalList
type DOMXPathNSResolverSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif