{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.WebKit2.Objects.UserMediaPermissionRequest
(
UserMediaPermissionRequest(..) ,
IsUserMediaPermissionRequest ,
toUserMediaPermissionRequest ,
#if defined(ENABLE_OVERLOADING)
ResolveUserMediaPermissionRequestMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
UserMediaPermissionRequestIsForAudioDevicePropertyInfo,
#endif
getUserMediaPermissionRequestIsForAudioDevice,
#if defined(ENABLE_OVERLOADING)
userMediaPermissionRequestIsForAudioDevice,
#endif
#if defined(ENABLE_OVERLOADING)
UserMediaPermissionRequestIsForVideoDevicePropertyInfo,
#endif
getUserMediaPermissionRequestIsForVideoDevice,
#if defined(ENABLE_OVERLOADING)
userMediaPermissionRequestIsForVideoDevice,
#endif
) 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
import {-# SOURCE #-} qualified GI.WebKit2.Interfaces.PermissionRequest as WebKit2.PermissionRequest
newtype UserMediaPermissionRequest = UserMediaPermissionRequest (SP.ManagedPtr UserMediaPermissionRequest)
deriving (UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool
(UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool)
-> (UserMediaPermissionRequest
-> UserMediaPermissionRequest -> Bool)
-> Eq UserMediaPermissionRequest
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool
$c/= :: UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool
== :: UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool
$c== :: UserMediaPermissionRequest -> UserMediaPermissionRequest -> Bool
Eq)
instance SP.ManagedPtrNewtype UserMediaPermissionRequest where
toManagedPtr :: UserMediaPermissionRequest -> ManagedPtr UserMediaPermissionRequest
toManagedPtr (UserMediaPermissionRequest ManagedPtr UserMediaPermissionRequest
p) = ManagedPtr UserMediaPermissionRequest
p
foreign import ccall "webkit_user_media_permission_request_get_type"
c_webkit_user_media_permission_request_get_type :: IO B.Types.GType
instance B.Types.TypedObject UserMediaPermissionRequest where
glibType :: IO GType
glibType = IO GType
c_webkit_user_media_permission_request_get_type
instance B.Types.GObject UserMediaPermissionRequest
class (SP.GObject o, O.IsDescendantOf UserMediaPermissionRequest o) => IsUserMediaPermissionRequest o
instance (SP.GObject o, O.IsDescendantOf UserMediaPermissionRequest o) => IsUserMediaPermissionRequest o
instance O.HasParentTypes UserMediaPermissionRequest
type instance O.ParentTypes UserMediaPermissionRequest = '[GObject.Object.Object, WebKit2.PermissionRequest.PermissionRequest]
toUserMediaPermissionRequest :: (MIO.MonadIO m, IsUserMediaPermissionRequest o) => o -> m UserMediaPermissionRequest
toUserMediaPermissionRequest :: forall (m :: * -> *) o.
(MonadIO m, IsUserMediaPermissionRequest o) =>
o -> m UserMediaPermissionRequest
toUserMediaPermissionRequest = IO UserMediaPermissionRequest -> m UserMediaPermissionRequest
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO UserMediaPermissionRequest -> m UserMediaPermissionRequest)
-> (o -> IO UserMediaPermissionRequest)
-> o
-> m UserMediaPermissionRequest
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr UserMediaPermissionRequest
-> UserMediaPermissionRequest)
-> o -> IO UserMediaPermissionRequest
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr UserMediaPermissionRequest -> UserMediaPermissionRequest
UserMediaPermissionRequest
instance B.GValue.IsGValue (Maybe UserMediaPermissionRequest) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_webkit_user_media_permission_request_get_type
gvalueSet_ :: Ptr GValue -> Maybe UserMediaPermissionRequest -> IO ()
gvalueSet_ Ptr GValue
gv Maybe UserMediaPermissionRequest
P.Nothing = Ptr GValue -> Ptr UserMediaPermissionRequest -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr UserMediaPermissionRequest
forall a. Ptr a
FP.nullPtr :: FP.Ptr UserMediaPermissionRequest)
gvalueSet_ Ptr GValue
gv (P.Just UserMediaPermissionRequest
obj) = UserMediaPermissionRequest
-> (Ptr UserMediaPermissionRequest -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr UserMediaPermissionRequest
obj (Ptr GValue -> Ptr UserMediaPermissionRequest -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe UserMediaPermissionRequest)
gvalueGet_ Ptr GValue
gv = do
Ptr UserMediaPermissionRequest
ptr <- Ptr GValue -> IO (Ptr UserMediaPermissionRequest)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr UserMediaPermissionRequest)
if Ptr UserMediaPermissionRequest
ptr Ptr UserMediaPermissionRequest
-> Ptr UserMediaPermissionRequest -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr UserMediaPermissionRequest
forall a. Ptr a
FP.nullPtr
then UserMediaPermissionRequest -> Maybe UserMediaPermissionRequest
forall a. a -> Maybe a
P.Just (UserMediaPermissionRequest -> Maybe UserMediaPermissionRequest)
-> IO UserMediaPermissionRequest
-> IO (Maybe UserMediaPermissionRequest)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr UserMediaPermissionRequest
-> UserMediaPermissionRequest)
-> Ptr UserMediaPermissionRequest -> IO UserMediaPermissionRequest
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr UserMediaPermissionRequest -> UserMediaPermissionRequest
UserMediaPermissionRequest Ptr UserMediaPermissionRequest
ptr
else Maybe UserMediaPermissionRequest
-> IO (Maybe UserMediaPermissionRequest)
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe UserMediaPermissionRequest
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveUserMediaPermissionRequestMethod (t :: Symbol) (o :: *) :: * where
ResolveUserMediaPermissionRequestMethod "allow" o = WebKit2.PermissionRequest.PermissionRequestAllowMethodInfo
ResolveUserMediaPermissionRequestMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveUserMediaPermissionRequestMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveUserMediaPermissionRequestMethod "deny" o = WebKit2.PermissionRequest.PermissionRequestDenyMethodInfo
ResolveUserMediaPermissionRequestMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveUserMediaPermissionRequestMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveUserMediaPermissionRequestMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveUserMediaPermissionRequestMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveUserMediaPermissionRequestMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveUserMediaPermissionRequestMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveUserMediaPermissionRequestMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveUserMediaPermissionRequestMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveUserMediaPermissionRequestMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveUserMediaPermissionRequestMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveUserMediaPermissionRequestMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveUserMediaPermissionRequestMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveUserMediaPermissionRequestMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveUserMediaPermissionRequestMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveUserMediaPermissionRequestMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveUserMediaPermissionRequestMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveUserMediaPermissionRequestMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveUserMediaPermissionRequestMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveUserMediaPermissionRequestMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveUserMediaPermissionRequestMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveUserMediaPermissionRequestMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveUserMediaPermissionRequestMethod t UserMediaPermissionRequest, O.OverloadedMethod info UserMediaPermissionRequest p) => OL.IsLabel t (UserMediaPermissionRequest -> 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 ~ ResolveUserMediaPermissionRequestMethod t UserMediaPermissionRequest, O.OverloadedMethod info UserMediaPermissionRequest p, R.HasField t UserMediaPermissionRequest p) => R.HasField t UserMediaPermissionRequest p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveUserMediaPermissionRequestMethod t UserMediaPermissionRequest, O.OverloadedMethodInfo info UserMediaPermissionRequest) => OL.IsLabel t (O.MethodProxy info UserMediaPermissionRequest) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
getUserMediaPermissionRequestIsForAudioDevice :: (MonadIO m, IsUserMediaPermissionRequest o) => o -> m Bool
getUserMediaPermissionRequestIsForAudioDevice :: forall (m :: * -> *) o.
(MonadIO m, IsUserMediaPermissionRequest o) =>
o -> m Bool
getUserMediaPermissionRequestIsForAudioDevice o
obj = IO Bool -> m Bool
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Bool -> m Bool) -> IO Bool -> m Bool
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Bool
forall a. GObject a => a -> String -> IO Bool
B.Properties.getObjectPropertyBool o
obj String
"is-for-audio-device"
#if defined(ENABLE_OVERLOADING)
data UserMediaPermissionRequestIsForAudioDevicePropertyInfo
instance AttrInfo UserMediaPermissionRequestIsForAudioDevicePropertyInfo where
type AttrAllowedOps UserMediaPermissionRequestIsForAudioDevicePropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint UserMediaPermissionRequestIsForAudioDevicePropertyInfo = IsUserMediaPermissionRequest
type AttrSetTypeConstraint UserMediaPermissionRequestIsForAudioDevicePropertyInfo = (~) ()
type AttrTransferTypeConstraint UserMediaPermissionRequestIsForAudioDevicePropertyInfo = (~) ()
type AttrTransferType UserMediaPermissionRequestIsForAudioDevicePropertyInfo = ()
type AttrGetType UserMediaPermissionRequestIsForAudioDevicePropertyInfo = Bool
type AttrLabel UserMediaPermissionRequestIsForAudioDevicePropertyInfo = "is-for-audio-device"
type AttrOrigin UserMediaPermissionRequestIsForAudioDevicePropertyInfo = UserMediaPermissionRequest
attrGet = getUserMediaPermissionRequestIsForAudioDevice
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
#endif
getUserMediaPermissionRequestIsForVideoDevice :: (MonadIO m, IsUserMediaPermissionRequest o) => o -> m Bool
getUserMediaPermissionRequestIsForVideoDevice :: forall (m :: * -> *) o.
(MonadIO m, IsUserMediaPermissionRequest o) =>
o -> m Bool
getUserMediaPermissionRequestIsForVideoDevice o
obj = IO Bool -> m Bool
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Bool -> m Bool) -> IO Bool -> m Bool
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Bool
forall a. GObject a => a -> String -> IO Bool
B.Properties.getObjectPropertyBool o
obj String
"is-for-video-device"
#if defined(ENABLE_OVERLOADING)
data UserMediaPermissionRequestIsForVideoDevicePropertyInfo
instance AttrInfo UserMediaPermissionRequestIsForVideoDevicePropertyInfo where
type AttrAllowedOps UserMediaPermissionRequestIsForVideoDevicePropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint UserMediaPermissionRequestIsForVideoDevicePropertyInfo = IsUserMediaPermissionRequest
type AttrSetTypeConstraint UserMediaPermissionRequestIsForVideoDevicePropertyInfo = (~) ()
type AttrTransferTypeConstraint UserMediaPermissionRequestIsForVideoDevicePropertyInfo = (~) ()
type AttrTransferType UserMediaPermissionRequestIsForVideoDevicePropertyInfo = ()
type AttrGetType UserMediaPermissionRequestIsForVideoDevicePropertyInfo = Bool
type AttrLabel UserMediaPermissionRequestIsForVideoDevicePropertyInfo = "is-for-video-device"
type AttrOrigin UserMediaPermissionRequestIsForVideoDevicePropertyInfo = UserMediaPermissionRequest
attrGet = getUserMediaPermissionRequestIsForVideoDevice
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList UserMediaPermissionRequest
type instance O.AttributeList UserMediaPermissionRequest = UserMediaPermissionRequestAttributeList
type UserMediaPermissionRequestAttributeList = ('[ '("isForAudioDevice", UserMediaPermissionRequestIsForAudioDevicePropertyInfo), '("isForVideoDevice", UserMediaPermissionRequestIsForVideoDevicePropertyInfo)] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING)
userMediaPermissionRequestIsForAudioDevice :: AttrLabelProxy "isForAudioDevice"
userMediaPermissionRequestIsForAudioDevice = AttrLabelProxy
userMediaPermissionRequestIsForVideoDevice :: AttrLabelProxy "isForVideoDevice"
userMediaPermissionRequestIsForVideoDevice = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList UserMediaPermissionRequest = UserMediaPermissionRequestSignalList
type UserMediaPermissionRequestSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif