{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gtk.Objects.ConstraintLayoutChild
(
ConstraintLayoutChild(..) ,
IsConstraintLayoutChild ,
toConstraintLayoutChild ,
#if defined(ENABLE_OVERLOADING)
ResolveConstraintLayoutChildMethod ,
#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 qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gtk.Objects.LayoutChild as Gtk.LayoutChild
newtype ConstraintLayoutChild = ConstraintLayoutChild (SP.ManagedPtr ConstraintLayoutChild)
deriving (ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
(ConstraintLayoutChild -> ConstraintLayoutChild -> Bool)
-> (ConstraintLayoutChild -> ConstraintLayoutChild -> Bool)
-> Eq ConstraintLayoutChild
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
$c/= :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
== :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
$c== :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
Eq)
instance SP.ManagedPtrNewtype ConstraintLayoutChild where
toManagedPtr :: ConstraintLayoutChild -> ManagedPtr ConstraintLayoutChild
toManagedPtr (ConstraintLayoutChild ManagedPtr ConstraintLayoutChild
p) = ManagedPtr ConstraintLayoutChild
p
foreign import ccall "gtk_constraint_layout_child_get_type"
c_gtk_constraint_layout_child_get_type :: IO B.Types.GType
instance B.Types.TypedObject ConstraintLayoutChild where
glibType :: IO GType
glibType = IO GType
c_gtk_constraint_layout_child_get_type
instance B.Types.GObject ConstraintLayoutChild
class (SP.GObject o, O.IsDescendantOf ConstraintLayoutChild o) => IsConstraintLayoutChild o
instance (SP.GObject o, O.IsDescendantOf ConstraintLayoutChild o) => IsConstraintLayoutChild o
instance O.HasParentTypes ConstraintLayoutChild
type instance O.ParentTypes ConstraintLayoutChild = '[Gtk.LayoutChild.LayoutChild, GObject.Object.Object]
toConstraintLayoutChild :: (MIO.MonadIO m, IsConstraintLayoutChild o) => o -> m ConstraintLayoutChild
toConstraintLayoutChild :: forall (m :: * -> *) o.
(MonadIO m, IsConstraintLayoutChild o) =>
o -> m ConstraintLayoutChild
toConstraintLayoutChild = IO ConstraintLayoutChild -> m ConstraintLayoutChild
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO ConstraintLayoutChild -> m ConstraintLayoutChild)
-> (o -> IO ConstraintLayoutChild) -> o -> m ConstraintLayoutChild
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr ConstraintLayoutChild -> ConstraintLayoutChild)
-> o -> IO ConstraintLayoutChild
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr ConstraintLayoutChild -> ConstraintLayoutChild
ConstraintLayoutChild
instance B.GValue.IsGValue (Maybe ConstraintLayoutChild) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_gtk_constraint_layout_child_get_type
gvalueSet_ :: Ptr GValue -> Maybe ConstraintLayoutChild -> IO ()
gvalueSet_ Ptr GValue
gv Maybe ConstraintLayoutChild
P.Nothing = Ptr GValue -> Ptr ConstraintLayoutChild -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr ConstraintLayoutChild
forall a. Ptr a
FP.nullPtr :: FP.Ptr ConstraintLayoutChild)
gvalueSet_ Ptr GValue
gv (P.Just ConstraintLayoutChild
obj) = ConstraintLayoutChild
-> (Ptr ConstraintLayoutChild -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr ConstraintLayoutChild
obj (Ptr GValue -> Ptr ConstraintLayoutChild -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe ConstraintLayoutChild)
gvalueGet_ Ptr GValue
gv = do
Ptr ConstraintLayoutChild
ptr <- Ptr GValue -> IO (Ptr ConstraintLayoutChild)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr ConstraintLayoutChild)
if Ptr ConstraintLayoutChild
ptr Ptr ConstraintLayoutChild -> Ptr ConstraintLayoutChild -> Bool
forall a. Eq a => a -> a -> Bool
/= Ptr ConstraintLayoutChild
forall a. Ptr a
FP.nullPtr
then ConstraintLayoutChild -> Maybe ConstraintLayoutChild
forall a. a -> Maybe a
P.Just (ConstraintLayoutChild -> Maybe ConstraintLayoutChild)
-> IO ConstraintLayoutChild -> IO (Maybe ConstraintLayoutChild)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ManagedPtr ConstraintLayoutChild -> ConstraintLayoutChild)
-> Ptr ConstraintLayoutChild -> IO ConstraintLayoutChild
forall a b.
(HasCallStack, GObject a, GObject b) =>
(ManagedPtr a -> a) -> Ptr b -> IO a
B.ManagedPtr.newObject ManagedPtr ConstraintLayoutChild -> ConstraintLayoutChild
ConstraintLayoutChild Ptr ConstraintLayoutChild
ptr
else Maybe ConstraintLayoutChild -> IO (Maybe ConstraintLayoutChild)
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe ConstraintLayoutChild
forall a. Maybe a
P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveConstraintLayoutChildMethod (t :: Symbol) (o :: *) :: * where
ResolveConstraintLayoutChildMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveConstraintLayoutChildMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveConstraintLayoutChildMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveConstraintLayoutChildMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveConstraintLayoutChildMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveConstraintLayoutChildMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveConstraintLayoutChildMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveConstraintLayoutChildMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveConstraintLayoutChildMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveConstraintLayoutChildMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveConstraintLayoutChildMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveConstraintLayoutChildMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveConstraintLayoutChildMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveConstraintLayoutChildMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveConstraintLayoutChildMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveConstraintLayoutChildMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveConstraintLayoutChildMethod "getChildWidget" o = Gtk.LayoutChild.LayoutChildGetChildWidgetMethodInfo
ResolveConstraintLayoutChildMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveConstraintLayoutChildMethod "getLayoutManager" o = Gtk.LayoutChild.LayoutChildGetLayoutManagerMethodInfo
ResolveConstraintLayoutChildMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveConstraintLayoutChildMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveConstraintLayoutChildMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveConstraintLayoutChildMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveConstraintLayoutChildMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveConstraintLayoutChildMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveConstraintLayoutChildMethod t ConstraintLayoutChild, O.OverloadedMethod info ConstraintLayoutChild p) => OL.IsLabel t (ConstraintLayoutChild -> 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 ~ ResolveConstraintLayoutChildMethod t ConstraintLayoutChild, O.OverloadedMethod info ConstraintLayoutChild p, R.HasField t ConstraintLayoutChild p) => R.HasField t ConstraintLayoutChild p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveConstraintLayoutChildMethod t ConstraintLayoutChild, O.OverloadedMethodInfo info ConstraintLayoutChild) => OL.IsLabel t (O.MethodProxy info ConstraintLayoutChild) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList ConstraintLayoutChild
type instance O.AttributeList ConstraintLayoutChild = ConstraintLayoutChildAttributeList
type ConstraintLayoutChildAttributeList = ('[ '("childWidget", Gtk.LayoutChild.LayoutChildChildWidgetPropertyInfo), '("layoutManager", Gtk.LayoutChild.LayoutChildLayoutManagerPropertyInfo)] :: [(Symbol, *)])
#endif
#if defined(ENABLE_OVERLOADING)
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList ConstraintLayoutChild = ConstraintLayoutChildSignalList
type ConstraintLayoutChildSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, *)])
#endif