{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gdk.Objects.MotionEvent
(
MotionEvent(..) ,
IsMotionEvent ,
toMotionEvent ,
#if defined(ENABLE_OVERLOADING)
ResolveMotionEventMethod ,
#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 {-# SOURCE #-} qualified GI.Gdk.Objects.Event as Gdk.Event
newtype MotionEvent = MotionEvent (SP.ManagedPtr MotionEvent)
deriving (MotionEvent -> MotionEvent -> Bool
(MotionEvent -> MotionEvent -> Bool)
-> (MotionEvent -> MotionEvent -> Bool) -> Eq MotionEvent
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: MotionEvent -> MotionEvent -> Bool
$c/= :: MotionEvent -> MotionEvent -> Bool
== :: MotionEvent -> MotionEvent -> Bool
$c== :: MotionEvent -> MotionEvent -> Bool
Eq)
instance SP.ManagedPtrNewtype MotionEvent where
toManagedPtr :: MotionEvent -> ManagedPtr MotionEvent
toManagedPtr (MotionEvent ManagedPtr MotionEvent
p) = ManagedPtr MotionEvent
p
foreign import ccall "gdk_motion_event_get_type"
c_gdk_motion_event_get_type :: IO B.Types.GType
instance B.Types.TypedObject MotionEvent where
glibType :: IO GType
glibType = IO GType
c_gdk_motion_event_get_type
class (SP.BoxedPtr o, SP.TypedObject o, O.IsDescendantOf MotionEvent o) => IsMotionEvent o
instance (SP.BoxedPtr o, SP.TypedObject o, O.IsDescendantOf MotionEvent o) => IsMotionEvent o
instance O.HasParentTypes MotionEvent
type instance O.ParentTypes MotionEvent = '[Gdk.Event.Event]
toMotionEvent :: (MIO.MonadIO m, IsMotionEvent o) => o -> m MotionEvent
toMotionEvent :: forall (m :: * -> *) o.
(MonadIO m, IsMotionEvent o) =>
o -> m MotionEvent
toMotionEvent = IO MotionEvent -> m MotionEvent
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO MotionEvent -> m MotionEvent)
-> (o -> IO MotionEvent) -> o -> m MotionEvent
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr MotionEvent -> MotionEvent) -> o -> IO MotionEvent
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr MotionEvent -> MotionEvent
MotionEvent
#if defined(ENABLE_OVERLOADING)
type family ResolveMotionEventMethod (t :: Symbol) (o :: *) :: * where
ResolveMotionEventMethod "ref" o = Gdk.Event.EventRefMethodInfo
ResolveMotionEventMethod "triggersContextMenu" o = Gdk.Event.EventTriggersContextMenuMethodInfo
ResolveMotionEventMethod "unref" o = Gdk.Event.EventUnrefMethodInfo
ResolveMotionEventMethod "getAxes" o = Gdk.Event.EventGetAxesMethodInfo
ResolveMotionEventMethod "getAxis" o = Gdk.Event.EventGetAxisMethodInfo
ResolveMotionEventMethod "getDevice" o = Gdk.Event.EventGetDeviceMethodInfo
ResolveMotionEventMethod "getDeviceTool" o = Gdk.Event.EventGetDeviceToolMethodInfo
ResolveMotionEventMethod "getDisplay" o = Gdk.Event.EventGetDisplayMethodInfo
ResolveMotionEventMethod "getEventSequence" o = Gdk.Event.EventGetEventSequenceMethodInfo
ResolveMotionEventMethod "getEventType" o = Gdk.Event.EventGetEventTypeMethodInfo
ResolveMotionEventMethod "getHistory" o = Gdk.Event.EventGetHistoryMethodInfo
ResolveMotionEventMethod "getModifierState" o = Gdk.Event.EventGetModifierStateMethodInfo
ResolveMotionEventMethod "getPointerEmulated" o = Gdk.Event.EventGetPointerEmulatedMethodInfo
ResolveMotionEventMethod "getPosition" o = Gdk.Event.EventGetPositionMethodInfo
ResolveMotionEventMethod "getSeat" o = Gdk.Event.EventGetSeatMethodInfo
ResolveMotionEventMethod "getSurface" o = Gdk.Event.EventGetSurfaceMethodInfo
ResolveMotionEventMethod "getTime" o = Gdk.Event.EventGetTimeMethodInfo
ResolveMotionEventMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveMotionEventMethod t MotionEvent, O.OverloadedMethod info MotionEvent p) => OL.IsLabel t (MotionEvent -> 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 ~ ResolveMotionEventMethod t MotionEvent, O.OverloadedMethod info MotionEvent p, R.HasField t MotionEvent p) => R.HasField t MotionEvent p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveMotionEventMethod t MotionEvent, O.OverloadedMethodInfo info MotionEvent) => OL.IsLabel t (O.MethodProxy info MotionEvent) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
instance BoxedPtr MotionEvent where
boxedPtrCopy :: MotionEvent -> IO MotionEvent
boxedPtrCopy = MotionEvent -> IO MotionEvent
forall (m :: * -> *) a. Monad m => a -> m a
return
boxedPtrFree :: MotionEvent -> IO ()
boxedPtrFree = \MotionEvent
_x -> () -> IO ()
forall (m :: * -> *) a. Monad m => a -> m a
return ()