{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.WebKit2WebExtension.Objects.DOMCSSRuleList
(
DOMCSSRuleList(..) ,
IsDOMCSSRuleList ,
toDOMCSSRuleList ,
#if defined(ENABLE_OVERLOADING)
ResolveDOMCSSRuleListMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
DOMCSSRuleListGetLengthMethodInfo ,
#endif
dOMCSSRuleListGetLength ,
#if defined(ENABLE_OVERLOADING)
DOMCSSRuleListItemMethodInfo ,
#endif
dOMCSSRuleListItem ,
#if defined(ENABLE_OVERLOADING)
DOMCSSRuleListLengthPropertyInfo ,
#endif
#if defined(ENABLE_OVERLOADING)
dOMCSSRuleListLength ,
#endif
getDOMCSSRuleListLength ,
) 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 GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.WebKit2WebExtension.Objects.DOMCSSRule as WebKit2WebExtension.DOMCSSRule
import {-# SOURCE #-} qualified GI.WebKit2WebExtension.Objects.DOMObject as WebKit2WebExtension.DOMObject
newtype DOMCSSRuleList = DOMCSSRuleList (SP.ManagedPtr DOMCSSRuleList)
deriving (DOMCSSRuleList -> DOMCSSRuleList -> Bool
(DOMCSSRuleList -> DOMCSSRuleList -> Bool)
-> (DOMCSSRuleList -> DOMCSSRuleList -> Bool) -> Eq DOMCSSRuleList
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: DOMCSSRuleList -> DOMCSSRuleList -> Bool
== :: DOMCSSRuleList -> DOMCSSRuleList -> Bool
$c/= :: DOMCSSRuleList -> DOMCSSRuleList -> Bool
/= :: DOMCSSRuleList -> DOMCSSRuleList -> Bool
Eq)
instance SP.ManagedPtrNewtype DOMCSSRuleList where
toManagedPtr :: DOMCSSRuleList -> ManagedPtr DOMCSSRuleList
toManagedPtr (DOMCSSRuleList ManagedPtr DOMCSSRuleList
p) = ManagedPtr DOMCSSRuleList
p
foreign import ccall "webkit_dom_css_rule_list_get_type"
c_webkit_dom_css_rule_list_get_type :: IO B.Types.GType
instance B.Types.TypedObject DOMCSSRuleList where
glibType :: IO GType
glibType = IO GType
c_webkit_dom_css_rule_list_get_type
instance B.Types.GObject DOMCSSRuleList
class (SP.GObject o, O.IsDescendantOf DOMCSSRuleList o) => IsDOMCSSRuleList o
instance (SP.GObject o, O.IsDescendantOf DOMCSSRuleList o) => IsDOMCSSRuleList o
instance O.HasParentTypes DOMCSSRuleList
type instance O.ParentTypes DOMCSSRuleList = '[WebKit2WebExtension.DOMObject.DOMObject, GObject.Object.Object]
toDOMCSSRuleList :: (MIO.MonadIO m, IsDOMCSSRuleList o) => o -> m DOMCSSRuleList
toDOMCSSRuleList :: forall (m :: * -> *) o.
(MonadIO m, IsDOMCSSRuleList o) =>
o -> m DOMCSSRuleList
toDOMCSSRuleList = IO DOMCSSRuleList -> m DOMCSSRuleList
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO DOMCSSRuleList -> m DOMCSSRuleList)
-> (o -> IO DOMCSSRuleList) -> o -> m DOMCSSRuleList
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr DOMCSSRuleList -> DOMCSSRuleList)
-> o -> IO DOMCSSRuleList
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr DOMCSSRuleList -> DOMCSSRuleList
DOMCSSRuleList
instance B.GValue.IsGValue (Maybe DOMCSSRuleList) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_webkit_dom_css_rule_list_get_type
gvalueSet_ :: Ptr GValue -> Maybe DOMCSSRuleList -> IO ()
gvalueSet_ Ptr GValue
gv Maybe DOMCSSRuleList
P.Nothing = Ptr GValue -> Ptr DOMCSSRuleList -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr DOMCSSRuleList
forall a. Ptr a
FP.nullPtr :: FP.Ptr DOMCSSRuleList)
gvalueSet_ Ptr GValue
gv (P.Just DOMCSSRuleList
obj) = DOMCSSRuleList -> (Ptr DOMCSSRuleList -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr DOMCSSRuleList
obj (Ptr GValue -> Ptr DOMCSSRuleList -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe DOMCSSRuleList)
gvalueGet_ Ptr GValue
gv = do
Ptr DOMCSSRuleList
ptr <- Ptr GValue -> IO (Ptr DOMCSSRuleList)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr DOMCSSRuleList)
if Ptr DOMCSSRuleList
ptr Ptr DOMCSSRuleList -> Ptr DOMCSSRuleList -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr DOMCSSRuleList
forall a. Ptr a
FP.nullPtr
then DOMCSSRuleList -> Maybe DOMCSSRuleList
forall a. a -> Maybe a
P.Just (DOMCSSRuleList -> Maybe DOMCSSRuleList)
-> IO DOMCSSRuleList -> IO (Maybe DOMCSSRuleList)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr DOMCSSRuleList -> DOMCSSRuleList)
-> Ptr DOMCSSRuleList -> IO DOMCSSRuleList
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr DOMCSSRuleList -> DOMCSSRuleList
DOMCSSRuleList Ptr DOMCSSRuleList
ptr
else Maybe DOMCSSRuleList -> IO (Maybe DOMCSSRuleList)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe DOMCSSRuleList
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveDOMCSSRuleListMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveDOMCSSRuleListMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveDOMCSSRuleListMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveDOMCSSRuleListMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveDOMCSSRuleListMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveDOMCSSRuleListMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveDOMCSSRuleListMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveDOMCSSRuleListMethod "item" o = DOMCSSRuleListItemMethodInfo
ResolveDOMCSSRuleListMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveDOMCSSRuleListMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveDOMCSSRuleListMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveDOMCSSRuleListMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveDOMCSSRuleListMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveDOMCSSRuleListMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveDOMCSSRuleListMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveDOMCSSRuleListMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveDOMCSSRuleListMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveDOMCSSRuleListMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveDOMCSSRuleListMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveDOMCSSRuleListMethod "getLength" o = DOMCSSRuleListGetLengthMethodInfo
ResolveDOMCSSRuleListMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveDOMCSSRuleListMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveDOMCSSRuleListMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveDOMCSSRuleListMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveDOMCSSRuleListMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveDOMCSSRuleListMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveDOMCSSRuleListMethod t DOMCSSRuleList, O.OverloadedMethod info DOMCSSRuleList p) => OL.IsLabel t (DOMCSSRuleList -> 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 ~ ResolveDOMCSSRuleListMethod t DOMCSSRuleList, O.OverloadedMethod info DOMCSSRuleList p, R.HasField t DOMCSSRuleList p) => R.HasField t DOMCSSRuleList p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveDOMCSSRuleListMethod t DOMCSSRuleList, O.OverloadedMethodInfo info DOMCSSRuleList) => OL.IsLabel t (O.MethodProxy info DOMCSSRuleList) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
getDOMCSSRuleListLength :: (MonadIO m, IsDOMCSSRuleList o) => o -> m CULong
getDOMCSSRuleListLength :: forall (m :: * -> *) o.
(MonadIO m, IsDOMCSSRuleList o) =>
o -> m CULong
getDOMCSSRuleListLength o
obj = IO CULong -> m CULong
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO CULong -> m CULong) -> IO CULong -> m CULong
forall a b. (a -> b) -> a -> b
$ o -> String -> IO CULong
forall a. GObject a => a -> String -> IO CULong
B.Properties.getObjectPropertyULong o
obj String
"length"
#if defined(ENABLE_OVERLOADING)
data DOMCSSRuleListLengthPropertyInfo
instance AttrInfo DOMCSSRuleListLengthPropertyInfo where
type AttrAllowedOps DOMCSSRuleListLengthPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint DOMCSSRuleListLengthPropertyInfo = IsDOMCSSRuleList
type AttrSetTypeConstraint DOMCSSRuleListLengthPropertyInfo = (~) ()
type AttrTransferTypeConstraint DOMCSSRuleListLengthPropertyInfo = (~) ()
type AttrTransferType DOMCSSRuleListLengthPropertyInfo = ()
type AttrGetType DOMCSSRuleListLengthPropertyInfo = CULong
type AttrLabel DOMCSSRuleListLengthPropertyInfo = "length"
type AttrOrigin DOMCSSRuleListLengthPropertyInfo = DOMCSSRuleList
attrGet = getDOMCSSRuleListLength
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.WebKit2WebExtension.Objects.DOMCSSRuleList.length"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-webkit2webextension-4.0.30/docs/GI-WebKit2WebExtension-Objects-DOMCSSRuleList.html#g:attr:length"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList DOMCSSRuleList
type instance O.AttributeList DOMCSSRuleList = DOMCSSRuleListAttributeList
type DOMCSSRuleListAttributeList = ('[ '("coreObject", WebKit2WebExtension.DOMObject.DOMObjectCoreObjectPropertyInfo), '("length", DOMCSSRuleListLengthPropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
dOMCSSRuleListLength :: AttrLabelProxy "length"
dOMCSSRuleListLength = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList DOMCSSRuleList = DOMCSSRuleListSignalList
type DOMCSSRuleListSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "webkit_dom_css_rule_list_get_length" webkit_dom_css_rule_list_get_length ::
Ptr DOMCSSRuleList ->
IO CULong
{-# DEPRECATED dOMCSSRuleListGetLength ["(Since version 2.22)","Use JavaScriptCore API instead"] #-}
dOMCSSRuleListGetLength ::
(B.CallStack.HasCallStack, MonadIO m, IsDOMCSSRuleList a) =>
a
-> m CULong
dOMCSSRuleListGetLength :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsDOMCSSRuleList a) =>
a -> m CULong
dOMCSSRuleListGetLength a
self = IO CULong -> m CULong
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO CULong -> m CULong) -> IO CULong -> m CULong
forall a b. (a -> b) -> a -> b
$ do
Ptr DOMCSSRuleList
self' <- a -> IO (Ptr DOMCSSRuleList)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
CULong
result <- Ptr DOMCSSRuleList -> IO CULong
webkit_dom_css_rule_list_get_length Ptr DOMCSSRuleList
self'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
CULong -> IO CULong
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return CULong
result
#if defined(ENABLE_OVERLOADING)
data DOMCSSRuleListGetLengthMethodInfo
instance (signature ~ (m CULong), MonadIO m, IsDOMCSSRuleList a) => O.OverloadedMethod DOMCSSRuleListGetLengthMethodInfo a signature where
overloadedMethod = dOMCSSRuleListGetLength
instance O.OverloadedMethodInfo DOMCSSRuleListGetLengthMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.WebKit2WebExtension.Objects.DOMCSSRuleList.dOMCSSRuleListGetLength",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-webkit2webextension-4.0.30/docs/GI-WebKit2WebExtension-Objects-DOMCSSRuleList.html#v:dOMCSSRuleListGetLength"
})
#endif
foreign import ccall "webkit_dom_css_rule_list_item" webkit_dom_css_rule_list_item ::
Ptr DOMCSSRuleList ->
CULong ->
IO (Ptr WebKit2WebExtension.DOMCSSRule.DOMCSSRule)
{-# DEPRECATED dOMCSSRuleListItem ["(Since version 2.22)","Use JavaScriptCore API instead"] #-}
dOMCSSRuleListItem ::
(B.CallStack.HasCallStack, MonadIO m, IsDOMCSSRuleList a) =>
a
-> CULong
-> m WebKit2WebExtension.DOMCSSRule.DOMCSSRule
dOMCSSRuleListItem :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsDOMCSSRuleList a) =>
a -> CULong -> m DOMCSSRule
dOMCSSRuleListItem a
self CULong
index = IO DOMCSSRule -> m DOMCSSRule
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO DOMCSSRule -> m DOMCSSRule) -> IO DOMCSSRule -> m DOMCSSRule
forall a b. (a -> b) -> a -> b
$ do
Ptr DOMCSSRuleList
self' <- a -> IO (Ptr DOMCSSRuleList)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
self
Ptr DOMCSSRule
result <- Ptr DOMCSSRuleList -> CULong -> IO (Ptr DOMCSSRule)
webkit_dom_css_rule_list_item Ptr DOMCSSRuleList
self' CULong
index
Text -> Ptr DOMCSSRule -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"dOMCSSRuleListItem" Ptr DOMCSSRule
result
DOMCSSRule
result' <- ((ManagedPtr DOMCSSRule -> DOMCSSRule)
-> Ptr DOMCSSRule -> IO DOMCSSRule
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
wrapObject ManagedPtr DOMCSSRule -> DOMCSSRule
WebKit2WebExtension.DOMCSSRule.DOMCSSRule) Ptr DOMCSSRule
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
self
DOMCSSRule -> IO DOMCSSRule
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return DOMCSSRule
result'
#if defined(ENABLE_OVERLOADING)
data DOMCSSRuleListItemMethodInfo
instance (signature ~ (CULong -> m WebKit2WebExtension.DOMCSSRule.DOMCSSRule), MonadIO m, IsDOMCSSRuleList a) => O.OverloadedMethod DOMCSSRuleListItemMethodInfo a signature where
overloadedMethod = dOMCSSRuleListItem
instance O.OverloadedMethodInfo DOMCSSRuleListItemMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.WebKit2WebExtension.Objects.DOMCSSRuleList.dOMCSSRuleListItem",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-webkit2webextension-4.0.30/docs/GI-WebKit2WebExtension-Objects-DOMCSSRuleList.html#v:dOMCSSRuleListItem"
})
#endif