{-# 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.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.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 GHC.Records as R
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
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 :: (MIO.MonadIO m, IsDOMXPathNSResolver o) => o -> m DOMXPathNSResolver
toDOMXPathNSResolver :: forall (m :: * -> *) o.
(MonadIO m, IsDOMXPathNSResolver o) =>
o -> m DOMXPathNSResolver
toDOMXPathNSResolver = IO DOMXPathNSResolver -> m DOMXPathNSResolver
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.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'
B.ManagedPtr.unsafeCastTo ManagedPtr DOMXPathNSResolver -> DOMXPathNSResolver
DOMXPathNSResolver
instance B.GValue.IsGValue (Maybe DOMXPathNSResolver) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_webkit_dom_xpath_ns_resolver_get_type
gvalueSet_ :: Ptr GValue -> Maybe DOMXPathNSResolver -> IO ()
gvalueSet_ Ptr GValue
gv Maybe DOMXPathNSResolver
P.Nothing = Ptr GValue -> Ptr DOMXPathNSResolver -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr DOMXPathNSResolver
forall a. Ptr a
FP.nullPtr :: FP.Ptr DOMXPathNSResolver)
gvalueSet_ Ptr GValue
gv (P.Just DOMXPathNSResolver
obj) = DOMXPathNSResolver -> (Ptr DOMXPathNSResolver -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr DOMXPathNSResolver
obj (Ptr GValue -> Ptr DOMXPathNSResolver -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe DOMXPathNSResolver)
gvalueGet_ Ptr GValue
gv = do
Ptr DOMXPathNSResolver
ptr <- Ptr GValue -> IO (Ptr DOMXPathNSResolver)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr DOMXPathNSResolver)
if Ptr DOMXPathNSResolver
ptr Ptr DOMXPathNSResolver -> Ptr DOMXPathNSResolver -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr DOMXPathNSResolver
forall a. Ptr a
FP.nullPtr
then DOMXPathNSResolver -> Maybe DOMXPathNSResolver
forall a. a -> Maybe a
P.Just (DOMXPathNSResolver -> Maybe DOMXPathNSResolver)
-> IO DOMXPathNSResolver -> IO (Maybe DOMXPathNSResolver)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (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
else Maybe DOMXPathNSResolver -> IO (Maybe DOMXPathNSResolver)
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe DOMXPathNSResolver
forall a. Maybe a
P.Nothing
#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.OverloadedMethod 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
#if MIN_VERSION_base(4,13,0)
instance (info ~ ResolveDOMXPathNSResolverMethod t DOMXPathNSResolver, O.OverloadedMethod info DOMXPathNSResolver p, R.HasField t DOMXPathNSResolver p) => R.HasField t DOMXPathNSResolver p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveDOMXPathNSResolverMethod t DOMXPathNSResolver, O.OverloadedMethodInfo info DOMXPathNSResolver) => OL.IsLabel t (O.MethodProxy info DOMXPathNSResolver) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#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 :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsDOMXPathNSResolver a) =>
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.OverloadedMethod DOMXPathNSResolverLookupNamespaceUriMethodInfo a signature where
overloadedMethod = dOMXPathNSResolverLookupNamespaceUri
instance O.OverloadedMethodInfo DOMXPathNSResolverLookupNamespaceUriMethodInfo a where
overloadedMethodInfo = O.MethodInfo {
O.overloadedMethodName = "GI.WebKit2WebExtension.Interfaces.DOMXPathNSResolver.dOMXPathNSResolverLookupNamespaceUri",
O.overloadedMethodURL = "https://hackage.haskell.org/package/gi-webkit2webextension-4.0.26/docs/GI-WebKit2WebExtension-Interfaces-DOMXPathNSResolver.html#v:dOMXPathNSResolverLookupNamespaceUri"
}
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList DOMXPathNSResolver = DOMXPathNSResolverSignalList
type DOMXPathNSResolverSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif