#define ENABLE_OVERLOADING (MIN_VERSION_haskell_gi_overloading(1,0,0) \
&& !defined(__HADDOCK_VERSION__))
module GI.Gtk.Objects.GestureRotate
(
GestureRotate(..) ,
IsGestureRotate ,
toGestureRotate ,
noGestureRotate ,
#if ENABLE_OVERLOADING
GestureRotateGetAngleDeltaMethodInfo ,
#endif
gestureRotateGetAngleDelta ,
gestureRotateNew ,
C_GestureRotateAngleChangedCallback ,
GestureRotateAngleChangedCallback ,
#if ENABLE_OVERLOADING
GestureRotateAngleChangedSignalInfo ,
#endif
afterGestureRotateAngleChanged ,
genClosure_GestureRotateAngleChanged ,
mk_GestureRotateAngleChangedCallback ,
noGestureRotateAngleChangedCallback ,
onGestureRotateAngleChanged ,
wrap_GestureRotateAngleChangedCallback ,
) 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.ManagedPtr as B.ManagedPtr
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.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gtk.Objects.EventController as Gtk.EventController
import {-# SOURCE #-} qualified GI.Gtk.Objects.Gesture as Gtk.Gesture
import {-# SOURCE #-} qualified GI.Gtk.Objects.Widget as Gtk.Widget
newtype GestureRotate = GestureRotate (ManagedPtr GestureRotate)
foreign import ccall "gtk_gesture_rotate_get_type"
c_gtk_gesture_rotate_get_type :: IO GType
instance GObject GestureRotate where
gobjectType _ = c_gtk_gesture_rotate_get_type
class GObject o => IsGestureRotate o
#if MIN_VERSION_base(4,9,0)
instance {-# OVERLAPPABLE #-} (GObject a, O.UnknownAncestorError GestureRotate a) =>
IsGestureRotate a
#endif
instance IsGestureRotate GestureRotate
instance Gtk.Gesture.IsGesture GestureRotate
instance Gtk.EventController.IsEventController GestureRotate
instance GObject.Object.IsObject GestureRotate
toGestureRotate :: (MonadIO m, IsGestureRotate o) => o -> m GestureRotate
toGestureRotate = liftIO . unsafeCastTo GestureRotate
noGestureRotate :: Maybe GestureRotate
noGestureRotate = Nothing
#if ENABLE_OVERLOADING
type family ResolveGestureRotateMethod (t :: Symbol) (o :: *) :: * where
ResolveGestureRotateMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveGestureRotateMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveGestureRotateMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveGestureRotateMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveGestureRotateMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveGestureRotateMethod "group" o = Gtk.Gesture.GestureGroupMethodInfo
ResolveGestureRotateMethod "handleEvent" o = Gtk.EventController.EventControllerHandleEventMethodInfo
ResolveGestureRotateMethod "handlesSequence" o = Gtk.Gesture.GestureHandlesSequenceMethodInfo
ResolveGestureRotateMethod "isActive" o = Gtk.Gesture.GestureIsActiveMethodInfo
ResolveGestureRotateMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveGestureRotateMethod "isGroupedWith" o = Gtk.Gesture.GestureIsGroupedWithMethodInfo
ResolveGestureRotateMethod "isRecognized" o = Gtk.Gesture.GestureIsRecognizedMethodInfo
ResolveGestureRotateMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveGestureRotateMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveGestureRotateMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveGestureRotateMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveGestureRotateMethod "reset" o = Gtk.EventController.EventControllerResetMethodInfo
ResolveGestureRotateMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveGestureRotateMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveGestureRotateMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveGestureRotateMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveGestureRotateMethod "ungroup" o = Gtk.Gesture.GestureUngroupMethodInfo
ResolveGestureRotateMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveGestureRotateMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveGestureRotateMethod "getAngleDelta" o = GestureRotateGetAngleDeltaMethodInfo
ResolveGestureRotateMethod "getBoundingBox" o = Gtk.Gesture.GestureGetBoundingBoxMethodInfo
ResolveGestureRotateMethod "getBoundingBoxCenter" o = Gtk.Gesture.GestureGetBoundingBoxCenterMethodInfo
ResolveGestureRotateMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveGestureRotateMethod "getDevice" o = Gtk.Gesture.GestureGetDeviceMethodInfo
ResolveGestureRotateMethod "getGroup" o = Gtk.Gesture.GestureGetGroupMethodInfo
ResolveGestureRotateMethod "getLastEvent" o = Gtk.Gesture.GestureGetLastEventMethodInfo
ResolveGestureRotateMethod "getLastUpdatedSequence" o = Gtk.Gesture.GestureGetLastUpdatedSequenceMethodInfo
ResolveGestureRotateMethod "getPoint" o = Gtk.Gesture.GestureGetPointMethodInfo
ResolveGestureRotateMethod "getPropagationPhase" o = Gtk.EventController.EventControllerGetPropagationPhaseMethodInfo
ResolveGestureRotateMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveGestureRotateMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveGestureRotateMethod "getSequenceState" o = Gtk.Gesture.GestureGetSequenceStateMethodInfo
ResolveGestureRotateMethod "getSequences" o = Gtk.Gesture.GestureGetSequencesMethodInfo
ResolveGestureRotateMethod "getWidget" o = Gtk.EventController.EventControllerGetWidgetMethodInfo
ResolveGestureRotateMethod "getWindow" o = Gtk.Gesture.GestureGetWindowMethodInfo
ResolveGestureRotateMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveGestureRotateMethod "setPropagationPhase" o = Gtk.EventController.EventControllerSetPropagationPhaseMethodInfo
ResolveGestureRotateMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveGestureRotateMethod "setSequenceState" o = Gtk.Gesture.GestureSetSequenceStateMethodInfo
ResolveGestureRotateMethod "setState" o = Gtk.Gesture.GestureSetStateMethodInfo
ResolveGestureRotateMethod "setWindow" o = Gtk.Gesture.GestureSetWindowMethodInfo
ResolveGestureRotateMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveGestureRotateMethod t GestureRotate, O.MethodInfo info GestureRotate p) => O.IsLabelProxy t (GestureRotate -> p) where
fromLabelProxy _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#if MIN_VERSION_base(4,9,0)
instance (info ~ ResolveGestureRotateMethod t GestureRotate, O.MethodInfo info GestureRotate p) => O.IsLabel t (GestureRotate -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#else
fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
#endif
#endif
type GestureRotateAngleChangedCallback =
Double
-> Double
-> IO ()
noGestureRotateAngleChangedCallback :: Maybe GestureRotateAngleChangedCallback
noGestureRotateAngleChangedCallback = Nothing
type C_GestureRotateAngleChangedCallback =
Ptr () ->
CDouble ->
CDouble ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_GestureRotateAngleChangedCallback :: C_GestureRotateAngleChangedCallback -> IO (FunPtr C_GestureRotateAngleChangedCallback)
genClosure_GestureRotateAngleChanged :: GestureRotateAngleChangedCallback -> IO Closure
genClosure_GestureRotateAngleChanged cb = do
let cb' = wrap_GestureRotateAngleChangedCallback cb
mk_GestureRotateAngleChangedCallback cb' >>= newCClosure
wrap_GestureRotateAngleChangedCallback ::
GestureRotateAngleChangedCallback ->
C_GestureRotateAngleChangedCallback
wrap_GestureRotateAngleChangedCallback _cb _ angle angleDelta _ = do
let angle' = realToFrac angle
let angleDelta' = realToFrac angleDelta
_cb angle' angleDelta'
onGestureRotateAngleChanged :: (IsGestureRotate a, MonadIO m) => a -> GestureRotateAngleChangedCallback -> m SignalHandlerId
onGestureRotateAngleChanged obj cb = liftIO $ do
let cb' = wrap_GestureRotateAngleChangedCallback cb
cb'' <- mk_GestureRotateAngleChangedCallback cb'
connectSignalFunPtr obj "angle-changed" cb'' SignalConnectBefore
afterGestureRotateAngleChanged :: (IsGestureRotate a, MonadIO m) => a -> GestureRotateAngleChangedCallback -> m SignalHandlerId
afterGestureRotateAngleChanged obj cb = liftIO $ do
let cb' = wrap_GestureRotateAngleChangedCallback cb
cb'' <- mk_GestureRotateAngleChangedCallback cb'
connectSignalFunPtr obj "angle-changed" cb'' SignalConnectAfter
#if ENABLE_OVERLOADING
instance O.HasAttributeList GestureRotate
type instance O.AttributeList GestureRotate = GestureRotateAttributeList
type GestureRotateAttributeList = ('[ '("nPoints", Gtk.Gesture.GestureNPointsPropertyInfo), '("propagationPhase", Gtk.EventController.EventControllerPropagationPhasePropertyInfo), '("widget", Gtk.EventController.EventControllerWidgetPropertyInfo), '("window", Gtk.Gesture.GestureWindowPropertyInfo)] :: [(Symbol, *)])
#endif
#if ENABLE_OVERLOADING
#endif
#if ENABLE_OVERLOADING
data GestureRotateAngleChangedSignalInfo
instance SignalInfo GestureRotateAngleChangedSignalInfo where
type HaskellCallbackType GestureRotateAngleChangedSignalInfo = GestureRotateAngleChangedCallback
connectSignal _ obj cb connectMode = do
let cb' = wrap_GestureRotateAngleChangedCallback cb
cb'' <- mk_GestureRotateAngleChangedCallback cb'
connectSignalFunPtr obj "angle-changed" cb'' connectMode
type instance O.SignalList GestureRotate = GestureRotateSignalList
type GestureRotateSignalList = ('[ '("angleChanged", GestureRotateAngleChangedSignalInfo), '("begin", Gtk.Gesture.GestureBeginSignalInfo), '("cancel", Gtk.Gesture.GestureCancelSignalInfo), '("end", Gtk.Gesture.GestureEndSignalInfo), '("notify", GObject.Object.ObjectNotifySignalInfo), '("sequenceStateChanged", Gtk.Gesture.GestureSequenceStateChangedSignalInfo), '("update", Gtk.Gesture.GestureUpdateSignalInfo)] :: [(Symbol, *)])
#endif
foreign import ccall "gtk_gesture_rotate_new" gtk_gesture_rotate_new ::
Ptr Gtk.Widget.Widget ->
IO (Ptr GestureRotate)
gestureRotateNew ::
(B.CallStack.HasCallStack, MonadIO m, Gtk.Widget.IsWidget a) =>
a
-> m GestureRotate
gestureRotateNew widget = liftIO $ do
widget' <- unsafeManagedPtrCastPtr widget
result <- gtk_gesture_rotate_new widget'
checkUnexpectedReturnNULL "gestureRotateNew" result
result' <- (wrapObject GestureRotate) result
touchManagedPtr widget
return result'
#if ENABLE_OVERLOADING
#endif
foreign import ccall "gtk_gesture_rotate_get_angle_delta" gtk_gesture_rotate_get_angle_delta ::
Ptr GestureRotate ->
IO CDouble
gestureRotateGetAngleDelta ::
(B.CallStack.HasCallStack, MonadIO m, IsGestureRotate a) =>
a
-> m Double
gestureRotateGetAngleDelta gesture = liftIO $ do
gesture' <- unsafeManagedPtrCastPtr gesture
result <- gtk_gesture_rotate_get_angle_delta gesture'
let result' = realToFrac result
touchManagedPtr gesture
return result'
#if ENABLE_OVERLOADING
data GestureRotateGetAngleDeltaMethodInfo
instance (signature ~ (m Double), MonadIO m, IsGestureRotate a) => O.MethodInfo GestureRotateGetAngleDeltaMethodInfo a signature where
overloadedMethod _ = gestureRotateGetAngleDelta
#endif