{-# LANGUAGE TypeApplications #-}


-- | Copyright  : Will Thompson and Iñaki García Etxebarria
-- License    : LGPL-2.1
-- Maintainer : Iñaki García Etxebarria
-- 
-- Class structure for t'GI.Gtk.Structs.MountOperationHandlerProxy_.MountOperationHandlerProxy_'.

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

module GI.Gtk.Structs.MountOperationHandlerProxyClass_
    ( 

-- * Exported types
    MountOperationHandlerProxyClass_(..)    ,
    newZeroMountOperationHandlerProxyClass_ ,


 -- * Methods

#if defined(ENABLE_OVERLOADING)
    ResolveMountOperationHandlerProxyClass_Method,
#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.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


-- | Memory-managed wrapper type.
newtype MountOperationHandlerProxyClass_ = MountOperationHandlerProxyClass_ (SP.ManagedPtr MountOperationHandlerProxyClass_)
    deriving (MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_ -> Bool
(MountOperationHandlerProxyClass_
 -> MountOperationHandlerProxyClass_ -> Bool)
-> (MountOperationHandlerProxyClass_
    -> MountOperationHandlerProxyClass_ -> Bool)
-> Eq MountOperationHandlerProxyClass_
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_ -> Bool
== :: MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_ -> Bool
$c/= :: MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_ -> Bool
/= :: MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_ -> Bool
Eq)

instance SP.ManagedPtrNewtype MountOperationHandlerProxyClass_ where
    toManagedPtr :: MountOperationHandlerProxyClass_
-> ManagedPtr MountOperationHandlerProxyClass_
toManagedPtr (MountOperationHandlerProxyClass_ ManagedPtr MountOperationHandlerProxyClass_
p) = ManagedPtr MountOperationHandlerProxyClass_
p

instance BoxedPtr MountOperationHandlerProxyClass_ where
    boxedPtrCopy :: MountOperationHandlerProxyClass_
-> IO MountOperationHandlerProxyClass_
boxedPtrCopy = \MountOperationHandlerProxyClass_
p -> MountOperationHandlerProxyClass_
-> (Ptr MountOperationHandlerProxyClass_
    -> IO MountOperationHandlerProxyClass_)
-> IO MountOperationHandlerProxyClass_
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr MountOperationHandlerProxyClass_
p (Int
-> Ptr MountOperationHandlerProxyClass_
-> IO (Ptr MountOperationHandlerProxyClass_)
forall a. (HasCallStack, CallocPtr a) => Int -> Ptr a -> IO (Ptr a)
copyBytes Int
408 (Ptr MountOperationHandlerProxyClass_
 -> IO (Ptr MountOperationHandlerProxyClass_))
-> (Ptr MountOperationHandlerProxyClass_
    -> IO MountOperationHandlerProxyClass_)
-> Ptr MountOperationHandlerProxyClass_
-> IO MountOperationHandlerProxyClass_
forall (m :: * -> *) a b c.
Monad m =>
(a -> m b) -> (b -> m c) -> a -> m c
>=> (ManagedPtr MountOperationHandlerProxyClass_
 -> MountOperationHandlerProxyClass_)
-> Ptr MountOperationHandlerProxyClass_
-> IO MountOperationHandlerProxyClass_
forall a.
(HasCallStack, BoxedPtr a) =>
(ManagedPtr a -> a) -> Ptr a -> IO a
B.ManagedPtr.wrapPtr ManagedPtr MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_
MountOperationHandlerProxyClass_)
    boxedPtrFree :: MountOperationHandlerProxyClass_ -> IO ()
boxedPtrFree = \MountOperationHandlerProxyClass_
x -> MountOperationHandlerProxyClass_
-> (Ptr MountOperationHandlerProxyClass_ -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
SP.withManagedPtr MountOperationHandlerProxyClass_
x Ptr MountOperationHandlerProxyClass_ -> IO ()
forall a. Ptr a -> IO ()
SP.freeMem
instance CallocPtr MountOperationHandlerProxyClass_ where
    boxedPtrCalloc :: IO (Ptr MountOperationHandlerProxyClass_)
boxedPtrCalloc = Int -> IO (Ptr MountOperationHandlerProxyClass_)
forall a. Int -> IO (Ptr a)
callocBytes Int
408


-- | Construct a `MountOperationHandlerProxyClass_` struct initialized to zero.
newZeroMountOperationHandlerProxyClass_ :: MonadIO m => m MountOperationHandlerProxyClass_
newZeroMountOperationHandlerProxyClass_ :: forall (m :: * -> *).
MonadIO m =>
m MountOperationHandlerProxyClass_
newZeroMountOperationHandlerProxyClass_ = IO MountOperationHandlerProxyClass_
-> m MountOperationHandlerProxyClass_
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO MountOperationHandlerProxyClass_
 -> m MountOperationHandlerProxyClass_)
-> IO MountOperationHandlerProxyClass_
-> m MountOperationHandlerProxyClass_
forall a b. (a -> b) -> a -> b
$ IO (Ptr MountOperationHandlerProxyClass_)
forall a. CallocPtr a => IO (Ptr a)
boxedPtrCalloc IO (Ptr MountOperationHandlerProxyClass_)
-> (Ptr MountOperationHandlerProxyClass_
    -> IO MountOperationHandlerProxyClass_)
-> IO MountOperationHandlerProxyClass_
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= (ManagedPtr MountOperationHandlerProxyClass_
 -> MountOperationHandlerProxyClass_)
-> Ptr MountOperationHandlerProxyClass_
-> IO MountOperationHandlerProxyClass_
forall a.
(HasCallStack, BoxedPtr a) =>
(ManagedPtr a -> a) -> Ptr a -> IO a
wrapPtr ManagedPtr MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_
MountOperationHandlerProxyClass_

instance tag ~ 'AttrSet => Constructible MountOperationHandlerProxyClass_ tag where
    new :: forall (m :: * -> *).
MonadIO m =>
(ManagedPtr MountOperationHandlerProxyClass_
 -> MountOperationHandlerProxyClass_)
-> [AttrOp MountOperationHandlerProxyClass_ tag]
-> m MountOperationHandlerProxyClass_
new ManagedPtr MountOperationHandlerProxyClass_
-> MountOperationHandlerProxyClass_
_ [AttrOp MountOperationHandlerProxyClass_ tag]
attrs = do
        MountOperationHandlerProxyClass_
o <- m MountOperationHandlerProxyClass_
forall (m :: * -> *).
MonadIO m =>
m MountOperationHandlerProxyClass_
newZeroMountOperationHandlerProxyClass_
        MountOperationHandlerProxyClass_
-> [AttrOp MountOperationHandlerProxyClass_ 'AttrSet] -> m ()
forall o (m :: * -> *).
MonadIO m =>
o -> [AttrOp o 'AttrSet] -> m ()
GI.Attributes.set MountOperationHandlerProxyClass_
o [AttrOp MountOperationHandlerProxyClass_ tag]
[AttrOp MountOperationHandlerProxyClass_ 'AttrSet]
attrs
        MountOperationHandlerProxyClass_
-> m MountOperationHandlerProxyClass_
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return MountOperationHandlerProxyClass_
o


-- XXX Skipped attribute for "MountOperationHandlerProxyClass_:parent_class"
-- Not implemented: Field type is an unsupported struct type

#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList MountOperationHandlerProxyClass_
type instance O.AttributeList MountOperationHandlerProxyClass_ = MountOperationHandlerProxyClass_AttributeList
type MountOperationHandlerProxyClass_AttributeList = ('[ ] :: [(Symbol, DK.Type)])
#endif

#if defined(ENABLE_OVERLOADING)
type family ResolveMountOperationHandlerProxyClass_Method (t :: Symbol) (o :: DK.Type) :: DK.Type where
    ResolveMountOperationHandlerProxyClass_Method l o = O.MethodResolutionFailed l o

instance (info ~ ResolveMountOperationHandlerProxyClass_Method t MountOperationHandlerProxyClass_, O.OverloadedMethod info MountOperationHandlerProxyClass_ p) => OL.IsLabel t (MountOperationHandlerProxyClass_ -> 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 ~ ResolveMountOperationHandlerProxyClass_Method t MountOperationHandlerProxyClass_, O.OverloadedMethod info MountOperationHandlerProxyClass_ p, R.HasField t MountOperationHandlerProxyClass_ p) => R.HasField t MountOperationHandlerProxyClass_ p where
    getField = O.overloadedMethod @info

#endif

instance (info ~ ResolveMountOperationHandlerProxyClass_Method t MountOperationHandlerProxyClass_, O.OverloadedMethodInfo info MountOperationHandlerProxyClass_) => OL.IsLabel t (O.MethodProxy info MountOperationHandlerProxyClass_) where
#if MIN_VERSION_base(4,10,0)
    fromLabel = O.MethodProxy
#else
    fromLabel _ = O.MethodProxy
#endif

#endif