{-# LANGUAGE ImplicitParams, RankNTypes, TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gdk.Objects.Monitor
(
Monitor(..) ,
IsMonitor ,
toMonitor ,
#if defined(ENABLE_OVERLOADING)
ResolveMonitorMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorGetDisplayMethodInfo ,
#endif
monitorGetDisplay ,
#if defined(ENABLE_OVERLOADING)
MonitorGetGeometryMethodInfo ,
#endif
monitorGetGeometry ,
#if defined(ENABLE_OVERLOADING)
MonitorGetHeightMmMethodInfo ,
#endif
monitorGetHeightMm ,
#if defined(ENABLE_OVERLOADING)
MonitorGetManufacturerMethodInfo ,
#endif
monitorGetManufacturer ,
#if defined(ENABLE_OVERLOADING)
MonitorGetModelMethodInfo ,
#endif
monitorGetModel ,
#if defined(ENABLE_OVERLOADING)
MonitorGetRefreshRateMethodInfo ,
#endif
monitorGetRefreshRate ,
#if defined(ENABLE_OVERLOADING)
MonitorGetScaleFactorMethodInfo ,
#endif
monitorGetScaleFactor ,
#if defined(ENABLE_OVERLOADING)
MonitorGetSubpixelLayoutMethodInfo ,
#endif
monitorGetSubpixelLayout ,
#if defined(ENABLE_OVERLOADING)
MonitorGetWidthMmMethodInfo ,
#endif
monitorGetWidthMm ,
#if defined(ENABLE_OVERLOADING)
MonitorGetWorkareaMethodInfo ,
#endif
monitorGetWorkarea ,
#if defined(ENABLE_OVERLOADING)
MonitorIsPrimaryMethodInfo ,
#endif
monitorIsPrimary ,
#if defined(ENABLE_OVERLOADING)
MonitorDisplayPropertyInfo ,
#endif
constructMonitorDisplay ,
getMonitorDisplay ,
#if defined(ENABLE_OVERLOADING)
monitorDisplay ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorGeometryPropertyInfo ,
#endif
getMonitorGeometry ,
#if defined(ENABLE_OVERLOADING)
monitorGeometry ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorHeightMmPropertyInfo ,
#endif
getMonitorHeightMm ,
#if defined(ENABLE_OVERLOADING)
monitorHeightMm ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorManufacturerPropertyInfo ,
#endif
getMonitorManufacturer ,
#if defined(ENABLE_OVERLOADING)
monitorManufacturer ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorModelPropertyInfo ,
#endif
getMonitorModel ,
#if defined(ENABLE_OVERLOADING)
monitorModel ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorRefreshRatePropertyInfo ,
#endif
getMonitorRefreshRate ,
#if defined(ENABLE_OVERLOADING)
monitorRefreshRate ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorScaleFactorPropertyInfo ,
#endif
getMonitorScaleFactor ,
#if defined(ENABLE_OVERLOADING)
monitorScaleFactor ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorSubpixelLayoutPropertyInfo ,
#endif
getMonitorSubpixelLayout ,
#if defined(ENABLE_OVERLOADING)
monitorSubpixelLayout ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorWidthMmPropertyInfo ,
#endif
getMonitorWidthMm ,
#if defined(ENABLE_OVERLOADING)
monitorWidthMm ,
#endif
#if defined(ENABLE_OVERLOADING)
MonitorWorkareaPropertyInfo ,
#endif
getMonitorWorkarea ,
#if defined(ENABLE_OVERLOADING)
monitorWorkarea ,
#endif
MonitorInvalidateCallback ,
#if defined(ENABLE_OVERLOADING)
MonitorInvalidateSignalInfo ,
#endif
afterMonitorInvalidate ,
onMonitorInvalidate ,
) 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 Data.Word as DW
import qualified Data.Int as DI
import qualified System.Posix.Types as SPT
import qualified Foreign.C.Types as FCT
#if MIN_VERSION_base(4,18,0)
import qualified GI.Cairo.Enums as Cairo.Enums
import qualified GI.Cairo.Structs.Context as Cairo.Context
import qualified GI.Cairo.Structs.FontOptions as Cairo.FontOptions
import qualified GI.Cairo.Structs.Pattern as Cairo.Pattern
import qualified GI.Cairo.Structs.Region as Cairo.Region
import qualified GI.Cairo.Structs.Surface as Cairo.Surface
import qualified GI.GLib.Callbacks as GLib.Callbacks
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.AppLaunchContext as Gdk.AppLaunchContext
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.DeviceManager as Gdk.DeviceManager
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.DragContext as Gdk.DragContext
import {-# SOURCE #-} qualified GI.Gdk.Objects.DrawingContext as Gdk.DrawingContext
import {-# SOURCE #-} qualified GI.Gdk.Objects.FrameClock as Gdk.FrameClock
import {-# SOURCE #-} qualified GI.Gdk.Objects.GLContext as Gdk.GLContext
import {-# SOURCE #-} qualified GI.Gdk.Objects.Screen as Gdk.Screen
import {-# SOURCE #-} qualified GI.Gdk.Objects.Seat as Gdk.Seat
import {-# SOURCE #-} qualified GI.Gdk.Objects.Visual as Gdk.Visual
import {-# SOURCE #-} qualified GI.Gdk.Objects.Window as Gdk.Window
import {-# SOURCE #-} qualified GI.Gdk.Structs.Atom as Gdk.Atom
import {-# SOURCE #-} qualified GI.Gdk.Structs.Color as Gdk.Color
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventAny as Gdk.EventAny
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventButton as Gdk.EventButton
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventConfigure as Gdk.EventConfigure
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventCrossing as Gdk.EventCrossing
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventDND as Gdk.EventDND
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventExpose as Gdk.EventExpose
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventFocus as Gdk.EventFocus
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventGrabBroken as Gdk.EventGrabBroken
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventKey as Gdk.EventKey
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventMotion as Gdk.EventMotion
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventOwnerChange as Gdk.EventOwnerChange
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventPadAxis as Gdk.EventPadAxis
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventPadButton as Gdk.EventPadButton
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventPadGroupMode as Gdk.EventPadGroupMode
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventProperty as Gdk.EventProperty
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventProximity as Gdk.EventProximity
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventScroll as Gdk.EventScroll
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventSelection as Gdk.EventSelection
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventSequence as Gdk.EventSequence
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventSetting as Gdk.EventSetting
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventTouch as Gdk.EventTouch
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventTouchpadPinch as Gdk.EventTouchpadPinch
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventTouchpadSwipe as Gdk.EventTouchpadSwipe
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventVisibility as Gdk.EventVisibility
import {-# SOURCE #-} qualified GI.Gdk.Structs.EventWindowState as Gdk.EventWindowState
import {-# SOURCE #-} qualified GI.Gdk.Structs.FrameTimings as Gdk.FrameTimings
import {-# SOURCE #-} qualified GI.Gdk.Structs.Geometry as Gdk.Geometry
import {-# SOURCE #-} qualified GI.Gdk.Structs.RGBA as Gdk.RGBA
import {-# SOURCE #-} qualified GI.Gdk.Structs.Rectangle as Gdk.Rectangle
import {-# SOURCE #-} qualified GI.Gdk.Structs.WindowAttr as Gdk.WindowAttr
import {-# SOURCE #-} qualified GI.Gdk.Unions.Event as Gdk.Event
import qualified GI.GdkPixbuf.Objects.Pixbuf as GdkPixbuf.Pixbuf
import qualified GI.Gio.Interfaces.Icon as Gio.Icon
import qualified GI.Gio.Objects.AppLaunchContext as Gio.AppLaunchContext
#else
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gdk.Enums as Gdk.Enums
import {-# SOURCE #-} qualified GI.Gdk.Objects.Display as Gdk.Display
import {-# SOURCE #-} qualified GI.Gdk.Structs.Rectangle as Gdk.Rectangle
#endif
newtype Monitor = Monitor (SP.ManagedPtr Monitor)
deriving (Monitor -> Monitor -> Bool
(Monitor -> Monitor -> Bool)
-> (Monitor -> Monitor -> Bool) -> Eq Monitor
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: Monitor -> Monitor -> Bool
== :: Monitor -> Monitor -> Bool
$c/= :: Monitor -> Monitor -> Bool
/= :: Monitor -> Monitor -> Bool
Eq)
instance SP.ManagedPtrNewtype Monitor where
toManagedPtr :: Monitor -> ManagedPtr Monitor
toManagedPtr (Monitor ManagedPtr Monitor
p) = ManagedPtr Monitor
p
foreign import ccall "gdk_monitor_get_type"
c_gdk_monitor_get_type :: IO B.Types.GType
instance B.Types.TypedObject Monitor where
glibType :: IO GType
glibType = IO GType
c_gdk_monitor_get_type
instance B.Types.GObject Monitor
class (SP.GObject o, O.IsDescendantOf Monitor o) => IsMonitor o
instance (SP.GObject o, O.IsDescendantOf Monitor o) => IsMonitor o
instance O.HasParentTypes Monitor
type instance O.ParentTypes Monitor = '[GObject.Object.Object]
toMonitor :: (MIO.MonadIO m, IsMonitor o) => o -> m Monitor
toMonitor :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Monitor
toMonitor = IO Monitor -> m Monitor
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Monitor -> m Monitor) -> (o -> IO Monitor) -> o -> m Monitor
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr Monitor -> Monitor) -> o -> IO Monitor
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr Monitor -> Monitor
Monitor
instance B.GValue.IsGValue (Maybe Monitor) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_gdk_monitor_get_type
gvalueSet_ :: Ptr GValue -> Maybe Monitor -> IO ()
gvalueSet_ Ptr GValue
gv Maybe Monitor
P.Nothing = Ptr GValue -> Ptr Monitor -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr Monitor
forall a. Ptr a
FP.nullPtr :: FP.Ptr Monitor)
gvalueSet_ Ptr GValue
gv (P.Just Monitor
obj) = Monitor -> (Ptr Monitor -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr Monitor
obj (Ptr GValue -> Ptr Monitor -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe Monitor)
gvalueGet_ Ptr GValue
gv = do
Ptr Monitor
ptr <- Ptr GValue -> IO (Ptr Monitor)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr Monitor)
if Ptr Monitor
ptr Ptr Monitor -> Ptr Monitor -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr Monitor
forall a. Ptr a
FP.nullPtr
then Monitor -> Maybe Monitor
forall a. a -> Maybe a
P.Just (Monitor -> Maybe Monitor) -> IO Monitor -> IO (Maybe Monitor)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr Monitor -> Monitor) -> Ptr Monitor -> IO Monitor
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr Monitor -> Monitor
Monitor Ptr Monitor
ptr
else Maybe Monitor -> IO (Maybe Monitor)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Monitor
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveMonitorMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveMonitorMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveMonitorMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveMonitorMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveMonitorMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveMonitorMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveMonitorMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveMonitorMethod "isPrimary" o = MonitorIsPrimaryMethodInfo
ResolveMonitorMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveMonitorMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveMonitorMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveMonitorMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveMonitorMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveMonitorMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveMonitorMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveMonitorMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveMonitorMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveMonitorMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveMonitorMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveMonitorMethod "getDisplay" o = MonitorGetDisplayMethodInfo
ResolveMonitorMethod "getGeometry" o = MonitorGetGeometryMethodInfo
ResolveMonitorMethod "getHeightMm" o = MonitorGetHeightMmMethodInfo
ResolveMonitorMethod "getManufacturer" o = MonitorGetManufacturerMethodInfo
ResolveMonitorMethod "getModel" o = MonitorGetModelMethodInfo
ResolveMonitorMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveMonitorMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveMonitorMethod "getRefreshRate" o = MonitorGetRefreshRateMethodInfo
ResolveMonitorMethod "getScaleFactor" o = MonitorGetScaleFactorMethodInfo
ResolveMonitorMethod "getSubpixelLayout" o = MonitorGetSubpixelLayoutMethodInfo
ResolveMonitorMethod "getWidthMm" o = MonitorGetWidthMmMethodInfo
ResolveMonitorMethod "getWorkarea" o = MonitorGetWorkareaMethodInfo
ResolveMonitorMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveMonitorMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveMonitorMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveMonitorMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveMonitorMethod t Monitor, O.OverloadedMethod info Monitor p) => OL.IsLabel t (Monitor -> 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 ~ ResolveMonitorMethod t Monitor, O.OverloadedMethod info Monitor p, R.HasField t Monitor p) => R.HasField t Monitor p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveMonitorMethod t Monitor, O.OverloadedMethodInfo info Monitor) => OL.IsLabel t (O.MethodProxy info Monitor) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
type MonitorInvalidateCallback =
IO ()
type C_MonitorInvalidateCallback =
Ptr Monitor ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_MonitorInvalidateCallback :: C_MonitorInvalidateCallback -> IO (FunPtr C_MonitorInvalidateCallback)
wrap_MonitorInvalidateCallback ::
GObject a => (a -> MonitorInvalidateCallback) ->
C_MonitorInvalidateCallback
wrap_MonitorInvalidateCallback :: forall a. GObject a => (a -> IO ()) -> C_MonitorInvalidateCallback
wrap_MonitorInvalidateCallback a -> IO ()
gi'cb Ptr Monitor
gi'selfPtr Ptr ()
_ = do
Ptr Monitor -> (Monitor -> IO ()) -> IO ()
forall o b.
(HasCallStack, GObject o) =>
Ptr o -> (o -> IO b) -> IO b
B.ManagedPtr.withNewObject Ptr Monitor
gi'selfPtr ((Monitor -> IO ()) -> IO ()) -> (Monitor -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Monitor
gi'self -> a -> IO ()
gi'cb (Monitor -> a
forall a b. Coercible a b => a -> b
Coerce.coerce Monitor
gi'self)
onMonitorInvalidate :: (IsMonitor a, MonadIO m) => a -> ((?self :: a) => MonitorInvalidateCallback) -> m SignalHandlerId
onMonitorInvalidate :: forall a (m :: * -> *).
(IsMonitor a, MonadIO m) =>
a -> ((?self::a) => IO ()) -> m SignalHandlerId
onMonitorInvalidate a
obj (?self::a) => IO ()
cb = IO SignalHandlerId -> m SignalHandlerId
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SignalHandlerId -> m SignalHandlerId)
-> IO SignalHandlerId -> m SignalHandlerId
forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> IO ()
wrapped a
self = let ?self = a
?self::a
self in IO ()
(?self::a) => IO ()
cb
let wrapped' :: C_MonitorInvalidateCallback
wrapped' = (a -> IO ()) -> C_MonitorInvalidateCallback
forall a. GObject a => (a -> IO ()) -> C_MonitorInvalidateCallback
wrap_MonitorInvalidateCallback a -> IO ()
wrapped
FunPtr C_MonitorInvalidateCallback
wrapped'' <- C_MonitorInvalidateCallback
-> IO (FunPtr C_MonitorInvalidateCallback)
mk_MonitorInvalidateCallback C_MonitorInvalidateCallback
wrapped'
a
-> Text
-> FunPtr C_MonitorInvalidateCallback
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"invalidate" FunPtr C_MonitorInvalidateCallback
wrapped'' SignalConnectMode
SignalConnectBefore Maybe Text
forall a. Maybe a
Nothing
afterMonitorInvalidate :: (IsMonitor a, MonadIO m) => a -> ((?self :: a) => MonitorInvalidateCallback) -> m SignalHandlerId
afterMonitorInvalidate :: forall a (m :: * -> *).
(IsMonitor a, MonadIO m) =>
a -> ((?self::a) => IO ()) -> m SignalHandlerId
afterMonitorInvalidate a
obj (?self::a) => IO ()
cb = IO SignalHandlerId -> m SignalHandlerId
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SignalHandlerId -> m SignalHandlerId)
-> IO SignalHandlerId -> m SignalHandlerId
forall a b. (a -> b) -> a -> b
$ do
let wrapped :: a -> IO ()
wrapped a
self = let ?self = a
?self::a
self in IO ()
(?self::a) => IO ()
cb
let wrapped' :: C_MonitorInvalidateCallback
wrapped' = (a -> IO ()) -> C_MonitorInvalidateCallback
forall a. GObject a => (a -> IO ()) -> C_MonitorInvalidateCallback
wrap_MonitorInvalidateCallback a -> IO ()
wrapped
FunPtr C_MonitorInvalidateCallback
wrapped'' <- C_MonitorInvalidateCallback
-> IO (FunPtr C_MonitorInvalidateCallback)
mk_MonitorInvalidateCallback C_MonitorInvalidateCallback
wrapped'
a
-> Text
-> FunPtr C_MonitorInvalidateCallback
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
forall o a.
GObject o =>
o
-> Text
-> FunPtr a
-> SignalConnectMode
-> Maybe Text
-> IO SignalHandlerId
connectSignalFunPtr a
obj Text
"invalidate" FunPtr C_MonitorInvalidateCallback
wrapped'' SignalConnectMode
SignalConnectAfter Maybe Text
forall a. Maybe a
Nothing
#if defined(ENABLE_OVERLOADING)
data MonitorInvalidateSignalInfo
instance SignalInfo MonitorInvalidateSignalInfo where
type HaskellCallbackType MonitorInvalidateSignalInfo = MonitorInvalidateCallback
connectSignal obj cb connectMode detail = do
let cb' = wrap_MonitorInvalidateCallback cb
cb'' <- mk_MonitorInvalidateCallback cb'
connectSignalFunPtr obj "invalidate" cb'' connectMode detail
dbgSignalInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor::invalidate"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:signal:invalidate"})
#endif
getMonitorDisplay :: (MonadIO m, IsMonitor o) => o -> m Gdk.Display.Display
getMonitorDisplay :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Display
getMonitorDisplay o
obj = IO Display -> m Display
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Display -> m Display) -> IO Display -> m Display
forall a b. (a -> b) -> a -> b
$ Text -> IO (Maybe Display) -> IO Display
forall a. HasCallStack => Text -> IO (Maybe a) -> IO a
checkUnexpectedNothing Text
"getMonitorDisplay" (IO (Maybe Display) -> IO Display)
-> IO (Maybe Display) -> IO Display
forall a b. (a -> b) -> a -> b
$ o
-> String -> (ManagedPtr Display -> Display) -> IO (Maybe Display)
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
constructMonitorDisplay :: (IsMonitor o, MIO.MonadIO m, Gdk.Display.IsDisplay a) => a -> m (GValueConstruct o)
constructMonitorDisplay :: forall o (m :: * -> *) a.
(IsMonitor o, MonadIO m, IsDisplay a) =>
a -> m (GValueConstruct o)
constructMonitorDisplay a
val = IO (GValueConstruct o) -> m (GValueConstruct o)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> m (GValueConstruct o))
-> IO (GValueConstruct o) -> m (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ do
IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> IO (GValueConstruct o))
-> IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ String -> Maybe a -> IO (GValueConstruct o)
forall a o.
GObject a =>
String -> Maybe a -> IO (GValueConstruct o)
B.Properties.constructObjectPropertyObject String
"display" (a -> Maybe a
forall a. a -> Maybe a
P.Just a
val)
#if defined(ENABLE_OVERLOADING)
data MonitorDisplayPropertyInfo
instance AttrInfo MonitorDisplayPropertyInfo where
type AttrAllowedOps MonitorDisplayPropertyInfo = '[ 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint MonitorDisplayPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorDisplayPropertyInfo = Gdk.Display.IsDisplay
type AttrTransferTypeConstraint MonitorDisplayPropertyInfo = Gdk.Display.IsDisplay
type AttrTransferType MonitorDisplayPropertyInfo = Gdk.Display.Display
type AttrGetType MonitorDisplayPropertyInfo = Gdk.Display.Display
type AttrLabel MonitorDisplayPropertyInfo = "display"
type AttrOrigin MonitorDisplayPropertyInfo = Monitor
attrGet = getMonitorDisplay
attrSet = undefined
attrTransfer _ v = do
unsafeCastTo Gdk.Display.Display v
attrConstruct = constructMonitorDisplay
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.display"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:display"
})
#endif
getMonitorGeometry :: (MonadIO m, IsMonitor o) => o -> m (Maybe Gdk.Rectangle.Rectangle)
getMonitorGeometry :: forall (m :: * -> *) o.
(MonadIO m, IsMonitor o) =>
o -> m (Maybe Rectangle)
getMonitorGeometry o
obj = IO (Maybe Rectangle) -> m (Maybe Rectangle)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe Rectangle) -> m (Maybe Rectangle))
-> IO (Maybe Rectangle) -> m (Maybe Rectangle)
forall a b. (a -> b) -> a -> b
$ o
-> String
-> (ManagedPtr Rectangle -> Rectangle)
-> IO (Maybe Rectangle)
forall a b.
(GObject a, GBoxed b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyBoxed o
obj String
"geometry" ManagedPtr Rectangle -> Rectangle
Gdk.Rectangle.Rectangle
#if defined(ENABLE_OVERLOADING)
data MonitorGeometryPropertyInfo
instance AttrInfo MonitorGeometryPropertyInfo where
type AttrAllowedOps MonitorGeometryPropertyInfo = '[ 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint MonitorGeometryPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorGeometryPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorGeometryPropertyInfo = (~) ()
type AttrTransferType MonitorGeometryPropertyInfo = ()
type AttrGetType MonitorGeometryPropertyInfo = (Maybe Gdk.Rectangle.Rectangle)
type AttrLabel MonitorGeometryPropertyInfo = "geometry"
type AttrOrigin MonitorGeometryPropertyInfo = Monitor
attrGet = getMonitorGeometry
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.geometry"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:geometry"
})
#endif
getMonitorHeightMm :: (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorHeightMm :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorHeightMm o
obj = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Int32
forall a. GObject a => a -> String -> IO Int32
B.Properties.getObjectPropertyInt32 o
obj String
"height-mm"
#if defined(ENABLE_OVERLOADING)
data MonitorHeightMmPropertyInfo
instance AttrInfo MonitorHeightMmPropertyInfo where
type AttrAllowedOps MonitorHeightMmPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint MonitorHeightMmPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorHeightMmPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorHeightMmPropertyInfo = (~) ()
type AttrTransferType MonitorHeightMmPropertyInfo = ()
type AttrGetType MonitorHeightMmPropertyInfo = Int32
type AttrLabel MonitorHeightMmPropertyInfo = "height-mm"
type AttrOrigin MonitorHeightMmPropertyInfo = Monitor
attrGet = getMonitorHeightMm
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.heightMm"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:heightMm"
})
#endif
getMonitorManufacturer :: (MonadIO m, IsMonitor o) => o -> m (Maybe T.Text)
getMonitorManufacturer :: forall (m :: * -> *) o.
(MonadIO m, IsMonitor o) =>
o -> m (Maybe Text)
getMonitorManufacturer o
obj = IO (Maybe Text) -> m (Maybe Text)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe Text) -> m (Maybe Text))
-> IO (Maybe Text) -> m (Maybe Text)
forall a b. (a -> b) -> a -> b
$ o -> String -> IO (Maybe Text)
forall a. GObject a => a -> String -> IO (Maybe Text)
B.Properties.getObjectPropertyString o
obj String
"manufacturer"
#if defined(ENABLE_OVERLOADING)
data MonitorManufacturerPropertyInfo
instance AttrInfo MonitorManufacturerPropertyInfo where
type AttrAllowedOps MonitorManufacturerPropertyInfo = '[ 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint MonitorManufacturerPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorManufacturerPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorManufacturerPropertyInfo = (~) ()
type AttrTransferType MonitorManufacturerPropertyInfo = ()
type AttrGetType MonitorManufacturerPropertyInfo = (Maybe T.Text)
type AttrLabel MonitorManufacturerPropertyInfo = "manufacturer"
type AttrOrigin MonitorManufacturerPropertyInfo = Monitor
attrGet = getMonitorManufacturer
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.manufacturer"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:manufacturer"
})
#endif
getMonitorModel :: (MonadIO m, IsMonitor o) => o -> m (Maybe T.Text)
getMonitorModel :: forall (m :: * -> *) o.
(MonadIO m, IsMonitor o) =>
o -> m (Maybe Text)
getMonitorModel o
obj = IO (Maybe Text) -> m (Maybe Text)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe Text) -> m (Maybe Text))
-> IO (Maybe Text) -> m (Maybe Text)
forall a b. (a -> b) -> a -> b
$ o -> String -> IO (Maybe Text)
forall a. GObject a => a -> String -> IO (Maybe Text)
B.Properties.getObjectPropertyString o
obj String
"model"
#if defined(ENABLE_OVERLOADING)
data MonitorModelPropertyInfo
instance AttrInfo MonitorModelPropertyInfo where
type AttrAllowedOps MonitorModelPropertyInfo = '[ 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint MonitorModelPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorModelPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorModelPropertyInfo = (~) ()
type AttrTransferType MonitorModelPropertyInfo = ()
type AttrGetType MonitorModelPropertyInfo = (Maybe T.Text)
type AttrLabel MonitorModelPropertyInfo = "model"
type AttrOrigin MonitorModelPropertyInfo = Monitor
attrGet = getMonitorModel
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.model"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:model"
})
#endif
getMonitorRefreshRate :: (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorRefreshRate :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorRefreshRate o
obj = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Int32
forall a. GObject a => a -> String -> IO Int32
B.Properties.getObjectPropertyInt32 o
obj String
"refresh-rate"
#if defined(ENABLE_OVERLOADING)
data MonitorRefreshRatePropertyInfo
instance AttrInfo MonitorRefreshRatePropertyInfo where
type AttrAllowedOps MonitorRefreshRatePropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint MonitorRefreshRatePropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorRefreshRatePropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorRefreshRatePropertyInfo = (~) ()
type AttrTransferType MonitorRefreshRatePropertyInfo = ()
type AttrGetType MonitorRefreshRatePropertyInfo = Int32
type AttrLabel MonitorRefreshRatePropertyInfo = "refresh-rate"
type AttrOrigin MonitorRefreshRatePropertyInfo = Monitor
attrGet = getMonitorRefreshRate
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.refreshRate"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:refreshRate"
})
#endif
getMonitorScaleFactor :: (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorScaleFactor :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorScaleFactor o
obj = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Int32
forall a. GObject a => a -> String -> IO Int32
B.Properties.getObjectPropertyInt32 o
obj String
"scale-factor"
#if defined(ENABLE_OVERLOADING)
data MonitorScaleFactorPropertyInfo
instance AttrInfo MonitorScaleFactorPropertyInfo where
type AttrAllowedOps MonitorScaleFactorPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint MonitorScaleFactorPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorScaleFactorPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorScaleFactorPropertyInfo = (~) ()
type AttrTransferType MonitorScaleFactorPropertyInfo = ()
type AttrGetType MonitorScaleFactorPropertyInfo = Int32
type AttrLabel MonitorScaleFactorPropertyInfo = "scale-factor"
type AttrOrigin MonitorScaleFactorPropertyInfo = Monitor
attrGet = getMonitorScaleFactor
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.scaleFactor"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:scaleFactor"
})
#endif
getMonitorSubpixelLayout :: (MonadIO m, IsMonitor o) => o -> m Gdk.Enums.SubpixelLayout
getMonitorSubpixelLayout :: forall (m :: * -> *) o.
(MonadIO m, IsMonitor o) =>
o -> m SubpixelLayout
getMonitorSubpixelLayout o
obj = IO SubpixelLayout -> m SubpixelLayout
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO SubpixelLayout -> m SubpixelLayout)
-> IO SubpixelLayout -> m SubpixelLayout
forall a b. (a -> b) -> a -> b
$ o -> String -> IO SubpixelLayout
forall a b. (GObject a, Enum b, BoxedEnum b) => a -> String -> IO b
B.Properties.getObjectPropertyEnum o
obj String
"subpixel-layout"
#if defined(ENABLE_OVERLOADING)
data MonitorSubpixelLayoutPropertyInfo
instance AttrInfo MonitorSubpixelLayoutPropertyInfo where
type AttrAllowedOps MonitorSubpixelLayoutPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint MonitorSubpixelLayoutPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorSubpixelLayoutPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorSubpixelLayoutPropertyInfo = (~) ()
type AttrTransferType MonitorSubpixelLayoutPropertyInfo = ()
type AttrGetType MonitorSubpixelLayoutPropertyInfo = Gdk.Enums.SubpixelLayout
type AttrLabel MonitorSubpixelLayoutPropertyInfo = "subpixel-layout"
type AttrOrigin MonitorSubpixelLayoutPropertyInfo = Monitor
attrGet = getMonitorSubpixelLayout
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.subpixelLayout"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:subpixelLayout"
})
#endif
getMonitorWidthMm :: (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorWidthMm :: forall (m :: * -> *) o. (MonadIO m, IsMonitor o) => o -> m Int32
getMonitorWidthMm o
obj = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ o -> String -> IO Int32
forall a. GObject a => a -> String -> IO Int32
B.Properties.getObjectPropertyInt32 o
obj String
"width-mm"
#if defined(ENABLE_OVERLOADING)
data MonitorWidthMmPropertyInfo
instance AttrInfo MonitorWidthMmPropertyInfo where
type AttrAllowedOps MonitorWidthMmPropertyInfo = '[ 'AttrGet]
type AttrBaseTypeConstraint MonitorWidthMmPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorWidthMmPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorWidthMmPropertyInfo = (~) ()
type AttrTransferType MonitorWidthMmPropertyInfo = ()
type AttrGetType MonitorWidthMmPropertyInfo = Int32
type AttrLabel MonitorWidthMmPropertyInfo = "width-mm"
type AttrOrigin MonitorWidthMmPropertyInfo = Monitor
attrGet = getMonitorWidthMm
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.widthMm"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:widthMm"
})
#endif
getMonitorWorkarea :: (MonadIO m, IsMonitor o) => o -> m (Maybe Gdk.Rectangle.Rectangle)
getMonitorWorkarea :: forall (m :: * -> *) o.
(MonadIO m, IsMonitor o) =>
o -> m (Maybe Rectangle)
getMonitorWorkarea o
obj = IO (Maybe Rectangle) -> m (Maybe Rectangle)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe Rectangle) -> m (Maybe Rectangle))
-> IO (Maybe Rectangle) -> m (Maybe Rectangle)
forall a b. (a -> b) -> a -> b
$ o
-> String
-> (ManagedPtr Rectangle -> Rectangle)
-> IO (Maybe Rectangle)
forall a b.
(GObject a, GBoxed b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyBoxed o
obj String
"workarea" ManagedPtr Rectangle -> Rectangle
Gdk.Rectangle.Rectangle
#if defined(ENABLE_OVERLOADING)
data MonitorWorkareaPropertyInfo
instance AttrInfo MonitorWorkareaPropertyInfo where
type AttrAllowedOps MonitorWorkareaPropertyInfo = '[ 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint MonitorWorkareaPropertyInfo = IsMonitor
type AttrSetTypeConstraint MonitorWorkareaPropertyInfo = (~) ()
type AttrTransferTypeConstraint MonitorWorkareaPropertyInfo = (~) ()
type AttrTransferType MonitorWorkareaPropertyInfo = ()
type AttrGetType MonitorWorkareaPropertyInfo = (Maybe Gdk.Rectangle.Rectangle)
type AttrLabel MonitorWorkareaPropertyInfo = "workarea"
type AttrOrigin MonitorWorkareaPropertyInfo = Monitor
attrGet = getMonitorWorkarea
attrSet = undefined
attrTransfer _ = undefined
attrConstruct = undefined
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.workarea"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#g:attr:workarea"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList Monitor
type instance O.AttributeList Monitor = MonitorAttributeList
type MonitorAttributeList = ('[ '("display", MonitorDisplayPropertyInfo), '("geometry", MonitorGeometryPropertyInfo), '("heightMm", MonitorHeightMmPropertyInfo), '("manufacturer", MonitorManufacturerPropertyInfo), '("model", MonitorModelPropertyInfo), '("refreshRate", MonitorRefreshRatePropertyInfo), '("scaleFactor", MonitorScaleFactorPropertyInfo), '("subpixelLayout", MonitorSubpixelLayoutPropertyInfo), '("widthMm", MonitorWidthMmPropertyInfo), '("workarea", MonitorWorkareaPropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
monitorDisplay :: AttrLabelProxy "display"
monitorDisplay = AttrLabelProxy
monitorGeometry :: AttrLabelProxy "geometry"
monitorGeometry = AttrLabelProxy
monitorHeightMm :: AttrLabelProxy "heightMm"
monitorHeightMm = AttrLabelProxy
monitorManufacturer :: AttrLabelProxy "manufacturer"
monitorManufacturer = AttrLabelProxy
monitorModel :: AttrLabelProxy "model"
monitorModel = AttrLabelProxy
monitorRefreshRate :: AttrLabelProxy "refreshRate"
monitorRefreshRate = AttrLabelProxy
monitorScaleFactor :: AttrLabelProxy "scaleFactor"
monitorScaleFactor = AttrLabelProxy
monitorSubpixelLayout :: AttrLabelProxy "subpixelLayout"
monitorSubpixelLayout = AttrLabelProxy
monitorWidthMm :: AttrLabelProxy "widthMm"
monitorWidthMm = AttrLabelProxy
monitorWorkarea :: AttrLabelProxy "workarea"
monitorWorkarea = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList Monitor = MonitorSignalList
type MonitorSignalList = ('[ '("invalidate", MonitorInvalidateSignalInfo), '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "gdk_monitor_get_display" gdk_monitor_get_display ::
Ptr Monitor ->
IO (Ptr Gdk.Display.Display)
monitorGetDisplay ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Gdk.Display.Display
monitorGetDisplay :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Display
monitorGetDisplay a
monitor = IO Display -> m Display
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Display -> m Display) -> IO Display -> m Display
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Ptr Display
result <- Ptr Monitor -> IO (Ptr Display)
gdk_monitor_get_display Ptr Monitor
monitor'
Text -> Ptr Display -> IO ()
forall a. HasCallStack => Text -> Ptr a -> IO ()
checkUnexpectedReturnNULL Text
"monitorGetDisplay" Ptr Display
result
Display
result' <- ((ManagedPtr Display -> Display) -> Ptr Display -> IO Display
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
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Display -> IO Display
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Display
result'
#if defined(ENABLE_OVERLOADING)
data MonitorGetDisplayMethodInfo
instance (signature ~ (m Gdk.Display.Display), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetDisplayMethodInfo a signature where
overloadedMethod = monitorGetDisplay
instance O.OverloadedMethodInfo MonitorGetDisplayMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetDisplay",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetDisplay"
})
#endif
foreign import ccall "gdk_monitor_get_geometry" gdk_monitor_get_geometry ::
Ptr Monitor ->
Ptr Gdk.Rectangle.Rectangle ->
IO ()
monitorGetGeometry ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m (Gdk.Rectangle.Rectangle)
monitorGetGeometry :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Rectangle
monitorGetGeometry a
monitor = IO Rectangle -> m Rectangle
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Rectangle -> m Rectangle) -> IO Rectangle -> m Rectangle
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Ptr Rectangle
geometry <- Int -> IO (Ptr Rectangle)
forall a. GBoxed a => Int -> IO (Ptr a)
SP.callocBoxedBytes Int
16 :: IO (Ptr Gdk.Rectangle.Rectangle)
Ptr Monitor -> Ptr Rectangle -> IO ()
gdk_monitor_get_geometry Ptr Monitor
monitor' Ptr Rectangle
geometry
Rectangle
geometry' <- ((ManagedPtr Rectangle -> Rectangle)
-> Ptr Rectangle -> IO Rectangle
forall a.
(HasCallStack, GBoxed a) =>
(ManagedPtr a -> a) -> Ptr a -> IO a
wrapBoxed ManagedPtr Rectangle -> Rectangle
Gdk.Rectangle.Rectangle) Ptr Rectangle
geometry
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Rectangle -> IO Rectangle
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Rectangle
geometry'
#if defined(ENABLE_OVERLOADING)
data MonitorGetGeometryMethodInfo
instance (signature ~ (m (Gdk.Rectangle.Rectangle)), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetGeometryMethodInfo a signature where
overloadedMethod = monitorGetGeometry
instance O.OverloadedMethodInfo MonitorGetGeometryMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetGeometry",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetGeometry"
})
#endif
foreign import ccall "gdk_monitor_get_height_mm" gdk_monitor_get_height_mm ::
Ptr Monitor ->
IO Int32
monitorGetHeightMm ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Int32
monitorGetHeightMm :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Int32
monitorGetHeightMm a
monitor = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Int32
result <- Ptr Monitor -> IO Int32
gdk_monitor_get_height_mm Ptr Monitor
monitor'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Int32 -> IO Int32
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Int32
result
#if defined(ENABLE_OVERLOADING)
data MonitorGetHeightMmMethodInfo
instance (signature ~ (m Int32), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetHeightMmMethodInfo a signature where
overloadedMethod = monitorGetHeightMm
instance O.OverloadedMethodInfo MonitorGetHeightMmMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetHeightMm",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetHeightMm"
})
#endif
foreign import ccall "gdk_monitor_get_manufacturer" gdk_monitor_get_manufacturer ::
Ptr Monitor ->
IO CString
monitorGetManufacturer ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m (Maybe T.Text)
monitorGetManufacturer :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m (Maybe Text)
monitorGetManufacturer a
monitor = IO (Maybe Text) -> m (Maybe Text)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe Text) -> m (Maybe Text))
-> IO (Maybe Text) -> m (Maybe Text)
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
CString
result <- Ptr Monitor -> IO CString
gdk_monitor_get_manufacturer Ptr Monitor
monitor'
Maybe Text
maybeResult <- CString -> (CString -> IO Text) -> IO (Maybe Text)
forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull CString
result ((CString -> IO Text) -> IO (Maybe Text))
-> (CString -> IO Text) -> IO (Maybe Text)
forall a b. (a -> b) -> a -> b
$ \CString
result' -> do
Text
result'' <- HasCallStack => CString -> IO Text
CString -> IO Text
cstringToText CString
result'
Text -> IO Text
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Text
result''
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Maybe Text -> IO (Maybe Text)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Text
maybeResult
#if defined(ENABLE_OVERLOADING)
data MonitorGetManufacturerMethodInfo
instance (signature ~ (m (Maybe T.Text)), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetManufacturerMethodInfo a signature where
overloadedMethod = monitorGetManufacturer
instance O.OverloadedMethodInfo MonitorGetManufacturerMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetManufacturer",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetManufacturer"
})
#endif
foreign import ccall "gdk_monitor_get_model" gdk_monitor_get_model ::
Ptr Monitor ->
IO CString
monitorGetModel ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m (Maybe T.Text)
monitorGetModel :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m (Maybe Text)
monitorGetModel a
monitor = IO (Maybe Text) -> m (Maybe Text)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe Text) -> m (Maybe Text))
-> IO (Maybe Text) -> m (Maybe Text)
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
CString
result <- Ptr Monitor -> IO CString
gdk_monitor_get_model Ptr Monitor
monitor'
Maybe Text
maybeResult <- CString -> (CString -> IO Text) -> IO (Maybe Text)
forall a b. Ptr a -> (Ptr a -> IO b) -> IO (Maybe b)
convertIfNonNull CString
result ((CString -> IO Text) -> IO (Maybe Text))
-> (CString -> IO Text) -> IO (Maybe Text)
forall a b. (a -> b) -> a -> b
$ \CString
result' -> do
Text
result'' <- HasCallStack => CString -> IO Text
CString -> IO Text
cstringToText CString
result'
Text -> IO Text
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Text
result''
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Maybe Text -> IO (Maybe Text)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Text
maybeResult
#if defined(ENABLE_OVERLOADING)
data MonitorGetModelMethodInfo
instance (signature ~ (m (Maybe T.Text)), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetModelMethodInfo a signature where
overloadedMethod = monitorGetModel
instance O.OverloadedMethodInfo MonitorGetModelMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetModel",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetModel"
})
#endif
foreign import ccall "gdk_monitor_get_refresh_rate" gdk_monitor_get_refresh_rate ::
Ptr Monitor ->
IO Int32
monitorGetRefreshRate ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Int32
monitorGetRefreshRate :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Int32
monitorGetRefreshRate a
monitor = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Int32
result <- Ptr Monitor -> IO Int32
gdk_monitor_get_refresh_rate Ptr Monitor
monitor'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Int32 -> IO Int32
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Int32
result
#if defined(ENABLE_OVERLOADING)
data MonitorGetRefreshRateMethodInfo
instance (signature ~ (m Int32), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetRefreshRateMethodInfo a signature where
overloadedMethod = monitorGetRefreshRate
instance O.OverloadedMethodInfo MonitorGetRefreshRateMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetRefreshRate",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetRefreshRate"
})
#endif
foreign import ccall "gdk_monitor_get_scale_factor" gdk_monitor_get_scale_factor ::
Ptr Monitor ->
IO Int32
monitorGetScaleFactor ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Int32
monitorGetScaleFactor :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Int32
monitorGetScaleFactor a
monitor = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Int32
result <- Ptr Monitor -> IO Int32
gdk_monitor_get_scale_factor Ptr Monitor
monitor'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Int32 -> IO Int32
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Int32
result
#if defined(ENABLE_OVERLOADING)
data MonitorGetScaleFactorMethodInfo
instance (signature ~ (m Int32), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetScaleFactorMethodInfo a signature where
overloadedMethod = monitorGetScaleFactor
instance O.OverloadedMethodInfo MonitorGetScaleFactorMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetScaleFactor",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetScaleFactor"
})
#endif
foreign import ccall "gdk_monitor_get_subpixel_layout" gdk_monitor_get_subpixel_layout ::
Ptr Monitor ->
IO CUInt
monitorGetSubpixelLayout ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Gdk.Enums.SubpixelLayout
monitorGetSubpixelLayout :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m SubpixelLayout
monitorGetSubpixelLayout a
monitor = IO SubpixelLayout -> m SubpixelLayout
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SubpixelLayout -> m SubpixelLayout)
-> IO SubpixelLayout -> m SubpixelLayout
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
CUInt
result <- Ptr Monitor -> IO CUInt
gdk_monitor_get_subpixel_layout Ptr Monitor
monitor'
let result' :: SubpixelLayout
result' = (Int -> SubpixelLayout
forall a. Enum a => Int -> a
toEnum (Int -> SubpixelLayout)
-> (CUInt -> Int) -> CUInt -> SubpixelLayout
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CUInt -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral) CUInt
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
SubpixelLayout -> IO SubpixelLayout
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return SubpixelLayout
result'
#if defined(ENABLE_OVERLOADING)
data MonitorGetSubpixelLayoutMethodInfo
instance (signature ~ (m Gdk.Enums.SubpixelLayout), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetSubpixelLayoutMethodInfo a signature where
overloadedMethod = monitorGetSubpixelLayout
instance O.OverloadedMethodInfo MonitorGetSubpixelLayoutMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetSubpixelLayout",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetSubpixelLayout"
})
#endif
foreign import ccall "gdk_monitor_get_width_mm" gdk_monitor_get_width_mm ::
Ptr Monitor ->
IO Int32
monitorGetWidthMm ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Int32
monitorGetWidthMm :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Int32
monitorGetWidthMm a
monitor = IO Int32 -> m Int32
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Int32 -> m Int32) -> IO Int32 -> m Int32
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Int32
result <- Ptr Monitor -> IO Int32
gdk_monitor_get_width_mm Ptr Monitor
monitor'
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Int32 -> IO Int32
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Int32
result
#if defined(ENABLE_OVERLOADING)
data MonitorGetWidthMmMethodInfo
instance (signature ~ (m Int32), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetWidthMmMethodInfo a signature where
overloadedMethod = monitorGetWidthMm
instance O.OverloadedMethodInfo MonitorGetWidthMmMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetWidthMm",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetWidthMm"
})
#endif
foreign import ccall "gdk_monitor_get_workarea" gdk_monitor_get_workarea ::
Ptr Monitor ->
Ptr Gdk.Rectangle.Rectangle ->
IO ()
monitorGetWorkarea ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m (Gdk.Rectangle.Rectangle)
monitorGetWorkarea :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Rectangle
monitorGetWorkarea a
monitor = IO Rectangle -> m Rectangle
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Rectangle -> m Rectangle) -> IO Rectangle -> m Rectangle
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
Ptr Rectangle
workarea <- Int -> IO (Ptr Rectangle)
forall a. GBoxed a => Int -> IO (Ptr a)
SP.callocBoxedBytes Int
16 :: IO (Ptr Gdk.Rectangle.Rectangle)
Ptr Monitor -> Ptr Rectangle -> IO ()
gdk_monitor_get_workarea Ptr Monitor
monitor' Ptr Rectangle
workarea
Rectangle
workarea' <- ((ManagedPtr Rectangle -> Rectangle)
-> Ptr Rectangle -> IO Rectangle
forall a.
(HasCallStack, GBoxed a) =>
(ManagedPtr a -> a) -> Ptr a -> IO a
wrapBoxed ManagedPtr Rectangle -> Rectangle
Gdk.Rectangle.Rectangle) Ptr Rectangle
workarea
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Rectangle -> IO Rectangle
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Rectangle
workarea'
#if defined(ENABLE_OVERLOADING)
data MonitorGetWorkareaMethodInfo
instance (signature ~ (m (Gdk.Rectangle.Rectangle)), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorGetWorkareaMethodInfo a signature where
overloadedMethod = monitorGetWorkarea
instance O.OverloadedMethodInfo MonitorGetWorkareaMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorGetWorkarea",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorGetWorkarea"
})
#endif
foreign import ccall "gdk_monitor_is_primary" gdk_monitor_is_primary ::
Ptr Monitor ->
IO CInt
monitorIsPrimary ::
(B.CallStack.HasCallStack, MonadIO m, IsMonitor a) =>
a
-> m Bool
monitorIsPrimary :: forall (m :: * -> *) a.
(HasCallStack, MonadIO m, IsMonitor a) =>
a -> m Bool
monitorIsPrimary a
monitor = IO Bool -> m Bool
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO Bool -> m Bool) -> IO Bool -> m Bool
forall a b. (a -> b) -> a -> b
$ do
Ptr Monitor
monitor' <- a -> IO (Ptr Monitor)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
monitor
CInt
result <- Ptr Monitor -> IO CInt
gdk_monitor_is_primary Ptr Monitor
monitor'
let result' :: Bool
result' = (CInt -> CInt -> Bool
forall a. Eq a => a -> a -> Bool
/= CInt
0) CInt
result
a -> IO ()
forall a. ManagedPtrNewtype a => a -> IO ()
touchManagedPtr a
monitor
Bool -> IO Bool
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Bool
result'
#if defined(ENABLE_OVERLOADING)
data MonitorIsPrimaryMethodInfo
instance (signature ~ (m Bool), MonadIO m, IsMonitor a) => O.OverloadedMethod MonitorIsPrimaryMethodInfo a signature where
overloadedMethod = monitorIsPrimary
instance O.OverloadedMethodInfo MonitorIsPrimaryMethodInfo a where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gdk.Objects.Monitor.monitorIsPrimary",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gdk-3.0.29/docs/GI-Gdk-Objects-Monitor.html#v:monitorIsPrimary"
})
#endif