{-# LANGUAGE TypeApplications #-}


-- | Copyright  : Will Thompson, Iñaki García Etxebarria and Jonas Platte
-- License    : LGPL-2.1
-- Maintainer : Iñaki García Etxebarria
-- 
-- An event related to a pointer or touch device motion.

#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif

module GI.Gdk.Objects.MotionEvent
    ( 

-- * Exported types
    MotionEvent(..)                         ,
    IsMotionEvent                           ,
    toMotionEvent                           ,


 -- * Methods
-- | 
-- 
--  === __Click to display all available methods, including inherited ones__
-- ==== Methods
-- [ref]("GI.Gdk.Objects.Event#g:method:ref"), [triggersContextMenu]("GI.Gdk.Objects.Event#g:method:triggersContextMenu"), [unref]("GI.Gdk.Objects.Event#g:method:unref").
-- 
-- ==== Getters
-- [getAxes]("GI.Gdk.Objects.Event#g:method:getAxes"), [getAxis]("GI.Gdk.Objects.Event#g:method:getAxis"), [getDevice]("GI.Gdk.Objects.Event#g:method:getDevice"), [getDeviceTool]("GI.Gdk.Objects.Event#g:method:getDeviceTool"), [getDisplay]("GI.Gdk.Objects.Event#g:method:getDisplay"), [getEventSequence]("GI.Gdk.Objects.Event#g:method:getEventSequence"), [getEventType]("GI.Gdk.Objects.Event#g:method:getEventType"), [getHistory]("GI.Gdk.Objects.Event#g:method:getHistory"), [getModifierState]("GI.Gdk.Objects.Event#g:method:getModifierState"), [getPointerEmulated]("GI.Gdk.Objects.Event#g:method:getPointerEmulated"), [getPosition]("GI.Gdk.Objects.Event#g:method:getPosition"), [getSeat]("GI.Gdk.Objects.Event#g:method:getSeat"), [getSurface]("GI.Gdk.Objects.Event#g:method:getSurface"), [getTime]("GI.Gdk.Objects.Event#g:method:getTime").
-- 
-- ==== Setters
-- /None/.

#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

-- | Memory-managed wrapper type.
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

-- | Type class for types which can be safely cast to `MotionEvent`, for instance with `toMotionEvent`.
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]

-- | Cast to `MotionEvent`, for types for which this is known to be safe. For general casts, use `Data.GI.Base.ManagedPtr.castTo`.
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

--- XXX Missing getter and/or setter, so no GValue instance could be generated.
#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

-- XXX Wrapping a foreign struct/union with no known destructor or size, leak?
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 ()