{-# LANGUAGE ImplicitParams, RankNTypes, TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gdk.Objects.Seat
(
Seat(..) ,
IsSeat ,
toSeat ,
#if defined(ENABLE_OVERLOADING)
ResolveSeatMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
SeatGetCapabilitiesMethodInfo ,
#endif
seatGetCapabilities ,
#if defined(ENABLE_OVERLOADING)
SeatGetDisplayMethodInfo ,
#endif
seatGetDisplay ,
#if defined(ENABLE_OVERLOADING)
SeatGetKeyboardMethodInfo ,
#endif
seatGetKeyboard ,
#if defined(ENABLE_OVERLOADING)
SeatGetPointerMethodInfo ,
#endif
seatGetPointer ,
#if defined(ENABLE_OVERLOADING)
SeatGetSlavesMethodInfo ,
#endif
seatGetSlaves ,
#if defined(ENABLE_OVERLOADING)
SeatGrabMethodInfo ,
#endif
seatGrab ,
#if defined(ENABLE_OVERLOADING)
SeatUngrabMethodInfo ,
#endif
seatUngrab ,
#if defined(ENABLE_OVERLOADING)
SeatDisplayPropertyInfo ,
#endif
constructSeatDisplay ,
getSeatDisplay ,
#if defined(ENABLE_OVERLOADING)
seatDisplay ,
#endif
SeatDeviceAddedCallback ,
#if defined(ENABLE_OVERLOADING)
SeatDeviceAddedSignalInfo ,
#endif
afterSeatDeviceAdded ,
onSeatDeviceAdded ,
SeatDeviceRemovedCallback ,
#if defined(ENABLE_OVERLOADING)
SeatDeviceRemovedSignalInfo ,
#endif
afterSeatDeviceRemoved ,
onSeatDeviceRemoved ,
SeatToolAddedCallback ,
#if defined(ENABLE_OVERLOADING)
SeatToolAddedSignalInfo ,
#endif
afterSeatToolAdded ,
onSeatToolAdded ,
SeatToolRemovedCallback ,
#if defined(ENABLE_OVERLOADING)
SeatToolRemovedSignalInfo ,
#endif
afterSeatToolRemoved ,
onSeatToolRemoved ,
) 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 qualified GI.Gdk.Callbacks as Gdk.Callbacks
import {-# SOURCE #-} qualified GI.Gdk.Enums as Gdk.Enums
import {-# SOURCE #-} qualified GI.Gdk.Flags as Gdk.Flags
import {-# SOURCE #-} qualified GI.Gdk.Objects.Cursor as Gdk.Cursor
import {-# SOURCE #-} qualified GI.Gdk.Objects.Device as Gdk.Device
import {-# SOURCE #-} qualified GI.Gdk.Objects.DeviceTool as Gdk.DeviceTool
import {-# SOURCE #-} qualified GI.Gdk.Objects.Display as Gdk.Display
import {-# SOURCE #-} qualified GI.Gdk.Objects.Window as Gdk.Window
import {-# SOURCE #-} qualified GI.Gdk.Unions.Event as Gdk.Event
newtype Seat = Seat (SP.ManagedPtr Seat)
deriving (Seat -> Seat -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Seat -> Seat -> Bool
$c/= :: Seat -> Seat -> Bool
== :: Seat -> Seat -> Bool
$c== :: Seat -> Seat -> Bool
Eq)
instance SP.ManagedPtrNewtype Seat where
toManagedPtr :: Seat -> ManagedPtr Seat
toManagedPtr (Seat ManagedPtr Seat
p) = ManagedPtr Seat
p
foreign import ccall "gdk_seat_get_type"
c_gdk_seat_get_type :: IO B.Types.GType
instance B.Types.TypedObject Seat where
glibType :: IO GType
glibType = IO GType
c_gdk_seat_get_type
instance B.Types.GObject Seat
class (SP.GObject o, O.IsDescendantOf Seat o) => IsSeat o
instance (SP.GObject o, O.IsDescendantOf Seat o) => IsSeat o
instance O.HasParentTypes Seat
type instance O.ParentTypes Seat = '[GObject.Object.Object]
toSeat :: (MIO.MonadIO m, IsSeat o) => o -> m Seat
toSeat :: forall (m :: * -> *) o. (MonadIO m, IsSeat o) => o -> m Seat
toSeat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr Seat -> Seat
Seat
instance B.GValue.IsGValue (Maybe Seat) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_gdk_seat_get_type
gvalueSet_ :: Ptr GValue -> Maybe Seat -> IO ()
gvalueSet_ Ptr GValue
gv Maybe Seat
P.Nothing = forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (forall a. Ptr a
FP.nullPtr :: FP.Ptr Seat)
gvalueSet_ Ptr GValue
gv (P.Just Seat
obj) = forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr Seat
obj (forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe Seat)
gvalueGet_ Ptr GValue
gv = do
Ptr Seat
ptr <- forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr Seat)
if Ptr Seat
ptr forall a. Eq a => a -> a -> Bool
/= forall a. Ptr a
FP.nullPtr
then forall a. a -> Maybe a
P.Just forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr Seat -> Seat
Seat Ptr Seat
ptr
else forall (m :: * -> *) a. Monad m => a -> m a
return forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveSeatMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveSeatMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveSeatMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveSeatMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveSeatMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveSeatMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveSeatMethod "grab" o = SeatGrabMethodInfo
ResolveSeatMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveSeatMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveSeatMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveSeatMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveSeatMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveSeatMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveSeatMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveSeatMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveSeatMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveSeatMethod "ungrab" o = SeatUngrabMethodInfo
ResolveSeatMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveSeatMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveSeatMethod "getCapabilities" o = SeatGetCapabilitiesMethodInfo
ResolveSeatMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveSeatMethod "getDisplay" o = SeatGetDisplayMethodInfo
ResolveSeatMethod "getKeyboard" o = SeatGetKeyboardMethodInfo
ResolveSeatMethod "getPointer" o = SeatGetPointerMethodInfo
ResolveSeatMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveSeatMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveSeatMethod "getSlaves" o = SeatGetSlavesMethodInfo
ResolveSeatMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveSeatMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveSeatMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveSeatMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveSeatMethod t Seat, O.OverloadedMethod info Seat p) => OL.IsLabel t (Seat -> 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 ~ ResolveSeatMethod t Seat, O.OverloadedMethod info Seat p, R.HasField t Seat p) => R.HasField t Seat p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveSeatMethod t Seat, O.OverloadedMethodInfo info Seat) => OL.IsLabel t (O.MethodProxy info Seat) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
type SeatDeviceAddedCallback =
Gdk.Device.Device
-> IO ()
type C_SeatDeviceAddedCallback =
Ptr Seat ->
Ptr Gdk.Device.Device ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_SeatDeviceAddedCallback :: C_SeatDeviceAddedCallback -> IO (FunPtr C_SeatDeviceAddedCallback)
wrap_SeatDeviceAddedCallback ::
GObject a => (a -> SeatDeviceAddedCallback) ->
C_SeatDeviceAddedCallback
wrap_SeatDeviceAddedCallback :: forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceAddedCallback a -> SeatDeviceAddedCallback
gi'cb Ptr Seat
gi'selfPtr Ptr Device
device Ptr ()
_ = do
Device
device' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Device -> Device
Gdk.Device.Device) Ptr Device
device
forall a b.
(HasCallStack, ManagedPtrNewtype a) =>
Ptr a -> (a -> IO b) -> IO b
B.ManagedPtr.withTransient Ptr Seat
gi'selfPtr forall a b. (a -> b) -> a -> b
$ \Seat
gi'self -> a -> SeatDeviceAddedCallback
gi'cb (coerce :: forall a b. Coercible a b => a -> b
Coerce.coerce Seat
gi'self) Device
device'
onSeatDeviceAdded :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatDeviceAddedCallback) -> m SignalHandlerId
onSeatDeviceAdded :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatDeviceAddedCallback) -> m SignalHandlerId
onSeatDeviceAdded a
obj (?self::a) => SeatDeviceAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatDeviceAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatDeviceAddedCallback
cb
let wrapped' :: C_SeatDeviceAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceAddedCallback a -> SeatDeviceAddedCallback
wrapped
FunPtr C_SeatDeviceAddedCallback
wrapped'' <- C_SeatDeviceAddedCallback -> IO (FunPtr C_SeatDeviceAddedCallback)
mk_SeatDeviceAddedCallback C_SeatDeviceAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"device-added" FunPtr C_SeatDeviceAddedCallback
wrapped'' SignalConnectMode
SignalConnectBefore forall a. Maybe a
Nothing
afterSeatDeviceAdded :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatDeviceAddedCallback) -> m SignalHandlerId
afterSeatDeviceAdded :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatDeviceAddedCallback) -> m SignalHandlerId
afterSeatDeviceAdded a
obj (?self::a) => SeatDeviceAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatDeviceAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatDeviceAddedCallback
cb
let wrapped' :: C_SeatDeviceAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceAddedCallback a -> SeatDeviceAddedCallback
wrapped
FunPtr C_SeatDeviceAddedCallback
wrapped'' <- C_SeatDeviceAddedCallback -> IO (FunPtr C_SeatDeviceAddedCallback)
mk_SeatDeviceAddedCallback C_SeatDeviceAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"device-added" FunPtr C_SeatDeviceAddedCallback
wrapped'' SignalConnectMode
SignalConnectAfter forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
data SeatDeviceAddedSignalInfo
instance SignalInfo SeatDeviceAddedSignalInfo where
type HaskellCallbackType SeatDeviceAddedSignalInfo = SeatDeviceAddedCallback
connectSignal obj cb connectMode detail = do
let cb' = wrap_SeatDeviceAddedCallback cb
cb'' <- mk_SeatDeviceAddedCallback cb'
connectSignalFunPtr obj "device-added" cb'' connectMode detail
dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat::device-added"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#g:signal:deviceAdded"})
#endif
type SeatDeviceRemovedCallback =
Gdk.Device.Device
-> IO ()
type C_SeatDeviceRemovedCallback =
Ptr Seat ->
Ptr Gdk.Device.Device ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_SeatDeviceRemovedCallback :: C_SeatDeviceRemovedCallback -> IO (FunPtr C_SeatDeviceRemovedCallback)
wrap_SeatDeviceRemovedCallback ::
GObject a => (a -> SeatDeviceRemovedCallback) ->
C_SeatDeviceRemovedCallback
wrap_SeatDeviceRemovedCallback :: forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceRemovedCallback a -> SeatDeviceAddedCallback
gi'cb Ptr Seat
gi'selfPtr Ptr Device
device Ptr ()
_ = do
Device
device' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Device -> Device
Gdk.Device.Device) Ptr Device
device
forall a b.
(HasCallStack, ManagedPtrNewtype a) =>
Ptr a -> (a -> IO b) -> IO b
B.ManagedPtr.withTransient Ptr Seat
gi'selfPtr forall a b. (a -> b) -> a -> b
$ \Seat
gi'self -> a -> SeatDeviceAddedCallback
gi'cb (coerce :: forall a b. Coercible a b => a -> b
Coerce.coerce Seat
gi'self) Device
device'
onSeatDeviceRemoved :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatDeviceRemovedCallback) -> m SignalHandlerId
onSeatDeviceRemoved :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatDeviceAddedCallback) -> m SignalHandlerId
onSeatDeviceRemoved a
obj (?self::a) => SeatDeviceAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatDeviceAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatDeviceAddedCallback
cb
let wrapped' :: C_SeatDeviceAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceRemovedCallback a -> SeatDeviceAddedCallback
wrapped
FunPtr C_SeatDeviceAddedCallback
wrapped'' <- C_SeatDeviceAddedCallback -> IO (FunPtr C_SeatDeviceAddedCallback)
mk_SeatDeviceRemovedCallback C_SeatDeviceAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"device-removed" FunPtr C_SeatDeviceAddedCallback
wrapped'' SignalConnectMode
SignalConnectBefore forall a. Maybe a
Nothing
afterSeatDeviceRemoved :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatDeviceRemovedCallback) -> m SignalHandlerId
afterSeatDeviceRemoved :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatDeviceAddedCallback) -> m SignalHandlerId
afterSeatDeviceRemoved a
obj (?self::a) => SeatDeviceAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatDeviceAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatDeviceAddedCallback
cb
let wrapped' :: C_SeatDeviceAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatDeviceAddedCallback) -> C_SeatDeviceAddedCallback
wrap_SeatDeviceRemovedCallback a -> SeatDeviceAddedCallback
wrapped
FunPtr C_SeatDeviceAddedCallback
wrapped'' <- C_SeatDeviceAddedCallback -> IO (FunPtr C_SeatDeviceAddedCallback)
mk_SeatDeviceRemovedCallback C_SeatDeviceAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"device-removed" FunPtr C_SeatDeviceAddedCallback
wrapped'' SignalConnectMode
SignalConnectAfter forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
data SeatDeviceRemovedSignalInfo
instance SignalInfo SeatDeviceRemovedSignalInfo where
type HaskellCallbackType SeatDeviceRemovedSignalInfo = SeatDeviceRemovedCallback
connectSignal obj cb connectMode detail = do
let cb' = wrap_SeatDeviceRemovedCallback cb
cb'' <- mk_SeatDeviceRemovedCallback cb'
connectSignalFunPtr obj "device-removed" cb'' connectMode detail
dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat::device-removed"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#g:signal:deviceRemoved"})
#endif
type SeatToolAddedCallback =
Gdk.DeviceTool.DeviceTool
-> IO ()
type C_SeatToolAddedCallback =
Ptr Seat ->
Ptr Gdk.DeviceTool.DeviceTool ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_SeatToolAddedCallback :: C_SeatToolAddedCallback -> IO (FunPtr C_SeatToolAddedCallback)
wrap_SeatToolAddedCallback ::
GObject a => (a -> SeatToolAddedCallback) ->
C_SeatToolAddedCallback
wrap_SeatToolAddedCallback :: forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolAddedCallback a -> SeatToolAddedCallback
gi'cb Ptr Seat
gi'selfPtr Ptr DeviceTool
tool Ptr ()
_ = do
DeviceTool
tool' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr DeviceTool -> DeviceTool
Gdk.DeviceTool.DeviceTool) Ptr DeviceTool
tool
forall a b.
(HasCallStack, ManagedPtrNewtype a) =>
Ptr a -> (a -> IO b) -> IO b
B.ManagedPtr.withTransient Ptr Seat
gi'selfPtr forall a b. (a -> b) -> a -> b
$ \Seat
gi'self -> a -> SeatToolAddedCallback
gi'cb (coerce :: forall a b. Coercible a b => a -> b
Coerce.coerce Seat
gi'self) DeviceTool
tool'
onSeatToolAdded :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatToolAddedCallback) -> m SignalHandlerId
onSeatToolAdded :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatToolAddedCallback) -> m SignalHandlerId
onSeatToolAdded a
obj (?self::a) => SeatToolAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatToolAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatToolAddedCallback
cb
let wrapped' :: C_SeatToolAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolAddedCallback a -> SeatToolAddedCallback
wrapped
FunPtr C_SeatToolAddedCallback
wrapped'' <- C_SeatToolAddedCallback -> IO (FunPtr C_SeatToolAddedCallback)
mk_SeatToolAddedCallback C_SeatToolAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"tool-added" FunPtr C_SeatToolAddedCallback
wrapped'' SignalConnectMode
SignalConnectBefore forall a. Maybe a
Nothing
afterSeatToolAdded :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatToolAddedCallback) -> m SignalHandlerId
afterSeatToolAdded :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatToolAddedCallback) -> m SignalHandlerId
afterSeatToolAdded a
obj (?self::a) => SeatToolAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatToolAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatToolAddedCallback
cb
let wrapped' :: C_SeatToolAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolAddedCallback a -> SeatToolAddedCallback
wrapped
FunPtr C_SeatToolAddedCallback
wrapped'' <- C_SeatToolAddedCallback -> IO (FunPtr C_SeatToolAddedCallback)
mk_SeatToolAddedCallback C_SeatToolAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"tool-added" FunPtr C_SeatToolAddedCallback
wrapped'' SignalConnectMode
SignalConnectAfter forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
data SeatToolAddedSignalInfo
instance SignalInfo SeatToolAddedSignalInfo where
type HaskellCallbackType SeatToolAddedSignalInfo = SeatToolAddedCallback
connectSignal obj cb connectMode detail = do
let cb' = wrap_SeatToolAddedCallback cb
cb'' <- mk_SeatToolAddedCallback cb'
connectSignalFunPtr obj "tool-added" cb'' connectMode detail
dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat::tool-added"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#g:signal:toolAdded"})
#endif
type SeatToolRemovedCallback =
Gdk.DeviceTool.DeviceTool
-> IO ()
type C_SeatToolRemovedCallback =
Ptr Seat ->
Ptr Gdk.DeviceTool.DeviceTool ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_SeatToolRemovedCallback :: C_SeatToolRemovedCallback -> IO (FunPtr C_SeatToolRemovedCallback)
wrap_SeatToolRemovedCallback ::
GObject a => (a -> SeatToolRemovedCallback) ->
C_SeatToolRemovedCallback
wrap_SeatToolRemovedCallback :: forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolRemovedCallback a -> SeatToolAddedCallback
gi'cb Ptr Seat
gi'selfPtr Ptr DeviceTool
tool Ptr ()
_ = do
DeviceTool
tool' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr DeviceTool -> DeviceTool
Gdk.DeviceTool.DeviceTool) Ptr DeviceTool
tool
forall a b.
(HasCallStack, ManagedPtrNewtype a) =>
Ptr a -> (a -> IO b) -> IO b
B.ManagedPtr.withTransient Ptr Seat
gi'selfPtr forall a b. (a -> b) -> a -> b
$ \Seat
gi'self -> a -> SeatToolAddedCallback
gi'cb (coerce :: forall a b. Coercible a b => a -> b
Coerce.coerce Seat
gi'self) DeviceTool
tool'
onSeatToolRemoved :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatToolRemovedCallback) -> m SignalHandlerId
onSeatToolRemoved :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatToolAddedCallback) -> m SignalHandlerId
onSeatToolRemoved a
obj (?self::a) => SeatToolAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatToolAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatToolAddedCallback
cb
let wrapped' :: C_SeatToolAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolRemovedCallback a -> SeatToolAddedCallback
wrapped
FunPtr C_SeatToolAddedCallback
wrapped'' <- C_SeatToolAddedCallback -> IO (FunPtr C_SeatToolAddedCallback)
mk_SeatToolRemovedCallback C_SeatToolAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"tool-removed" FunPtr C_SeatToolAddedCallback
wrapped'' SignalConnectMode
SignalConnectBefore forall a. Maybe a
Nothing
afterSeatToolRemoved :: (IsSeat a, MonadIO m) => a -> ((?self :: a) => SeatToolRemovedCallback) -> m SignalHandlerId
afterSeatToolRemoved :: forall a (m :: * -> *).
(IsSeat a, MonadIO m) =>
a -> ((?self::a) => SeatToolAddedCallback) -> m SignalHandlerId
afterSeatToolRemoved a
obj (?self::a) => SeatToolAddedCallback
cb = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> SeatToolAddedCallback
wrapped a
self = let ?self = a
self in (?self::a) => SeatToolAddedCallback
cb
let wrapped' :: C_SeatToolAddedCallback
wrapped' = forall a.
GObject a =>
(a -> SeatToolAddedCallback) -> C_SeatToolAddedCallback
wrap_SeatToolRemovedCallback a -> SeatToolAddedCallback
wrapped
FunPtr C_SeatToolAddedCallback
wrapped'' <- C_SeatToolAddedCallback -> IO (FunPtr C_SeatToolAddedCallback)
mk_SeatToolRemovedCallback C_SeatToolAddedCallback
wrapped'
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"tool-removed" FunPtr C_SeatToolAddedCallback
wrapped'' SignalConnectMode
SignalConnectAfter forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
data SeatToolRemovedSignalInfo
instance SignalInfo SeatToolRemovedSignalInfo where
type HaskellCallbackType SeatToolRemovedSignalInfo = SeatToolRemovedCallback
connectSignal obj cb connectMode detail = do
let cb' = wrap_SeatToolRemovedCallback cb
cb'' <- mk_SeatToolRemovedCallback cb'
connectSignalFunPtr obj "tool-removed" cb'' connectMode detail
dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat::tool-removed"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#g:signal:toolRemoved"})
#endif
getSeatDisplay :: (MonadIO m, IsSeat o) => o -> m Gdk.Display.Display
getSeatDisplay :: forall (m :: * -> *) o. (MonadIO m, IsSeat o) => o -> m Display
getSeatDisplay o
obj = forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO forall a b. (a -> b) -> a -> b
$ forall a. HasCallStack => Text -> IO (Maybe a) -> IO a
checkUnexpectedNothing Text
"getSeatDisplay" forall a b. (a -> b) -> a -> b
$ forall a b.
(GObject a, GObject b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyObject o
obj String
"display" ManagedPtr Display -> Display
Gdk.Display.Display
constructSeatDisplay :: (IsSeat o, MIO.MonadIO m, Gdk.Display.IsDisplay a) => a -> m (GValueConstruct o)
constructSeatDisplay :: forall o (m :: * -> *) a.
(IsSeat o, MonadIO m, IsDisplay a) =>
a -> m (GValueConstruct o)
constructSeatDisplay a
val = forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO forall a b. (a -> b) -> a -> b
$ do
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO forall a b. (a -> b) -> a -> b
$ forall a o.
GObject a =>
String -> Maybe a -> IO (GValueConstruct o)
B.Properties.constructObjectPropertyObject String
"display" (forall a. a -> Maybe a
P.Just a
val)
#if defined(ENABLE_OVERLOADING)
data SeatDisplayPropertyInfo
instance AttrInfo SeatDisplayPropertyInfo where
type AttrAllowedOps SeatDisplayPropertyInfo = '[ 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint SeatDisplayPropertyInfo = IsSeat
type AttrSetTypeConstraint SeatDisplayPropertyInfo = Gdk.Display.IsDisplay
type AttrTransferTypeConstraint SeatDisplayPropertyInfo = Gdk.Display.IsDisplay
type AttrTransferType SeatDisplayPropertyInfo = Gdk.Display.Display
type AttrGetType SeatDisplayPropertyInfo = Gdk.Display.Display
type AttrLabel SeatDisplayPropertyInfo = "display"
type AttrOrigin SeatDisplayPropertyInfo = Seat
attrGet = getSeatDisplay
attrSet = undefined
attrTransfer _ v = do
unsafeCastTo Gdk.Display.Display v
attrConstruct = constructSeatDisplay
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.display"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#g:attr:display"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList Seat
type instance O.AttributeList Seat = SeatAttributeList
type SeatAttributeList = ('[ '("display", SeatDisplayPropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
seatDisplay :: AttrLabelProxy "display"
seatDisplay = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList Seat = SeatSignalList
type SeatSignalList = ('[ '("deviceAdded", SeatDeviceAddedSignalInfo), '("deviceRemoved", SeatDeviceRemovedSignalInfo), '("notify", GObject.Object.ObjectNotifySignalInfo), '("toolAdded", SeatToolAddedSignalInfo), '("toolRemoved", SeatToolRemovedSignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "gdk_seat_get_capabilities" gdk_seat_get_capabilities ::
Ptr Seat ->
IO CUInt
seatGetCapabilities ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> m [Gdk.Flags.SeatCapabilities]
seatGetCapabilities :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> m [SeatCapabilities]
seatGetCapabilities a
seat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
CUInt
result <- Ptr Seat -> IO CUInt
gdk_seat_get_capabilities Ptr Seat
seat'
let result' :: [SeatCapabilities]
result' = forall a b. (Storable a, Integral a, Bits a, IsGFlag b) => a -> [b]
wordToGFlags CUInt
result
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return [SeatCapabilities]
result'
#if defined(ENABLE_OVERLOADING)
data SeatGetCapabilitiesMethodInfo
instance (signature ~ (m [Gdk.Flags.SeatCapabilities]), MonadIO m, IsSeat a) => O.OverloadedMethod SeatGetCapabilitiesMethodInfo a signature where
overloadedMethod = seatGetCapabilities
instance O.OverloadedMethodInfo SeatGetCapabilitiesMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGetCapabilities",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGetCapabilities"
})
#endif
foreign import ccall "gdk_seat_get_display" gdk_seat_get_display ::
Ptr Seat ->
IO (Ptr Gdk.Display.Display)
seatGetDisplay ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> m Gdk.Display.Display
seatGetDisplay :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> m Display
seatGetDisplay a
seat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
Ptr Display
result <- Ptr Seat -> IO (Ptr Display)
gdk_seat_get_display Ptr Seat
seat'
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"seatGetDisplay" Ptr Display
result
Display
result' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Display -> Display
Gdk.Display.Display) Ptr Display
result
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return Display
result'
#if defined(ENABLE_OVERLOADING)
data SeatGetDisplayMethodInfo
instance (signature ~ (m Gdk.Display.Display), MonadIO m, IsSeat a) => O.OverloadedMethod SeatGetDisplayMethodInfo a signature where
overloadedMethod = seatGetDisplay
instance O.OverloadedMethodInfo SeatGetDisplayMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGetDisplay",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGetDisplay"
})
#endif
foreign import ccall "gdk_seat_get_keyboard" gdk_seat_get_keyboard ::
Ptr Seat ->
IO (Ptr Gdk.Device.Device)
seatGetKeyboard ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> m (Maybe Gdk.Device.Device)
seatGetKeyboard :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> m (Maybe Device)
seatGetKeyboard a
seat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
Ptr Device
result <- Ptr Seat -> IO (Ptr Device)
gdk_seat_get_keyboard Ptr Seat
seat'
Maybe Device
maybeResult <- forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull Ptr Device
result forall a b. (a -> b) -> a -> b
$ \Ptr Device
result' -> do
Device
result'' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Device -> Device
Gdk.Device.Device) Ptr Device
result'
forall (m :: * -> *) a. Monad m => a -> m a
return Device
result''
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Device
maybeResult
#if defined(ENABLE_OVERLOADING)
data SeatGetKeyboardMethodInfo
instance (signature ~ (m (Maybe Gdk.Device.Device)), MonadIO m, IsSeat a) => O.OverloadedMethod SeatGetKeyboardMethodInfo a signature where
overloadedMethod = seatGetKeyboard
instance O.OverloadedMethodInfo SeatGetKeyboardMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGetKeyboard",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGetKeyboard"
})
#endif
foreign import ccall "gdk_seat_get_pointer" gdk_seat_get_pointer ::
Ptr Seat ->
IO (Ptr Gdk.Device.Device)
seatGetPointer ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> m (Maybe Gdk.Device.Device)
seatGetPointer :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> m (Maybe Device)
seatGetPointer a
seat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
Ptr Device
result <- Ptr Seat -> IO (Ptr Device)
gdk_seat_get_pointer Ptr Seat
seat'
Maybe Device
maybeResult <- forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull Ptr Device
result forall a b. (a -> b) -> a -> b
$ \Ptr Device
result' -> do
Device
result'' <- (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Device -> Device
Gdk.Device.Device) Ptr Device
result'
forall (m :: * -> *) a. Monad m => a -> m a
return Device
result''
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Device
maybeResult
#if defined(ENABLE_OVERLOADING)
data SeatGetPointerMethodInfo
instance (signature ~ (m (Maybe Gdk.Device.Device)), MonadIO m, IsSeat a) => O.OverloadedMethod SeatGetPointerMethodInfo a signature where
overloadedMethod = seatGetPointer
instance O.OverloadedMethodInfo SeatGetPointerMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGetPointer",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGetPointer"
})
#endif
foreign import ccall "gdk_seat_get_slaves" gdk_seat_get_slaves ::
Ptr Seat ->
CUInt ->
IO (Ptr (GList (Ptr Gdk.Device.Device)))
seatGetSlaves ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> [Gdk.Flags.SeatCapabilities]
-> m [Gdk.Device.Device]
seatGetSlaves :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> [SeatCapabilities] -> m [Device]
seatGetSlaves a
seat [SeatCapabilities]
capabilities = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
let capabilities' :: CUInt
capabilities' = forall b a. (Num b, IsGFlag a) => [a] -> b
gflagsToWord [SeatCapabilities]
capabilities
Ptr (GList (Ptr Device))
result <- Ptr Seat -> CUInt -> IO (Ptr (GList (Ptr Device)))
gdk_seat_get_slaves Ptr Seat
seat' CUInt
capabilities'
[Ptr Device]
result' <- forall a. Ptr (GList (Ptr a)) -> IO [Ptr a]
unpackGList Ptr (GList (Ptr Device))
result
[Device]
result'' <- forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
newObject ManagedPtr Device -> Device
Gdk.Device.Device) [Ptr Device]
result'
forall a. Ptr (GList a) -> IO ()
g_list_free Ptr (GList (Ptr Device))
result
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return [Device]
result''
#if defined(ENABLE_OVERLOADING)
data SeatGetSlavesMethodInfo
instance (signature ~ ([Gdk.Flags.SeatCapabilities] -> m [Gdk.Device.Device]), MonadIO m, IsSeat a) => O.OverloadedMethod SeatGetSlavesMethodInfo a signature where
overloadedMethod = seatGetSlaves
instance O.OverloadedMethodInfo SeatGetSlavesMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGetSlaves",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGetSlaves"
})
#endif
foreign import ccall "gdk_seat_grab" gdk_seat_grab ::
Ptr Seat ->
Ptr Gdk.Window.Window ->
CUInt ->
CInt ->
Ptr Gdk.Cursor.Cursor ->
Ptr Gdk.Event.Event ->
FunPtr Gdk.Callbacks.C_SeatGrabPrepareFunc ->
Ptr () ->
IO CUInt
seatGrab ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a, Gdk.Window.IsWindow b, Gdk.Cursor.IsCursor c) =>
a
-> b
-> [Gdk.Flags.SeatCapabilities]
-> Bool
-> Maybe (c)
-> Maybe (Gdk.Event.Event)
-> Maybe (Gdk.Callbacks.SeatGrabPrepareFunc)
-> m Gdk.Enums.GrabStatus
seatGrab :: forall (m :: * -> *) a b c.
(HasCallStack, MonadIO m, IsSeat a, IsWindow b, IsCursor c) =>
a
-> b
-> [SeatCapabilities]
-> Bool
-> Maybe c
-> Maybe Event
-> Maybe SeatGrabPrepareFunc
-> m GrabStatus
seatGrab a
seat b
window [SeatCapabilities]
capabilities Bool
ownerEvents Maybe c
cursor Maybe Event
event Maybe SeatGrabPrepareFunc
prepareFunc = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
Ptr Window
window' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr b
window
let capabilities' :: CUInt
capabilities' = forall b a. (Num b, IsGFlag a) => [a] -> b
gflagsToWord [SeatCapabilities]
capabilities
let ownerEvents' :: CInt
ownerEvents' = (forall a b. (Integral a, Num b) => a -> b
P.fromIntegral forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Enum a => a -> Int
P.fromEnum) Bool
ownerEvents
Ptr Cursor
maybeCursor <- case Maybe c
cursor of
Maybe c
Nothing -> forall (m :: * -> *) a. Monad m => a -> m a
return forall a. Ptr a
nullPtr
Just c
jCursor -> do
Ptr Cursor
jCursor' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr c
jCursor
forall (m :: * -> *) a. Monad m => a -> m a
return Ptr Cursor
jCursor'
Ptr Event
maybeEvent <- case Maybe Event
event of
Maybe Event
Nothing -> forall (m :: * -> *) a. Monad m => a -> m a
return forall a. Ptr a
nullPtr
Just Event
jEvent -> do
Ptr Event
jEvent' <- forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr Event
jEvent
forall (m :: * -> *) a. Monad m => a -> m a
return Ptr Event
jEvent'
FunPtr C_SeatGrabPrepareFunc
maybePrepareFunc <- case Maybe SeatGrabPrepareFunc
prepareFunc of
Maybe SeatGrabPrepareFunc
Nothing -> forall (m :: * -> *) a. Monad m => a -> m a
return (forall a b. Ptr a -> FunPtr b
castPtrToFunPtr forall a. Ptr a
nullPtr)
Just SeatGrabPrepareFunc
jPrepareFunc -> do
FunPtr C_SeatGrabPrepareFunc
jPrepareFunc' <- C_SeatGrabPrepareFunc -> IO (FunPtr C_SeatGrabPrepareFunc)
Gdk.Callbacks.mk_SeatGrabPrepareFunc (Maybe (Ptr (FunPtr C_SeatGrabPrepareFunc))
-> SeatGrabPrepareFunc_WithClosures -> C_SeatGrabPrepareFunc
Gdk.Callbacks.wrap_SeatGrabPrepareFunc forall a. Maybe a
Nothing (SeatGrabPrepareFunc -> SeatGrabPrepareFunc_WithClosures
Gdk.Callbacks.drop_closures_SeatGrabPrepareFunc SeatGrabPrepareFunc
jPrepareFunc))
forall (m :: * -> *) a. Monad m => a -> m a
return FunPtr C_SeatGrabPrepareFunc
jPrepareFunc'
let prepareFuncData :: Ptr a
prepareFuncData = forall a. Ptr a
nullPtr
CUInt
result <- Ptr Seat
-> Ptr Window
-> CUInt
-> CInt
-> Ptr Cursor
-> Ptr Event
-> FunPtr C_SeatGrabPrepareFunc
-> Ptr ()
-> IO CUInt
gdk_seat_grab Ptr Seat
seat' Ptr Window
window' CUInt
capabilities' CInt
ownerEvents' Ptr Cursor
maybeCursor Ptr Event
maybeEvent FunPtr C_SeatGrabPrepareFunc
maybePrepareFunc forall a. Ptr a
prepareFuncData
let result' :: GrabStatus
result' = (forall a. Enum a => Int -> a
toEnum forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (Integral a, Num b) => a -> b
fromIntegral) CUInt
result
forall a. Ptr a -> IO ()
safeFreeFunPtr forall a b. (a -> b) -> a -> b
$ forall a b. FunPtr a -> Ptr b
castFunPtrToPtr FunPtr C_SeatGrabPrepareFunc
maybePrepareFunc
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr b
window
forall (m :: * -> *) a. Monad m => Maybe a -> (a -> m ()) -> m ()
whenJust Maybe c
cursor forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr
forall (m :: * -> *) a. Monad m => Maybe a -> (a -> m ()) -> m ()
whenJust Maybe Event
event forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr
forall (m :: * -> *) a. Monad m => a -> m a
return GrabStatus
result'
#if defined(ENABLE_OVERLOADING)
data SeatGrabMethodInfo
instance (signature ~ (b -> [Gdk.Flags.SeatCapabilities] -> Bool -> Maybe (c) -> Maybe (Gdk.Event.Event) -> Maybe (Gdk.Callbacks.SeatGrabPrepareFunc) -> m Gdk.Enums.GrabStatus), MonadIO m, IsSeat a, Gdk.Window.IsWindow b, Gdk.Cursor.IsCursor c) => O.OverloadedMethod SeatGrabMethodInfo a signature where
overloadedMethod = seatGrab
instance O.OverloadedMethodInfo SeatGrabMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatGrab",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatGrab"
})
#endif
foreign import ccall "gdk_seat_ungrab" gdk_seat_ungrab ::
Ptr Seat ->
IO ()
seatUngrab ::
(B.CallStack.HasCallStack, MonadIO m, IsSeat a) =>
a
-> m ()
seatUngrab :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsSeat a) =>
a -> m ()
seatUngrab a
seat = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall a b. (a -> b) -> a -> b
$ do
Ptr Seat
seat' <- forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
seat
Ptr Seat -> IO ()
gdk_seat_ungrab Ptr Seat
seat'
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
seat
forall (m :: * -> *) a. Monad m => a -> m a
return ()
#if defined(ENABLE_OVERLOADING)
data SeatUngrabMethodInfo
instance (signature ~ (m ()), MonadIO m, IsSeat a) => O.OverloadedMethod SeatUngrabMethodInfo a signature where
overloadedMethod = seatUngrab
instance O.OverloadedMethodInfo SeatUngrabMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Seat.seatUngrab",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.26/docs/GI-Gdk-Objects-Seat.html#v:seatUngrab"
})
#endif