{-# LANGUAGE TypeApplications #-}
#if !defined(__HADDOCK_VERSION__)
#define ENABLE_OVERLOADING
#endif
module GI.Gsk.Structs.ComponentTransfer
(
ComponentTransfer(..) ,
#if defined(ENABLE_OVERLOADING)
ResolveComponentTransferMethod ,
#endif
#if defined(ENABLE_OVERLOADING)
ComponentTransferCopyMethodInfo ,
#endif
componentTransferCopy ,
componentTransferEqual ,
#if defined(ENABLE_OVERLOADING)
ComponentTransferFreeMethodInfo ,
#endif
componentTransferFree ,
componentTransferNewDiscrete ,
componentTransferNewGamma ,
componentTransferNewIdentity ,
componentTransferNewLevels ,
componentTransferNewLinear ,
componentTransferNewTable ,
) 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)
#else
#endif
newtype ComponentTransfer = ComponentTransfer (SP.ManagedPtr ComponentTransfer)
deriving (ComponentTransfer -> ComponentTransfer -> Bool
(ComponentTransfer -> ComponentTransfer -> Bool)
-> (ComponentTransfer -> ComponentTransfer -> Bool)
-> Eq ComponentTransfer
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ComponentTransfer -> ComponentTransfer -> Bool
== :: ComponentTransfer -> ComponentTransfer -> Bool
$c/= :: ComponentTransfer -> ComponentTransfer -> Bool
/= :: ComponentTransfer -> ComponentTransfer -> Bool
Eq)
instance SP.ManagedPtrNewtype ComponentTransfer where
toManagedPtr :: ComponentTransfer -> ManagedPtr ComponentTransfer
toManagedPtr (ComponentTransfer ManagedPtr ComponentTransfer
p) = ManagedPtr ComponentTransfer
p
foreign import ccall "gsk_component_transfer_get_type" c_gsk_component_transfer_get_type ::
IO GType
type instance O.ParentTypes ComponentTransfer = '[]
instance O.HasParentTypes ComponentTransfer
instance B.Types.TypedObject ComponentTransfer where
glibType :: IO GType
glibType = IO GType
c_gsk_component_transfer_get_type
instance B.Types.GBoxed ComponentTransfer
instance B.GValue.IsGValue (Maybe ComponentTransfer) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_gsk_component_transfer_get_type
gvalueSet_ :: Ptr GValue -> Maybe ComponentTransfer -> IO ()
gvalueSet_ Ptr GValue
gv Maybe ComponentTransfer
P.Nothing = Ptr GValue -> Ptr ComponentTransfer -> IO ()
forall a. Ptr GValue -> Ptr a -> IO ()
B.GValue.set_boxed Ptr GValue
gv (Ptr ComponentTransfer
forall a. Ptr a
FP.nullPtr :: FP.Ptr ComponentTransfer)
gvalueSet_ Ptr GValue
gv (P.Just ComponentTransfer
obj) = ComponentTransfer -> (Ptr ComponentTransfer -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr ComponentTransfer
obj (Ptr GValue -> Ptr ComponentTransfer -> IO ()
forall a. Ptr GValue -> Ptr a -> IO ()
B.GValue.set_boxed Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe ComponentTransfer)
gvalueGet_ Ptr GValue
gv = do
ptr <- Ptr GValue -> IO (Ptr ComponentTransfer)
forall b. Ptr GValue -> IO (Ptr b)
B.GValue.get_boxed Ptr GValue
gv :: IO (Ptr ComponentTransfer)
if ptr /= FP.nullPtr
then P.Just <$> B.ManagedPtr.newBoxed ComponentTransfer ptr
else return P.Nothing
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList ComponentTransfer
type instance O.AttributeList ComponentTransfer = ComponentTransferAttributeList
type ComponentTransferAttributeList = ('[ ] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "gsk_component_transfer_new_discrete" gsk_component_transfer_new_discrete ::
Word32 ->
Ptr CFloat ->
IO (Ptr ComponentTransfer)
componentTransferNewDiscrete ::
(B.CallStack.HasCallStack, MonadIO m) =>
[Float]
-> m ComponentTransfer
componentTransferNewDiscrete :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
[Float] -> m ComponentTransfer
componentTransferNewDiscrete [Float]
values = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
let n :: Word32
n = Int -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Int -> Word32) -> Int -> Word32
forall a b. (a -> b) -> a -> b
$ [Float] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
P.length [Float]
values
values' <- ((Float -> CFloat) -> [Float] -> IO (Ptr CFloat)
forall a b. Storable b => (a -> b) -> [a] -> IO (Ptr b)
packMapStorableArray Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac) [Float]
values
result <- gsk_component_transfer_new_discrete n values'
checkUnexpectedReturnNULL "componentTransferNewDiscrete" result
result' <- (wrapBoxed ComponentTransfer) result
freeMem values'
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_new_gamma" gsk_component_transfer_new_gamma ::
CFloat ->
CFloat ->
CFloat ->
IO (Ptr ComponentTransfer)
componentTransferNewGamma ::
(B.CallStack.HasCallStack, MonadIO m) =>
Float
-> Float
-> Float
-> m ComponentTransfer
componentTransferNewGamma :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
Float -> Float -> Float -> m ComponentTransfer
componentTransferNewGamma Float
amp Float
exp Float
ofs = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
let amp' :: CFloat
amp' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
amp
let exp' :: CFloat
exp' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
exp
let ofs' :: CFloat
ofs' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
ofs
result <- CFloat -> CFloat -> CFloat -> IO (Ptr ComponentTransfer)
gsk_component_transfer_new_gamma CFloat
amp' CFloat
exp' CFloat
ofs'
checkUnexpectedReturnNULL "componentTransferNewGamma" result
result' <- (wrapBoxed ComponentTransfer) result
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_new_identity" gsk_component_transfer_new_identity ::
IO (Ptr ComponentTransfer)
componentTransferNewIdentity ::
(B.CallStack.HasCallStack, MonadIO m) =>
m ComponentTransfer
componentTransferNewIdentity :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
m ComponentTransfer
componentTransferNewIdentity = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
result <- IO (Ptr ComponentTransfer)
gsk_component_transfer_new_identity
checkUnexpectedReturnNULL "componentTransferNewIdentity" result
result' <- (wrapBoxed ComponentTransfer) result
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_new_levels" gsk_component_transfer_new_levels ::
CFloat ->
IO (Ptr ComponentTransfer)
componentTransferNewLevels ::
(B.CallStack.HasCallStack, MonadIO m) =>
Float
-> m ComponentTransfer
componentTransferNewLevels :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
Float -> m ComponentTransfer
componentTransferNewLevels Float
n = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
let n' :: CFloat
n' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
n
result <- CFloat -> IO (Ptr ComponentTransfer)
gsk_component_transfer_new_levels CFloat
n'
checkUnexpectedReturnNULL "componentTransferNewLevels" result
result' <- (wrapBoxed ComponentTransfer) result
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_new_linear" gsk_component_transfer_new_linear ::
CFloat ->
CFloat ->
IO (Ptr ComponentTransfer)
componentTransferNewLinear ::
(B.CallStack.HasCallStack, MonadIO m) =>
Float
-> Float
-> m ComponentTransfer
componentTransferNewLinear :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
Float -> Float -> m ComponentTransfer
componentTransferNewLinear Float
m Float
b = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
let m' :: CFloat
m' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
m
let b' :: CFloat
b' = Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac Float
b
result <- CFloat -> CFloat -> IO (Ptr ComponentTransfer)
gsk_component_transfer_new_linear CFloat
m' CFloat
b'
checkUnexpectedReturnNULL "componentTransferNewLinear" result
result' <- (wrapBoxed ComponentTransfer) result
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_new_table" gsk_component_transfer_new_table ::
Word32 ->
Ptr CFloat ->
IO (Ptr ComponentTransfer)
componentTransferNewTable ::
(B.CallStack.HasCallStack, MonadIO m) =>
[Float]
-> m ComponentTransfer
componentTransferNewTable :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
[Float] -> m ComponentTransfer
componentTransferNewTable [Float]
values = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
let n :: Word32
n = Int -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Int -> Word32) -> Int -> Word32
forall a b. (a -> b) -> a -> b
$ [Float] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
P.length [Float]
values
values' <- ((Float -> CFloat) -> [Float] -> IO (Ptr CFloat)
forall a b. Storable b => (a -> b) -> [a] -> IO (Ptr b)
packMapStorableArray Float -> CFloat
forall a b. (Real a, Fractional b) => a -> b
realToFrac) [Float]
values
result <- gsk_component_transfer_new_table n values'
checkUnexpectedReturnNULL "componentTransferNewTable" result
result' <- (wrapBoxed ComponentTransfer) result
freeMem values'
return result'
#if defined(ENABLE_OVERLOADING)
#endif
foreign import ccall "gsk_component_transfer_copy" gsk_component_transfer_copy ::
Ptr ComponentTransfer ->
IO (Ptr ComponentTransfer)
componentTransferCopy ::
(B.CallStack.HasCallStack, MonadIO m) =>
ComponentTransfer
-> m ComponentTransfer
componentTransferCopy :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
ComponentTransfer -> m ComponentTransfer
componentTransferCopy ComponentTransfer
other = IO ComponentTransfer -> m ComponentTransfer
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ComponentTransfer -> m ComponentTransfer)
-> IO ComponentTransfer -> m ComponentTransfer
forall a b. (a -> b) -> a -> b
$ do
other' <- ComponentTransfer -> IO (Ptr ComponentTransfer)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr ComponentTransfer
other
result <- gsk_component_transfer_copy other'
checkUnexpectedReturnNULL "componentTransferCopy" result
result' <- (wrapBoxed ComponentTransfer) result
touchManagedPtr other
return result'
#if defined(ENABLE_OVERLOADING)
data ComponentTransferCopyMethodInfo
instance (signature ~ (m ComponentTransfer), MonadIO m) => O.OverloadedMethod ComponentTransferCopyMethodInfo ComponentTransfer signature where
overloadedMethod = componentTransferCopy
instance O.OverloadedMethodInfo ComponentTransferCopyMethodInfo ComponentTransfer where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gsk.Structs.ComponentTransfer.componentTransferCopy",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gsk-4.0.9/docs/GI-Gsk-Structs-ComponentTransfer.html#v:componentTransferCopy"
})
#endif
foreign import ccall "gsk_component_transfer_free" gsk_component_transfer_free ::
Ptr ComponentTransfer ->
IO ()
componentTransferFree ::
(B.CallStack.HasCallStack, MonadIO m) =>
ComponentTransfer
-> m ()
componentTransferFree :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
ComponentTransfer -> m ()
componentTransferFree ComponentTransfer
self = IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ do
self' <- ComponentTransfer -> IO (Ptr ComponentTransfer)
forall a. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr a)
unsafeManagedPtrGetPtr ComponentTransfer
self
gsk_component_transfer_free self'
touchManagedPtr self
return ()
#if defined(ENABLE_OVERLOADING)
data ComponentTransferFreeMethodInfo
instance (signature ~ (m ()), MonadIO m) => O.OverloadedMethod ComponentTransferFreeMethodInfo ComponentTransfer signature where
overloadedMethod = componentTransferFree
instance O.OverloadedMethodInfo ComponentTransferFreeMethodInfo ComponentTransfer where
overloadedMethodInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gsk.Structs.ComponentTransfer.componentTransferFree",
O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gsk-4.0.9/docs/GI-Gsk-Structs-ComponentTransfer.html#v:componentTransferFree"
})
#endif
foreign import ccall "gsk_component_transfer_equal" gsk_component_transfer_equal ::
Ptr () ->
Ptr () ->
IO CInt
componentTransferEqual ::
(B.CallStack.HasCallStack, MonadIO m) =>
Ptr ()
-> Ptr ()
-> m Bool
componentTransferEqual :: forall (m :: * -> *).
(HasCallStack, MonadIO m) =>
Ptr () -> Ptr () -> m Bool
componentTransferEqual Ptr ()
self Ptr ()
other = 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
result <- Ptr () -> Ptr () -> IO CInt
gsk_component_transfer_equal Ptr ()
self Ptr ()
other
let result' = (CInt -> CInt -> Bool
forall a. Eq a => a -> a -> Bool
/= CInt
0) CInt
result
return result'
#if defined(ENABLE_OVERLOADING)
#endif
#if defined(ENABLE_OVERLOADING)
type family ResolveComponentTransferMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveComponentTransferMethod "copy" o = ComponentTransferCopyMethodInfo
ResolveComponentTransferMethod "free" o = ComponentTransferFreeMethodInfo
ResolveComponentTransferMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveComponentTransferMethod t ComponentTransfer, O.OverloadedMethod info ComponentTransfer p) => OL.IsLabel t (ComponentTransfer -> 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 ~ ResolveComponentTransferMethod t ComponentTransfer, O.OverloadedMethod info ComponentTransfer p, R.HasField t ComponentTransfer p) => R.HasField t ComponentTransfer p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveComponentTransferMethod t ComponentTransfer, O.OverloadedMethodInfo info ComponentTransfer) => OL.IsLabel t (O.MethodProxy info ComponentTransfer) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif