{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.WebKit2WebExtension.Interfaces.DOMNodeFilter
(
DOMNodeFilter(..) ,
noDOMNodeFilter ,
IsDOMNodeFilter ,
toDOMNodeFilter ,
#if defined(ENABLE_OVERLOADING)
ResolveDOMNodeFilterMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
DOMNodeFilterAcceptNodeMethodInfo ,
#endif
dOMNodeFilterAcceptNode ,
) 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.GI.Base.Signals as B.Signals
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
import {-# SOURCE #-} qualified GI.WebKit2WebExtension.Objects.DOMNode as WebKit2WebExtension.DOMNode
newtype DOMNodeFilter = DOMNodeFilter (ManagedPtr DOMNodeFilter)
deriving (DOMNodeFilter -> DOMNodeFilter -> Bool
(DOMNodeFilter -> DOMNodeFilter -> Bool)
-> (DOMNodeFilter -> DOMNodeFilter -> Bool) -> Eq DOMNodeFilter
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DOMNodeFilter -> DOMNodeFilter -> Bool
$c/= :: DOMNodeFilter -> DOMNodeFilter -> Bool
== :: DOMNodeFilter -> DOMNodeFilter -> Bool
$c== :: DOMNodeFilter -> DOMNodeFilter -> Bool
Eq)
noDOMNodeFilter :: Maybe DOMNodeFilter
noDOMNodeFilter :: Maybe DOMNodeFilter
noDOMNodeFilter = Maybe DOMNodeFilter
forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList DOMNodeFilter = DOMNodeFilterSignalList
type DOMNodeFilterSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "webkit_dom_node_filter_get_type"
c_webkit_dom_node_filter_get_type :: IO GType
instance GObject DOMNodeFilter where
gobjectType :: IO GType
gobjectType = IO GType
c_webkit_dom_node_filter_get_type
instance B.GValue.IsGValue DOMNodeFilter where
toGValue :: DOMNodeFilter -> IO GValue
toGValue o :: DOMNodeFilter
o = do
GType
gtype <- IO GType
c_webkit_dom_node_filter_get_type
DOMNodeFilter -> (Ptr DOMNodeFilter -> IO GValue) -> IO GValue
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr DOMNodeFilter
o (GType
-> (GValue -> Ptr DOMNodeFilter -> IO ())
-> Ptr DOMNodeFilter
-> IO GValue
forall a. GType -> (GValue -> a -> IO ()) -> a -> IO GValue
B.GValue.buildGValue GType
gtype GValue -> Ptr DOMNodeFilter -> IO ()
forall a. GObject a => GValue -> Ptr a -> IO ()
B.GValue.set_object)
fromGValue :: GValue -> IO DOMNodeFilter
fromGValue gv :: GValue
gv = do
Ptr DOMNodeFilter
ptr <- GValue -> IO (Ptr DOMNodeFilter)
forall b. GObject b => GValue -> IO (Ptr b)
B.GValue.get_object GValue
gv :: IO (Ptr DOMNodeFilter)
(ManagedPtr DOMNodeFilter -> DOMNodeFilter)
-> Ptr DOMNodeFilter -> IO DOMNodeFilter
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr DOMNodeFilter -> DOMNodeFilter
DOMNodeFilter Ptr DOMNodeFilter
ptr
class (GObject o, O.IsDescendantOf DOMNodeFilter o) => IsDOMNodeFilter o
instance (GObject o, O.IsDescendantOf DOMNodeFilter o) => IsDOMNodeFilter o
instance O.HasParentTypes DOMNodeFilter
type instance O.ParentTypes DOMNodeFilter = '[GObject.Object.Object]
toDOMNodeFilter :: (MonadIO m, IsDOMNodeFilter o) => o -> m DOMNodeFilter
toDOMNodeFilter :: o -> m DOMNodeFilter
toDOMNodeFilter = IO DOMNodeFilter -> m DOMNodeFilter
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO DOMNodeFilter -> m DOMNodeFilter)
-> (o -> IO DOMNodeFilter) -> o -> m DOMNodeFilter
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr DOMNodeFilter -> DOMNodeFilter)
-> o -> IO DOMNodeFilter
forall o o'.
(HasCallStack, GObject o, GObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
unsafeCastTo ManagedPtr DOMNodeFilter -> DOMNodeFilter
DOMNodeFilter
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList DOMNodeFilter
type instance O.AttributeList DOMNodeFilter = DOMNodeFilterAttributeList
type DOMNodeFilterAttributeList = ('[ ] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING)
#endif
#if defined(ENABLE_OVERLOADING)
type family ResolveDOMNodeFilterMethod (t :: Symbol) (o :: *) :: * where
ResolveDOMNodeFilterMethod "acceptNode" o = DOMNodeFilterAcceptNodeMethodInfo
ResolveDOMNodeFilterMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveDOMNodeFilterMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveDOMNodeFilterMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveDOMNodeFilterMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveDOMNodeFilterMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveDOMNodeFilterMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveDOMNodeFilterMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveDOMNodeFilterMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveDOMNodeFilterMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveDOMNodeFilterMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveDOMNodeFilterMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveDOMNodeFilterMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveDOMNodeFilterMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveDOMNodeFilterMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveDOMNodeFilterMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveDOMNodeFilterMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveDOMNodeFilterMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveDOMNodeFilterMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveDOMNodeFilterMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveDOMNodeFilterMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveDOMNodeFilterMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveDOMNodeFilterMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveDOMNodeFilterMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveDOMNodeFilterMethod t DOMNodeFilter, O.MethodInfo info DOMNodeFilter p) => OL.IsLabel t (DOMNodeFilter -> 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_node_filter_accept_node" webkit_dom_node_filter_accept_node ::
Ptr DOMNodeFilter ->
Ptr WebKit2WebExtension.DOMNode.DOMNode ->
IO Int16
{-# DEPRECATED dOMNodeFilterAcceptNode ["(Since version 2.22)","Use JavaScriptCore API instead"] #-}
dOMNodeFilterAcceptNode ::
(B.CallStack.HasCallStack, MonadIO m, IsDOMNodeFilter a, WebKit2WebExtension.DOMNode.IsDOMNode b) =>
a
-> b
-> m Int16
dOMNodeFilterAcceptNode :: a -> b -> m Int16
dOMNodeFilterAcceptNode filter :: a
filter node :: b
node = IO Int16 -> m Int16
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Int16 -> m Int16) -> IO Int16 -> m Int16
forall a b. (a -> b) -> a -> b
$ do
Ptr DOMNodeFilter
filter' <- a -> IO (Ptr DOMNodeFilter)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
filter
Ptr DOMNode
node' <- b -> IO (Ptr DOMNode)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr b
node
Int16
result <- Ptr DOMNodeFilter -> Ptr DOMNode -> IO Int16
webkit_dom_node_filter_accept_node Ptr DOMNodeFilter
filter' Ptr DOMNode
node'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
filter
b -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr b
node
Int16 -> IO Int16
forall (m :: * -> *) a. Monad m => a -> m a
return Int16
result
#if defined(ENABLE_OVERLOADING)
data DOMNodeFilterAcceptNodeMethodInfo
instance (signature ~ (b -> m Int16), MonadIO m, IsDOMNodeFilter a, WebKit2WebExtension.DOMNode.IsDOMNode b) => O.MethodInfo DOMNodeFilterAcceptNodeMethodInfo a signature where
overloadedMethod = dOMNodeFilterAcceptNode
#endif