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