module GI.WebKit2WebExtension.Objects.DOMMediaList
(
DOMMediaList(..) ,
DOMMediaListK ,
toDOMMediaList ,
noDOMMediaList ,
dOMMediaListAppendMedium ,
dOMMediaListDeleteMedium ,
dOMMediaListGetLength ,
dOMMediaListGetMediaText ,
dOMMediaListItem ,
dOMMediaListSetMediaText ,
DOMMediaListLengthPropertyInfo ,
getDOMMediaListLength ,
DOMMediaListMediaTextPropertyInfo ,
constructDOMMediaListMediaText ,
getDOMMediaListMediaText ,
setDOMMediaListMediaText ,
) where
import Prelude ()
import Data.GI.Base.ShortPrelude
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import GI.WebKit2WebExtension.Types
import GI.WebKit2WebExtension.Callbacks
import qualified GI.GObject as GObject
newtype DOMMediaList = DOMMediaList (ForeignPtr DOMMediaList)
foreign import ccall "webkit_dom_media_list_get_type"
c_webkit_dom_media_list_get_type :: IO GType
type instance ParentTypes DOMMediaList = DOMMediaListParentTypes
type DOMMediaListParentTypes = '[DOMObject, GObject.Object]
instance GObject DOMMediaList where
gobjectIsInitiallyUnowned _ = False
gobjectType _ = c_webkit_dom_media_list_get_type
class GObject o => DOMMediaListK o
instance (GObject o, IsDescendantOf DOMMediaList o) => DOMMediaListK o
toDOMMediaList :: DOMMediaListK o => o -> IO DOMMediaList
toDOMMediaList = unsafeCastTo DOMMediaList
noDOMMediaList :: Maybe DOMMediaList
noDOMMediaList = Nothing
getDOMMediaListLength :: (MonadIO m, DOMMediaListK o) => o -> m Word64
getDOMMediaListLength obj = liftIO $ getObjectPropertyUInt64 obj "length"
data DOMMediaListLengthPropertyInfo
instance AttrInfo DOMMediaListLengthPropertyInfo where
type AttrAllowedOps DOMMediaListLengthPropertyInfo = '[ 'AttrGet]
type AttrSetTypeConstraint DOMMediaListLengthPropertyInfo = (~) ()
type AttrBaseTypeConstraint DOMMediaListLengthPropertyInfo = DOMMediaListK
type AttrGetType DOMMediaListLengthPropertyInfo = Word64
type AttrLabel DOMMediaListLengthPropertyInfo = "DOMMediaList::length"
attrGet _ = getDOMMediaListLength
attrSet _ = undefined
attrConstruct _ = undefined
getDOMMediaListMediaText :: (MonadIO m, DOMMediaListK o) => o -> m T.Text
getDOMMediaListMediaText obj = liftIO $ getObjectPropertyString obj "media-text"
setDOMMediaListMediaText :: (MonadIO m, DOMMediaListK o) => o -> T.Text -> m ()
setDOMMediaListMediaText obj val = liftIO $ setObjectPropertyString obj "media-text" val
constructDOMMediaListMediaText :: T.Text -> IO ([Char], GValue)
constructDOMMediaListMediaText val = constructObjectPropertyString "media-text" val
data DOMMediaListMediaTextPropertyInfo
instance AttrInfo DOMMediaListMediaTextPropertyInfo where
type AttrAllowedOps DOMMediaListMediaTextPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet]
type AttrSetTypeConstraint DOMMediaListMediaTextPropertyInfo = (~) T.Text
type AttrBaseTypeConstraint DOMMediaListMediaTextPropertyInfo = DOMMediaListK
type AttrGetType DOMMediaListMediaTextPropertyInfo = T.Text
type AttrLabel DOMMediaListMediaTextPropertyInfo = "DOMMediaList::media-text"
attrGet _ = getDOMMediaListMediaText
attrSet _ = setDOMMediaListMediaText
attrConstruct _ = constructDOMMediaListMediaText
type instance AttributeList DOMMediaList = DOMMediaListAttributeList
type DOMMediaListAttributeList = ('[ '("core-object", DOMObjectCoreObjectPropertyInfo), '("length", DOMMediaListLengthPropertyInfo), '("media-text", DOMMediaListMediaTextPropertyInfo)] :: [(Symbol, *)])
type instance SignalList DOMMediaList = DOMMediaListSignalList
type DOMMediaListSignalList = ('[ '("notify", GObject.ObjectNotifySignalInfo), '("notify::[property]", GObjectNotifySignalInfo)] :: [(Symbol, *)])
foreign import ccall "webkit_dom_media_list_append_medium" webkit_dom_media_list_append_medium ::
Ptr DOMMediaList ->
CString ->
Ptr (Ptr GError) ->
IO ()
dOMMediaListAppendMedium ::
(MonadIO m, DOMMediaListK a) =>
a ->
T.Text ->
m ()
dOMMediaListAppendMedium _obj newMedium = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
newMedium' <- textToCString newMedium
onException (do
propagateGError $ webkit_dom_media_list_append_medium _obj' newMedium'
touchManagedPtr _obj
freeMem newMedium'
return ()
) (do
freeMem newMedium'
)
foreign import ccall "webkit_dom_media_list_delete_medium" webkit_dom_media_list_delete_medium ::
Ptr DOMMediaList ->
CString ->
Ptr (Ptr GError) ->
IO ()
dOMMediaListDeleteMedium ::
(MonadIO m, DOMMediaListK a) =>
a ->
T.Text ->
m ()
dOMMediaListDeleteMedium _obj oldMedium = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
oldMedium' <- textToCString oldMedium
onException (do
propagateGError $ webkit_dom_media_list_delete_medium _obj' oldMedium'
touchManagedPtr _obj
freeMem oldMedium'
return ()
) (do
freeMem oldMedium'
)
foreign import ccall "webkit_dom_media_list_get_length" webkit_dom_media_list_get_length ::
Ptr DOMMediaList ->
IO Word64
dOMMediaListGetLength ::
(MonadIO m, DOMMediaListK a) =>
a ->
m Word64
dOMMediaListGetLength _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_dom_media_list_get_length _obj'
touchManagedPtr _obj
return result
foreign import ccall "webkit_dom_media_list_get_media_text" webkit_dom_media_list_get_media_text ::
Ptr DOMMediaList ->
IO CString
dOMMediaListGetMediaText ::
(MonadIO m, DOMMediaListK a) =>
a ->
m T.Text
dOMMediaListGetMediaText _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_dom_media_list_get_media_text _obj'
checkUnexpectedReturnNULL "webkit_dom_media_list_get_media_text" result
result' <- cstringToText result
freeMem result
touchManagedPtr _obj
return result'
foreign import ccall "webkit_dom_media_list_item" webkit_dom_media_list_item ::
Ptr DOMMediaList ->
Word64 ->
IO CString
dOMMediaListItem ::
(MonadIO m, DOMMediaListK a) =>
a ->
Word64 ->
m T.Text
dOMMediaListItem _obj index = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_dom_media_list_item _obj' index
checkUnexpectedReturnNULL "webkit_dom_media_list_item" result
result' <- cstringToText result
freeMem result
touchManagedPtr _obj
return result'
foreign import ccall "webkit_dom_media_list_set_media_text" webkit_dom_media_list_set_media_text ::
Ptr DOMMediaList ->
CString ->
Ptr (Ptr GError) ->
IO ()
dOMMediaListSetMediaText ::
(MonadIO m, DOMMediaListK a) =>
a ->
T.Text ->
m ()
dOMMediaListSetMediaText _obj value = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
value' <- textToCString value
onException (do
propagateGError $ webkit_dom_media_list_set_media_text _obj' value'
touchManagedPtr _obj
freeMem value'
return ()
) (do
freeMem value'
)