{-# 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.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.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
$c== :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
== :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
$c/= :: ConstraintLayoutChild -> ConstraintLayoutChild -> Bool
/= :: 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 a. IO a -> m a
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 a. a -> IO a
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