{-# language CPP #-}
module Vulkan.Extensions.VK_EXT_host_image_copy ( copyMemoryToImageEXT
, copyImageToMemoryEXT
, copyImageToImageEXT
, transitionImageLayoutEXT
, getImageSubresourceLayout2EXT
, PhysicalDeviceHostImageCopyFeaturesEXT(..)
, PhysicalDeviceHostImageCopyPropertiesEXT(..)
, MemoryToImageCopyEXT(..)
, ImageToMemoryCopyEXT(..)
, CopyMemoryToImageInfoEXT(..)
, CopyImageToMemoryInfoEXT(..)
, CopyImageToImageInfoEXT(..)
, HostImageLayoutTransitionInfoEXT(..)
, SubresourceHostMemcpySizeEXT(..)
, HostImageCopyDevicePerformanceQueryEXT(..)
, HostImageCopyFlagsEXT
, HostImageCopyFlagBitsEXT( HOST_IMAGE_COPY_MEMCPY_EXT
, ..
)
, ImageSubresource2EXT
, SubresourceLayout2EXT
, EXT_HOST_IMAGE_COPY_SPEC_VERSION
, pattern EXT_HOST_IMAGE_COPY_SPEC_VERSION
, EXT_HOST_IMAGE_COPY_EXTENSION_NAME
, pattern EXT_HOST_IMAGE_COPY_EXTENSION_NAME
, ImageSubresource2KHR(..)
, SubresourceLayout2KHR(..)
, getImageSubresourceLayout2KHR
) where
import Data.Bits (Bits)
import Data.Bits (FiniteBits)
import Vulkan.CStruct.Utils (FixedArray)
import Vulkan.Internal.Utils (enumReadPrec)
import Vulkan.Internal.Utils (enumShowsPrec)
import Vulkan.Internal.Utils (traceAroundEvent)
import Control.Monad (unless)
import Control.Monad.IO.Class (liftIO)
import Foreign.Marshal.Alloc (allocaBytes)
import GHC.Base (when)
import GHC.IO (throwIO)
import GHC.Ptr (nullFunPtr)
import Foreign.Ptr (nullPtr)
import Foreign.Ptr (plusPtr)
import GHC.Show (showString)
import Numeric (showHex)
import Control.Monad.Trans.Class (lift)
import Control.Monad.Trans.Cont (evalContT)
import Data.Vector (generateM)
import qualified Data.Vector (imapM_)
import qualified Data.Vector (length)
import Vulkan.CStruct (FromCStruct)
import Vulkan.CStruct (FromCStruct(..))
import Vulkan.CStruct (ToCStruct)
import Vulkan.CStruct (ToCStruct(..))
import Vulkan.Zero (Zero)
import Vulkan.Zero (Zero(..))
import Control.Monad.IO.Class (MonadIO)
import Data.String (IsString)
import Data.Typeable (Typeable)
import Foreign.Storable (Storable)
import Foreign.Storable (Storable(peek))
import Foreign.Storable (Storable(poke))
import qualified Foreign.Storable (Storable(..))
import GHC.Generics (Generic)
import GHC.IO.Exception (IOErrorType(..))
import GHC.IO.Exception (IOException(..))
import Foreign.Ptr (FunPtr)
import Foreign.Ptr (Ptr)
import GHC.Read (Read(readPrec))
import GHC.Show (Show(showsPrec))
import Data.Word (Word32)
import Data.Word (Word8)
import Data.ByteString (ByteString)
import Data.Kind (Type)
import Control.Monad.Trans.Cont (ContT(..))
import Data.Vector (Vector)
import Vulkan.CStruct.Utils (advancePtrBytes)
import Vulkan.Core10.FundamentalTypes (bool32ToBool)
import Vulkan.Core10.FundamentalTypes (boolToBool32)
import Vulkan.Extensions.VK_KHR_maintenance5 (getImageSubresourceLayout2KHR)
import Vulkan.CStruct.Utils (peekByteStringFromSizedVectorPtr)
import Vulkan.CStruct.Utils (pokeFixedLengthByteString)
import Vulkan.NamedType ((:::))
import Vulkan.Core10.FundamentalTypes (Bool32)
import Vulkan.Core10.Handles (Device)
import Vulkan.Core10.Handles (Device(..))
import Vulkan.Core10.Handles (Device(Device))
import Vulkan.Dynamic (DeviceCmds(pVkCopyImageToImageEXT))
import Vulkan.Dynamic (DeviceCmds(pVkCopyImageToMemoryEXT))
import Vulkan.Dynamic (DeviceCmds(pVkCopyMemoryToImageEXT))
import Vulkan.Dynamic (DeviceCmds(pVkTransitionImageLayoutEXT))
import Vulkan.Core10.FundamentalTypes (DeviceSize)
import Vulkan.Core10.Handles (Device_T)
import Vulkan.Core10.FundamentalTypes (Extent3D)
import Vulkan.Core10.FundamentalTypes (Flags)
import Vulkan.Core10.Handles (Image)
import Vulkan.Core13.Promoted_From_VK_KHR_copy_commands2 (ImageCopy2)
import Vulkan.Core10.Enums.ImageLayout (ImageLayout)
import Vulkan.Extensions.VK_KHR_maintenance5 (ImageSubresource2KHR)
import Vulkan.Core10.CommandBufferBuilding (ImageSubresourceLayers)
import Vulkan.Core10.ImageView (ImageSubresourceRange)
import Vulkan.Core10.FundamentalTypes (Offset3D)
import Vulkan.Core10.Enums.Result (Result)
import Vulkan.Core10.Enums.Result (Result(..))
import Vulkan.Core10.Enums.StructureType (StructureType)
import Vulkan.Extensions.VK_KHR_maintenance5 (SubresourceLayout2KHR)
import Vulkan.Core10.APIConstants (UUID_SIZE)
import Vulkan.Exception (VulkanException(..))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_COPY_IMAGE_TO_IMAGE_INFO_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_COPY_IMAGE_TO_MEMORY_INFO_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_COPY_MEMORY_TO_IMAGE_INFO_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERY_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_HOST_IMAGE_LAYOUT_TRANSITION_INFO_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_IMAGE_TO_MEMORY_COPY_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_MEMORY_TO_IMAGE_COPY_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_FEATURES_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_PROPERTIES_EXT))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_SUBRESOURCE_HOST_MEMCPY_SIZE_EXT))
import Vulkan.Core10.Enums.Result (Result(SUCCESS))
import Vulkan.Extensions.VK_KHR_maintenance5 (getImageSubresourceLayout2KHR)
import Vulkan.Extensions.VK_KHR_maintenance5 (ImageSubresource2KHR(..))
import Vulkan.Extensions.VK_KHR_maintenance5 (SubresourceLayout2KHR(..))
foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
unsafe
#endif
"dynamic" mkVkCopyMemoryToImageEXT
:: FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result) -> Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result
copyMemoryToImageEXT :: forall io
. (MonadIO io)
=>
Device
->
CopyMemoryToImageInfoEXT
-> io ()
copyMemoryToImageEXT :: forall (io :: * -> *).
MonadIO io =>
Device -> CopyMemoryToImageInfoEXT -> io ()
copyMemoryToImageEXT Device
device CopyMemoryToImageInfoEXT
copyMemoryToImageInfo = IO () -> io ()
forall a. IO a -> io a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> io ())
-> (ContT () IO () -> IO ()) -> ContT () IO () -> io ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ContT () IO () -> IO ()
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT () IO () -> io ()) -> ContT () IO () -> io ()
forall a b. (a -> b) -> a -> b
$ do
let vkCopyMemoryToImageEXTPtr :: FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
vkCopyMemoryToImageEXTPtr = DeviceCmds
-> FunPtr
(Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
pVkCopyMemoryToImageEXT (case Device
device of Device{DeviceCmds
deviceCmds :: DeviceCmds
$sel:deviceCmds:Device :: Device -> DeviceCmds
deviceCmds} -> DeviceCmds
deviceCmds)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
vkCopyMemoryToImageEXTPtr FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
-> FunPtr
(Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
-> Bool
forall a. Eq a => a -> a -> Bool
/= FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
forall a. FunPtr a
nullFunPtr) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
IOException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (IOException -> IO ()) -> IOException -> IO ()
forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError Maybe Handle
forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkCopyMemoryToImageEXT is null" Maybe CInt
forall a. Maybe a
Nothing Maybe String
forall a. Maybe a
Nothing
let vkCopyMemoryToImageEXT' :: Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result
vkCopyMemoryToImageEXT' = FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
-> Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result
mkVkCopyMemoryToImageEXT FunPtr (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result)
vkCopyMemoryToImageEXTPtr
Ptr CopyMemoryToImageInfoEXT
pCopyMemoryToImageInfo <- ((Ptr CopyMemoryToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyMemoryToImageInfoEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr CopyMemoryToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyMemoryToImageInfoEXT))
-> ((Ptr CopyMemoryToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyMemoryToImageInfoEXT)
forall a b. (a -> b) -> a -> b
$ CopyMemoryToImageInfoEXT
-> (Ptr CopyMemoryToImageInfoEXT -> IO ()) -> IO ()
forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
forall b.
CopyMemoryToImageInfoEXT
-> (Ptr CopyMemoryToImageInfoEXT -> IO b) -> IO b
withCStruct (CopyMemoryToImageInfoEXT
copyMemoryToImageInfo)
Result
r <- IO Result -> ContT () IO Result
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO Result -> ContT () IO Result)
-> IO Result -> ContT () IO Result
forall a b. (a -> b) -> a -> b
$ String -> IO Result -> IO Result
forall a. String -> IO a -> IO a
traceAroundEvent String
"vkCopyMemoryToImageEXT" (Ptr Device_T -> Ptr CopyMemoryToImageInfoEXT -> IO Result
vkCopyMemoryToImageEXT'
(Device -> Ptr Device_T
deviceHandle (Device
device))
Ptr CopyMemoryToImageInfoEXT
pCopyMemoryToImageInfo)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r Result -> Result -> Bool
forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (VulkanException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
unsafe
#endif
"dynamic" mkVkCopyImageToMemoryEXT
:: FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result) -> Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result
copyImageToMemoryEXT :: forall io
. (MonadIO io)
=>
Device
->
CopyImageToMemoryInfoEXT
-> io ()
copyImageToMemoryEXT :: forall (io :: * -> *).
MonadIO io =>
Device -> CopyImageToMemoryInfoEXT -> io ()
copyImageToMemoryEXT Device
device CopyImageToMemoryInfoEXT
copyImageToMemoryInfo = IO () -> io ()
forall a. IO a -> io a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> io ())
-> (ContT () IO () -> IO ()) -> ContT () IO () -> io ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ContT () IO () -> IO ()
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT () IO () -> io ()) -> ContT () IO () -> io ()
forall a b. (a -> b) -> a -> b
$ do
let vkCopyImageToMemoryEXTPtr :: FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
vkCopyImageToMemoryEXTPtr = DeviceCmds
-> FunPtr
(Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
pVkCopyImageToMemoryEXT (case Device
device of Device{DeviceCmds
$sel:deviceCmds:Device :: Device -> DeviceCmds
deviceCmds :: DeviceCmds
deviceCmds} -> DeviceCmds
deviceCmds)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
vkCopyImageToMemoryEXTPtr FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
-> FunPtr
(Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
-> Bool
forall a. Eq a => a -> a -> Bool
/= FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
forall a. FunPtr a
nullFunPtr) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
IOException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (IOException -> IO ()) -> IOException -> IO ()
forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError Maybe Handle
forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkCopyImageToMemoryEXT is null" Maybe CInt
forall a. Maybe a
Nothing Maybe String
forall a. Maybe a
Nothing
let vkCopyImageToMemoryEXT' :: Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result
vkCopyImageToMemoryEXT' = FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
-> Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result
mkVkCopyImageToMemoryEXT FunPtr (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result)
vkCopyImageToMemoryEXTPtr
Ptr CopyImageToMemoryInfoEXT
pCopyImageToMemoryInfo <- ((Ptr CopyImageToMemoryInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToMemoryInfoEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr CopyImageToMemoryInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToMemoryInfoEXT))
-> ((Ptr CopyImageToMemoryInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToMemoryInfoEXT)
forall a b. (a -> b) -> a -> b
$ CopyImageToMemoryInfoEXT
-> (Ptr CopyImageToMemoryInfoEXT -> IO ()) -> IO ()
forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
forall b.
CopyImageToMemoryInfoEXT
-> (Ptr CopyImageToMemoryInfoEXT -> IO b) -> IO b
withCStruct (CopyImageToMemoryInfoEXT
copyImageToMemoryInfo)
Result
r <- IO Result -> ContT () IO Result
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO Result -> ContT () IO Result)
-> IO Result -> ContT () IO Result
forall a b. (a -> b) -> a -> b
$ String -> IO Result -> IO Result
forall a. String -> IO a -> IO a
traceAroundEvent String
"vkCopyImageToMemoryEXT" (Ptr Device_T -> Ptr CopyImageToMemoryInfoEXT -> IO Result
vkCopyImageToMemoryEXT'
(Device -> Ptr Device_T
deviceHandle (Device
device))
Ptr CopyImageToMemoryInfoEXT
pCopyImageToMemoryInfo)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r Result -> Result -> Bool
forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (VulkanException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
unsafe
#endif
"dynamic" mkVkCopyImageToImageEXT
:: FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result) -> Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result
copyImageToImageEXT :: forall io
. (MonadIO io)
=>
Device
->
CopyImageToImageInfoEXT
-> io ()
copyImageToImageEXT :: forall (io :: * -> *).
MonadIO io =>
Device -> CopyImageToImageInfoEXT -> io ()
copyImageToImageEXT Device
device CopyImageToImageInfoEXT
copyImageToImageInfo = IO () -> io ()
forall a. IO a -> io a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> io ())
-> (ContT () IO () -> IO ()) -> ContT () IO () -> io ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ContT () IO () -> IO ()
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT () IO () -> io ()) -> ContT () IO () -> io ()
forall a b. (a -> b) -> a -> b
$ do
let vkCopyImageToImageEXTPtr :: FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
vkCopyImageToImageEXTPtr = DeviceCmds
-> FunPtr
(Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
pVkCopyImageToImageEXT (case Device
device of Device{DeviceCmds
$sel:deviceCmds:Device :: Device -> DeviceCmds
deviceCmds :: DeviceCmds
deviceCmds} -> DeviceCmds
deviceCmds)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
vkCopyImageToImageEXTPtr FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
-> FunPtr
(Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
-> Bool
forall a. Eq a => a -> a -> Bool
/= FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
forall a. FunPtr a
nullFunPtr) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
IOException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (IOException -> IO ()) -> IOException -> IO ()
forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError Maybe Handle
forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkCopyImageToImageEXT is null" Maybe CInt
forall a. Maybe a
Nothing Maybe String
forall a. Maybe a
Nothing
let vkCopyImageToImageEXT' :: Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result
vkCopyImageToImageEXT' = FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
-> Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result
mkVkCopyImageToImageEXT FunPtr (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result)
vkCopyImageToImageEXTPtr
Ptr CopyImageToImageInfoEXT
pCopyImageToImageInfo <- ((Ptr CopyImageToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToImageInfoEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr CopyImageToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToImageInfoEXT))
-> ((Ptr CopyImageToImageInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr CopyImageToImageInfoEXT)
forall a b. (a -> b) -> a -> b
$ CopyImageToImageInfoEXT
-> (Ptr CopyImageToImageInfoEXT -> IO ()) -> IO ()
forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
forall b.
CopyImageToImageInfoEXT
-> (Ptr CopyImageToImageInfoEXT -> IO b) -> IO b
withCStruct (CopyImageToImageInfoEXT
copyImageToImageInfo)
Result
r <- IO Result -> ContT () IO Result
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO Result -> ContT () IO Result)
-> IO Result -> ContT () IO Result
forall a b. (a -> b) -> a -> b
$ String -> IO Result -> IO Result
forall a. String -> IO a -> IO a
traceAroundEvent String
"vkCopyImageToImageEXT" (Ptr Device_T -> Ptr CopyImageToImageInfoEXT -> IO Result
vkCopyImageToImageEXT'
(Device -> Ptr Device_T
deviceHandle (Device
device))
Ptr CopyImageToImageInfoEXT
pCopyImageToImageInfo)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r Result -> Result -> Bool
forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (VulkanException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
unsafe
#endif
"dynamic" mkVkTransitionImageLayoutEXT
:: FunPtr (Ptr Device_T -> Word32 -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result) -> Ptr Device_T -> Word32 -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result
transitionImageLayoutEXT :: forall io
. (MonadIO io)
=>
Device
->
("transitions" ::: Vector HostImageLayoutTransitionInfoEXT)
-> io ()
transitionImageLayoutEXT :: forall (io :: * -> *).
MonadIO io =>
Device
-> ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT)
-> io ()
transitionImageLayoutEXT Device
device "transitions" ::: Vector HostImageLayoutTransitionInfoEXT
transitions = IO () -> io ()
forall a. IO a -> io a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> io ())
-> (ContT () IO () -> IO ()) -> ContT () IO () -> io ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ContT () IO () -> IO ()
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT () IO () -> io ()) -> ContT () IO () -> io ()
forall a b. (a -> b) -> a -> b
$ do
let vkTransitionImageLayoutEXTPtr :: FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
vkTransitionImageLayoutEXTPtr = DeviceCmds
-> FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
pVkTransitionImageLayoutEXT (case Device
device of Device{DeviceCmds
$sel:deviceCmds:Device :: Device -> DeviceCmds
deviceCmds :: DeviceCmds
deviceCmds} -> DeviceCmds
deviceCmds)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
vkTransitionImageLayoutEXTPtr FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
-> FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
-> Bool
forall a. Eq a => a -> a -> Bool
/= FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
forall a. FunPtr a
nullFunPtr) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
IOException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (IOException -> IO ()) -> IOException -> IO ()
forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError Maybe Handle
forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkTransitionImageLayoutEXT is null" Maybe CInt
forall a. Maybe a
Nothing Maybe String
forall a. Maybe a
Nothing
let vkTransitionImageLayoutEXT' :: Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result
vkTransitionImageLayoutEXT' = FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
-> Ptr Device_T
-> Flags
-> Ptr HostImageLayoutTransitionInfoEXT
-> IO Result
mkVkTransitionImageLayoutEXT FunPtr
(Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result)
vkTransitionImageLayoutEXTPtr
Ptr HostImageLayoutTransitionInfoEXT
pPTransitions <- ((Ptr HostImageLayoutTransitionInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr HostImageLayoutTransitionInfoEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr HostImageLayoutTransitionInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr HostImageLayoutTransitionInfoEXT))
-> ((Ptr HostImageLayoutTransitionInfoEXT -> IO ()) -> IO ())
-> ContT () IO (Ptr HostImageLayoutTransitionInfoEXT)
forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @HostImageLayoutTransitionInfoEXT ((("transitions" ::: Vector HostImageLayoutTransitionInfoEXT) -> Int
forall a. Vector a -> Int
Data.Vector.length ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT
transitions)) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
56)
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ (Int -> HostImageLayoutTransitionInfoEXT -> IO ())
-> ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT)
-> IO ()
forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i HostImageLayoutTransitionInfoEXT
e -> Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr HostImageLayoutTransitionInfoEXT
pPTransitions Ptr HostImageLayoutTransitionInfoEXT
-> Int -> Ptr HostImageLayoutTransitionInfoEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
56 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr HostImageLayoutTransitionInfoEXT) (HostImageLayoutTransitionInfoEXT
e)) ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT
transitions)
Result
r <- IO Result -> ContT () IO Result
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO Result -> ContT () IO Result)
-> IO Result -> ContT () IO Result
forall a b. (a -> b) -> a -> b
$ String -> IO Result -> IO Result
forall a. String -> IO a -> IO a
traceAroundEvent String
"vkTransitionImageLayoutEXT" (Ptr Device_T
-> Flags -> Ptr HostImageLayoutTransitionInfoEXT -> IO Result
vkTransitionImageLayoutEXT'
(Device -> Ptr Device_T
deviceHandle (Device
device))
((Int -> Flags
forall a b. (Integral a, Num b) => a -> b
fromIntegral (("transitions" ::: Vector HostImageLayoutTransitionInfoEXT) -> Int
forall a. Vector a -> Int
Data.Vector.length (("transitions" ::: Vector HostImageLayoutTransitionInfoEXT)
-> Int)
-> ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT)
-> Int
forall a b. (a -> b) -> a -> b
$ ("transitions" ::: Vector HostImageLayoutTransitionInfoEXT
transitions)) :: Word32))
(Ptr HostImageLayoutTransitionInfoEXT
pPTransitions))
IO () -> ContT () IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT () m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT () IO ()) -> IO () -> ContT () IO ()
forall a b. (a -> b) -> a -> b
$ Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r Result -> Result -> Bool
forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (VulkanException -> IO ()
forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
getImageSubresourceLayout2EXT :: Device
-> Image -> ImageSubresource2KHR -> io (SubresourceLayout2KHR a)
getImageSubresourceLayout2EXT = Device
-> Image -> ImageSubresource2KHR -> io (SubresourceLayout2KHR a)
forall (a :: [*]) (io :: * -> *).
(Extendss SubresourceLayout2KHR a, PokeChain a, PeekChain a,
MonadIO io) =>
Device
-> Image -> ImageSubresource2KHR -> io (SubresourceLayout2KHR a)
getImageSubresourceLayout2KHR
data PhysicalDeviceHostImageCopyFeaturesEXT = PhysicalDeviceHostImageCopyFeaturesEXT
{
PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
hostImageCopy :: Bool }
deriving (Typeable, PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
(PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool)
-> (PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool)
-> Eq PhysicalDeviceHostImageCopyFeaturesEXT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
== :: PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
$c/= :: PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
/= :: PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceHostImageCopyFeaturesEXT)
#endif
deriving instance Show PhysicalDeviceHostImageCopyFeaturesEXT
instance ToCStruct PhysicalDeviceHostImageCopyFeaturesEXT where
withCStruct :: forall b.
PhysicalDeviceHostImageCopyFeaturesEXT
-> (Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b) -> IO b
withCStruct PhysicalDeviceHostImageCopyFeaturesEXT
x Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b
f = Int -> (Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b) -> IO b)
-> (Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p -> Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO b -> IO b
forall b.
Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p PhysicalDeviceHostImageCopyFeaturesEXT
x (Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b
f Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p)
pokeCStruct :: forall b.
Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p PhysicalDeviceHostImageCopyFeaturesEXT{Bool
$sel:hostImageCopy:PhysicalDeviceHostImageCopyFeaturesEXT :: PhysicalDeviceHostImageCopyFeaturesEXT -> Bool
hostImageCopy :: Bool
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_FEATURES_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
hostImageCopy))
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b.
Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_FEATURES_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
IO b
f
instance FromCStruct PhysicalDeviceHostImageCopyFeaturesEXT where
peekCStruct :: Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT
peekCStruct Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p = do
Bool32
hostImageCopy <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceHostImageCopyFeaturesEXT
p Ptr PhysicalDeviceHostImageCopyFeaturesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT)
-> PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT
forall a b. (a -> b) -> a -> b
$ Bool -> PhysicalDeviceHostImageCopyFeaturesEXT
PhysicalDeviceHostImageCopyFeaturesEXT
(Bool32 -> Bool
bool32ToBool Bool32
hostImageCopy)
instance Storable PhysicalDeviceHostImageCopyFeaturesEXT where
sizeOf :: PhysicalDeviceHostImageCopyFeaturesEXT -> Int
sizeOf ~PhysicalDeviceHostImageCopyFeaturesEXT
_ = Int
24
alignment :: PhysicalDeviceHostImageCopyFeaturesEXT -> Int
alignment ~PhysicalDeviceHostImageCopyFeaturesEXT
_ = Int
8
peek :: Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT
peek = Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> IO PhysicalDeviceHostImageCopyFeaturesEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO ()
poke Ptr PhysicalDeviceHostImageCopyFeaturesEXT
ptr PhysicalDeviceHostImageCopyFeaturesEXT
poked = Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO () -> IO ()
forall b.
Ptr PhysicalDeviceHostImageCopyFeaturesEXT
-> PhysicalDeviceHostImageCopyFeaturesEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyFeaturesEXT
ptr PhysicalDeviceHostImageCopyFeaturesEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero PhysicalDeviceHostImageCopyFeaturesEXT where
zero :: PhysicalDeviceHostImageCopyFeaturesEXT
zero = Bool -> PhysicalDeviceHostImageCopyFeaturesEXT
PhysicalDeviceHostImageCopyFeaturesEXT
Bool
forall a. Zero a => a
zero
data PhysicalDeviceHostImageCopyPropertiesEXT = PhysicalDeviceHostImageCopyPropertiesEXT
{
PhysicalDeviceHostImageCopyPropertiesEXT -> Flags
copySrcLayoutCount :: Word32
,
PhysicalDeviceHostImageCopyPropertiesEXT -> Ptr ImageLayout
copySrcLayouts :: Ptr ImageLayout
,
PhysicalDeviceHostImageCopyPropertiesEXT -> Flags
copyDstLayoutCount :: Word32
,
PhysicalDeviceHostImageCopyPropertiesEXT -> Ptr ImageLayout
copyDstLayouts :: Ptr ImageLayout
,
PhysicalDeviceHostImageCopyPropertiesEXT -> ByteString
optimalTilingLayoutUUID :: ByteString
,
PhysicalDeviceHostImageCopyPropertiesEXT -> Bool
identicalMemoryTypeRequirements :: Bool
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceHostImageCopyPropertiesEXT)
#endif
deriving instance Show PhysicalDeviceHostImageCopyPropertiesEXT
instance ToCStruct PhysicalDeviceHostImageCopyPropertiesEXT where
withCStruct :: forall b.
PhysicalDeviceHostImageCopyPropertiesEXT
-> (Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b) -> IO b
withCStruct PhysicalDeviceHostImageCopyPropertiesEXT
x Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b
f = Int
-> (Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
72 ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b) -> IO b)
-> (Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p -> Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO b -> IO b
forall b.
Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p PhysicalDeviceHostImageCopyPropertiesEXT
x (Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b
f Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p)
pokeCStruct :: forall b.
Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p PhysicalDeviceHostImageCopyPropertiesEXT{Bool
Flags
Ptr ImageLayout
ByteString
$sel:copySrcLayoutCount:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> Flags
$sel:copySrcLayouts:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> Ptr ImageLayout
$sel:copyDstLayoutCount:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> Flags
$sel:copyDstLayouts:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> Ptr ImageLayout
$sel:optimalTilingLayoutUUID:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> ByteString
$sel:identicalMemoryTypeRequirements:PhysicalDeviceHostImageCopyPropertiesEXT :: PhysicalDeviceHostImageCopyPropertiesEXT -> Bool
copySrcLayoutCount :: Flags
copySrcLayouts :: Ptr ImageLayout
copyDstLayoutCount :: Flags
copyDstLayouts :: Ptr ImageLayout
optimalTilingLayoutUUID :: ByteString
identicalMemoryTypeRequirements :: Bool
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_PROPERTIES_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (Flags
copySrcLayoutCount)
Ptr (Ptr ImageLayout) -> Ptr ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (Ptr ImageLayout)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr (Ptr ImageLayout))) (Ptr ImageLayout
copySrcLayouts)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32)) (Flags
copyDstLayoutCount)
Ptr (Ptr ImageLayout) -> Ptr ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (Ptr ImageLayout)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr ImageLayout))) (Ptr ImageLayout
copyDstLayouts)
Ptr (FixedArray UUID_SIZE Word8) -> ByteString -> IO ()
forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n Word8) -> ByteString -> IO ()
pokeFixedLengthByteString ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (FixedArray UUID_SIZE Word8)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr (FixedArray UUID_SIZE Word8))) (ByteString
optimalTilingLayoutUUID)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
identicalMemoryTypeRequirements))
IO b
f
cStructSize :: Int
cStructSize = Int
72
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b.
Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_HOST_IMAGE_COPY_PROPERTIES_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
IO b
f
instance FromCStruct PhysicalDeviceHostImageCopyPropertiesEXT where
peekCStruct :: Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT
peekCStruct Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p = do
Flags
copySrcLayoutCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32))
Ptr ImageLayout
pCopySrcLayouts <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ImageLayout) ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (Ptr ImageLayout)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr (Ptr ImageLayout)))
Flags
copyDstLayoutCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32))
Ptr ImageLayout
pCopyDstLayouts <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ImageLayout) ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (Ptr ImageLayout)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr ImageLayout)))
ByteString
optimalTilingLayoutUUID <- Ptr (FixedArray UUID_SIZE Word8) -> IO ByteString
forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n Word8) -> IO ByteString
peekByteStringFromSizedVectorPtr ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> Int -> Ptr (FixedArray UUID_SIZE Word8)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr (FixedArray UUID_SIZE Word8)))
Bool32
identicalMemoryTypeRequirements <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceHostImageCopyPropertiesEXT
p Ptr PhysicalDeviceHostImageCopyPropertiesEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32))
PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT)
-> PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT
forall a b. (a -> b) -> a -> b
$ Flags
-> Ptr ImageLayout
-> Flags
-> Ptr ImageLayout
-> ByteString
-> Bool
-> PhysicalDeviceHostImageCopyPropertiesEXT
PhysicalDeviceHostImageCopyPropertiesEXT
Flags
copySrcLayoutCount
Ptr ImageLayout
pCopySrcLayouts
Flags
copyDstLayoutCount
Ptr ImageLayout
pCopyDstLayouts
ByteString
optimalTilingLayoutUUID
(Bool32 -> Bool
bool32ToBool Bool32
identicalMemoryTypeRequirements)
instance Storable PhysicalDeviceHostImageCopyPropertiesEXT where
sizeOf :: PhysicalDeviceHostImageCopyPropertiesEXT -> Int
sizeOf ~PhysicalDeviceHostImageCopyPropertiesEXT
_ = Int
72
alignment :: PhysicalDeviceHostImageCopyPropertiesEXT -> Int
alignment ~PhysicalDeviceHostImageCopyPropertiesEXT
_ = Int
8
peek :: Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT
peek = Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> IO PhysicalDeviceHostImageCopyPropertiesEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO ()
poke Ptr PhysicalDeviceHostImageCopyPropertiesEXT
ptr PhysicalDeviceHostImageCopyPropertiesEXT
poked = Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO () -> IO ()
forall b.
Ptr PhysicalDeviceHostImageCopyPropertiesEXT
-> PhysicalDeviceHostImageCopyPropertiesEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceHostImageCopyPropertiesEXT
ptr PhysicalDeviceHostImageCopyPropertiesEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero PhysicalDeviceHostImageCopyPropertiesEXT where
zero :: PhysicalDeviceHostImageCopyPropertiesEXT
zero = Flags
-> Ptr ImageLayout
-> Flags
-> Ptr ImageLayout
-> ByteString
-> Bool
-> PhysicalDeviceHostImageCopyPropertiesEXT
PhysicalDeviceHostImageCopyPropertiesEXT
Flags
forall a. Zero a => a
zero
Ptr ImageLayout
forall a. Zero a => a
zero
Flags
forall a. Zero a => a
zero
Ptr ImageLayout
forall a. Zero a => a
zero
ByteString
forall a. Monoid a => a
mempty
Bool
forall a. Zero a => a
zero
data MemoryToImageCopyEXT = MemoryToImageCopyEXT
{
MemoryToImageCopyEXT -> Ptr ()
hostPointer :: Ptr ()
,
MemoryToImageCopyEXT -> Flags
memoryRowLength :: Word32
,
MemoryToImageCopyEXT -> Flags
memoryImageHeight :: Word32
,
MemoryToImageCopyEXT -> ImageSubresourceLayers
imageSubresource :: ImageSubresourceLayers
,
MemoryToImageCopyEXT -> Offset3D
imageOffset :: Offset3D
,
MemoryToImageCopyEXT -> Extent3D
imageExtent :: Extent3D
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (MemoryToImageCopyEXT)
#endif
deriving instance Show MemoryToImageCopyEXT
instance ToCStruct MemoryToImageCopyEXT where
withCStruct :: forall b.
MemoryToImageCopyEXT -> (Ptr MemoryToImageCopyEXT -> IO b) -> IO b
withCStruct MemoryToImageCopyEXT
x Ptr MemoryToImageCopyEXT -> IO b
f = Int -> (Ptr MemoryToImageCopyEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
72 ((Ptr MemoryToImageCopyEXT -> IO b) -> IO b)
-> (Ptr MemoryToImageCopyEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr MemoryToImageCopyEXT
p -> Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO b -> IO b
forall b.
Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryToImageCopyEXT
p MemoryToImageCopyEXT
x (Ptr MemoryToImageCopyEXT -> IO b
f Ptr MemoryToImageCopyEXT
p)
pokeCStruct :: forall b.
Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO b -> IO b
pokeCStruct Ptr MemoryToImageCopyEXT
p MemoryToImageCopyEXT{Flags
Ptr ()
Extent3D
Offset3D
ImageSubresourceLayers
$sel:hostPointer:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> Ptr ()
$sel:memoryRowLength:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> Flags
$sel:memoryImageHeight:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> Flags
$sel:imageSubresource:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> ImageSubresourceLayers
$sel:imageOffset:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> Offset3D
$sel:imageExtent:MemoryToImageCopyEXT :: MemoryToImageCopyEXT -> Extent3D
hostPointer :: Ptr ()
memoryRowLength :: Flags
memoryImageHeight :: Flags
imageSubresource :: ImageSubresourceLayers
imageOffset :: Offset3D
imageExtent :: Extent3D
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_MEMORY_TO_IMAGE_COPY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ()))) (Ptr ()
hostPointer)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Flags
memoryRowLength)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (Flags
memoryImageHeight)
Ptr ImageSubresourceLayers -> ImageSubresourceLayers -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers)) (ImageSubresourceLayers
imageSubresource)
Ptr Offset3D -> Offset3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D)) (Offset3D
imageOffset)
Ptr Extent3D -> Extent3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D)) (Extent3D
imageExtent)
IO b
f
cStructSize :: Int
cStructSize = Int
72
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr MemoryToImageCopyEXT -> IO b -> IO b
pokeZeroCStruct Ptr MemoryToImageCopyEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_MEMORY_TO_IMAGE_COPY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ()))) (Ptr ()
forall a. Zero a => a
zero)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Flags
forall a. Zero a => a
zero)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (Flags
forall a. Zero a => a
zero)
Ptr ImageSubresourceLayers -> ImageSubresourceLayers -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers)) (ImageSubresourceLayers
forall a. Zero a => a
zero)
Ptr Offset3D -> Offset3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D)) (Offset3D
forall a. Zero a => a
zero)
Ptr Extent3D -> Extent3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D)) (Extent3D
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct MemoryToImageCopyEXT where
peekCStruct :: Ptr MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT
peekCStruct Ptr MemoryToImageCopyEXT
p = do
Ptr ()
pHostPointer <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ()) ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ())))
Flags
memoryRowLength <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32))
Flags
memoryImageHeight <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32))
ImageSubresourceLayers
imageSubresource <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageSubresourceLayers ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers))
Offset3D
imageOffset <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Offset3D ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D))
Extent3D
imageExtent <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Extent3D ((Ptr MemoryToImageCopyEXT
p Ptr MemoryToImageCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D))
MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT)
-> MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT
forall a b. (a -> b) -> a -> b
$ Ptr ()
-> Flags
-> Flags
-> ImageSubresourceLayers
-> Offset3D
-> Extent3D
-> MemoryToImageCopyEXT
MemoryToImageCopyEXT
Ptr ()
pHostPointer
Flags
memoryRowLength
Flags
memoryImageHeight
ImageSubresourceLayers
imageSubresource
Offset3D
imageOffset
Extent3D
imageExtent
instance Storable MemoryToImageCopyEXT where
sizeOf :: MemoryToImageCopyEXT -> Int
sizeOf ~MemoryToImageCopyEXT
_ = Int
72
alignment :: MemoryToImageCopyEXT -> Int
alignment ~MemoryToImageCopyEXT
_ = Int
8
peek :: Ptr MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT
peek = Ptr MemoryToImageCopyEXT -> IO MemoryToImageCopyEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO ()
poke Ptr MemoryToImageCopyEXT
ptr MemoryToImageCopyEXT
poked = Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO () -> IO ()
forall b.
Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryToImageCopyEXT
ptr MemoryToImageCopyEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero MemoryToImageCopyEXT where
zero :: MemoryToImageCopyEXT
zero = Ptr ()
-> Flags
-> Flags
-> ImageSubresourceLayers
-> Offset3D
-> Extent3D
-> MemoryToImageCopyEXT
MemoryToImageCopyEXT
Ptr ()
forall a. Zero a => a
zero
Flags
forall a. Zero a => a
zero
Flags
forall a. Zero a => a
zero
ImageSubresourceLayers
forall a. Zero a => a
zero
Offset3D
forall a. Zero a => a
zero
Extent3D
forall a. Zero a => a
zero
data ImageToMemoryCopyEXT = ImageToMemoryCopyEXT
{
ImageToMemoryCopyEXT -> Ptr ()
hostPointer :: Ptr ()
,
ImageToMemoryCopyEXT -> Flags
memoryRowLength :: Word32
,
ImageToMemoryCopyEXT -> Flags
memoryImageHeight :: Word32
,
ImageToMemoryCopyEXT -> ImageSubresourceLayers
imageSubresource :: ImageSubresourceLayers
,
ImageToMemoryCopyEXT -> Offset3D
imageOffset :: Offset3D
,
ImageToMemoryCopyEXT -> Extent3D
imageExtent :: Extent3D
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (ImageToMemoryCopyEXT)
#endif
deriving instance Show ImageToMemoryCopyEXT
instance ToCStruct ImageToMemoryCopyEXT where
withCStruct :: forall b.
ImageToMemoryCopyEXT -> (Ptr ImageToMemoryCopyEXT -> IO b) -> IO b
withCStruct ImageToMemoryCopyEXT
x Ptr ImageToMemoryCopyEXT -> IO b
f = Int -> (Ptr ImageToMemoryCopyEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
72 ((Ptr ImageToMemoryCopyEXT -> IO b) -> IO b)
-> (Ptr ImageToMemoryCopyEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr ImageToMemoryCopyEXT
p -> Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO b -> IO b
forall b.
Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr ImageToMemoryCopyEXT
p ImageToMemoryCopyEXT
x (Ptr ImageToMemoryCopyEXT -> IO b
f Ptr ImageToMemoryCopyEXT
p)
pokeCStruct :: forall b.
Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO b -> IO b
pokeCStruct Ptr ImageToMemoryCopyEXT
p ImageToMemoryCopyEXT{Flags
Ptr ()
Extent3D
Offset3D
ImageSubresourceLayers
$sel:hostPointer:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> Ptr ()
$sel:memoryRowLength:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> Flags
$sel:memoryImageHeight:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> Flags
$sel:imageSubresource:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> ImageSubresourceLayers
$sel:imageOffset:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> Offset3D
$sel:imageExtent:ImageToMemoryCopyEXT :: ImageToMemoryCopyEXT -> Extent3D
hostPointer :: Ptr ()
memoryRowLength :: Flags
memoryImageHeight :: Flags
imageSubresource :: ImageSubresourceLayers
imageOffset :: Offset3D
imageExtent :: Extent3D
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_IMAGE_TO_MEMORY_COPY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ()))) (Ptr ()
hostPointer)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Flags
memoryRowLength)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (Flags
memoryImageHeight)
Ptr ImageSubresourceLayers -> ImageSubresourceLayers -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers)) (ImageSubresourceLayers
imageSubresource)
Ptr Offset3D -> Offset3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D)) (Offset3D
imageOffset)
Ptr Extent3D -> Extent3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D)) (Extent3D
imageExtent)
IO b
f
cStructSize :: Int
cStructSize = Int
72
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr ImageToMemoryCopyEXT -> IO b -> IO b
pokeZeroCStruct Ptr ImageToMemoryCopyEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_IMAGE_TO_MEMORY_COPY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ()))) (Ptr ()
forall a. Zero a => a
zero)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Flags
forall a. Zero a => a
zero)
Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (Flags
forall a. Zero a => a
zero)
Ptr ImageSubresourceLayers -> ImageSubresourceLayers -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers)) (ImageSubresourceLayers
forall a. Zero a => a
zero)
Ptr Offset3D -> Offset3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D)) (Offset3D
forall a. Zero a => a
zero)
Ptr Extent3D -> Extent3D -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D)) (Extent3D
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct ImageToMemoryCopyEXT where
peekCStruct :: Ptr ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT
peekCStruct Ptr ImageToMemoryCopyEXT
p = do
Ptr ()
pHostPointer <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ()) ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr ())))
Flags
memoryRowLength <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32))
Flags
memoryImageHeight <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32))
ImageSubresourceLayers
imageSubresource <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageSubresourceLayers ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr ImageSubresourceLayers
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceLayers))
Offset3D
imageOffset <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Offset3D ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Offset3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Offset3D))
Extent3D
imageExtent <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Extent3D ((Ptr ImageToMemoryCopyEXT
p Ptr ImageToMemoryCopyEXT -> Int -> Ptr Extent3D
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Extent3D))
ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT)
-> ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT
forall a b. (a -> b) -> a -> b
$ Ptr ()
-> Flags
-> Flags
-> ImageSubresourceLayers
-> Offset3D
-> Extent3D
-> ImageToMemoryCopyEXT
ImageToMemoryCopyEXT
Ptr ()
pHostPointer
Flags
memoryRowLength
Flags
memoryImageHeight
ImageSubresourceLayers
imageSubresource
Offset3D
imageOffset
Extent3D
imageExtent
instance Storable ImageToMemoryCopyEXT where
sizeOf :: ImageToMemoryCopyEXT -> Int
sizeOf ~ImageToMemoryCopyEXT
_ = Int
72
alignment :: ImageToMemoryCopyEXT -> Int
alignment ~ImageToMemoryCopyEXT
_ = Int
8
peek :: Ptr ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT
peek = Ptr ImageToMemoryCopyEXT -> IO ImageToMemoryCopyEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO ()
poke Ptr ImageToMemoryCopyEXT
ptr ImageToMemoryCopyEXT
poked = Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO () -> IO ()
forall b.
Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr ImageToMemoryCopyEXT
ptr ImageToMemoryCopyEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero ImageToMemoryCopyEXT where
zero :: ImageToMemoryCopyEXT
zero = Ptr ()
-> Flags
-> Flags
-> ImageSubresourceLayers
-> Offset3D
-> Extent3D
-> ImageToMemoryCopyEXT
ImageToMemoryCopyEXT
Ptr ()
forall a. Zero a => a
zero
Flags
forall a. Zero a => a
zero
Flags
forall a. Zero a => a
zero
ImageSubresourceLayers
forall a. Zero a => a
zero
Offset3D
forall a. Zero a => a
zero
Extent3D
forall a. Zero a => a
zero
data CopyMemoryToImageInfoEXT = CopyMemoryToImageInfoEXT
{
CopyMemoryToImageInfoEXT -> HostImageCopyFlagsEXT
flags :: HostImageCopyFlagsEXT
,
CopyMemoryToImageInfoEXT -> Image
dstImage :: Image
,
CopyMemoryToImageInfoEXT -> ImageLayout
dstImageLayout :: ImageLayout
,
CopyMemoryToImageInfoEXT -> Vector MemoryToImageCopyEXT
regions :: Vector MemoryToImageCopyEXT
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (CopyMemoryToImageInfoEXT)
#endif
deriving instance Show CopyMemoryToImageInfoEXT
instance ToCStruct CopyMemoryToImageInfoEXT where
withCStruct :: forall b.
CopyMemoryToImageInfoEXT
-> (Ptr CopyMemoryToImageInfoEXT -> IO b) -> IO b
withCStruct CopyMemoryToImageInfoEXT
x Ptr CopyMemoryToImageInfoEXT -> IO b
f = Int -> (Ptr CopyMemoryToImageInfoEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
48 ((Ptr CopyMemoryToImageInfoEXT -> IO b) -> IO b)
-> (Ptr CopyMemoryToImageInfoEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr CopyMemoryToImageInfoEXT
p -> Ptr CopyMemoryToImageInfoEXT
-> CopyMemoryToImageInfoEXT -> IO b -> IO b
forall b.
Ptr CopyMemoryToImageInfoEXT
-> CopyMemoryToImageInfoEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr CopyMemoryToImageInfoEXT
p CopyMemoryToImageInfoEXT
x (Ptr CopyMemoryToImageInfoEXT -> IO b
f Ptr CopyMemoryToImageInfoEXT
p)
pokeCStruct :: forall b.
Ptr CopyMemoryToImageInfoEXT
-> CopyMemoryToImageInfoEXT -> IO b -> IO b
pokeCStruct Ptr CopyMemoryToImageInfoEXT
p CopyMemoryToImageInfoEXT{Vector MemoryToImageCopyEXT
ImageLayout
Image
HostImageCopyFlagsEXT
$sel:flags:CopyMemoryToImageInfoEXT :: CopyMemoryToImageInfoEXT -> HostImageCopyFlagsEXT
$sel:dstImage:CopyMemoryToImageInfoEXT :: CopyMemoryToImageInfoEXT -> Image
$sel:dstImageLayout:CopyMemoryToImageInfoEXT :: CopyMemoryToImageInfoEXT -> ImageLayout
$sel:regions:CopyMemoryToImageInfoEXT :: CopyMemoryToImageInfoEXT -> Vector MemoryToImageCopyEXT
flags :: HostImageCopyFlagsEXT
dstImage :: Image
dstImageLayout :: ImageLayout
regions :: Vector MemoryToImageCopyEXT
..} IO b
f = ContT b IO b -> IO b
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT b IO b -> IO b) -> ContT b IO b -> IO b
forall a b. (a -> b) -> a -> b
$ do
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_MEMORY_TO_IMAGE_INFO_EXT)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT)) (HostImageCopyFlagsEXT
flags)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
dstImage)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
dstImageLayout)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32)) ((Int -> Flags
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Vector MemoryToImageCopyEXT -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector MemoryToImageCopyEXT -> Int)
-> Vector MemoryToImageCopyEXT -> Int
forall a b. (a -> b) -> a -> b
$ (Vector MemoryToImageCopyEXT
regions)) :: Word32))
Ptr MemoryToImageCopyEXT
pPRegions' <- ((Ptr MemoryToImageCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr MemoryToImageCopyEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr MemoryToImageCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr MemoryToImageCopyEXT))
-> ((Ptr MemoryToImageCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr MemoryToImageCopyEXT)
forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @MemoryToImageCopyEXT ((Vector MemoryToImageCopyEXT -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector MemoryToImageCopyEXT
regions)) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
72)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ (Int -> MemoryToImageCopyEXT -> IO ())
-> Vector MemoryToImageCopyEXT -> IO ()
forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i MemoryToImageCopyEXT
e -> Ptr MemoryToImageCopyEXT -> MemoryToImageCopyEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr MemoryToImageCopyEXT
pPRegions' Ptr MemoryToImageCopyEXT -> Int -> Ptr MemoryToImageCopyEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
72 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryToImageCopyEXT) (MemoryToImageCopyEXT
e)) (Vector MemoryToImageCopyEXT
regions)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr MemoryToImageCopyEXT) -> Ptr MemoryToImageCopyEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT
-> Int -> Ptr (Ptr MemoryToImageCopyEXT)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr MemoryToImageCopyEXT))) (Ptr MemoryToImageCopyEXT
pPRegions')
IO b -> ContT b IO b
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO b -> ContT b IO b) -> IO b -> ContT b IO b
forall a b. (a -> b) -> a -> b
$ IO b
f
cStructSize :: Int
cStructSize = Int
48
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr CopyMemoryToImageInfoEXT -> IO b -> IO b
pokeZeroCStruct Ptr CopyMemoryToImageInfoEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_MEMORY_TO_IMAGE_INFO_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct CopyMemoryToImageInfoEXT where
peekCStruct :: Ptr CopyMemoryToImageInfoEXT -> IO CopyMemoryToImageInfoEXT
peekCStruct Ptr CopyMemoryToImageInfoEXT
p = do
HostImageCopyFlagsEXT
flags <- forall a. Storable a => Ptr a -> IO a
peek @HostImageCopyFlagsEXT ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT))
Image
dstImage <- forall a. Storable a => Ptr a -> IO a
peek @Image ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image))
ImageLayout
dstImageLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout))
Flags
regionCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32))
Ptr MemoryToImageCopyEXT
pRegions <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr MemoryToImageCopyEXT) ((Ptr CopyMemoryToImageInfoEXT
p Ptr CopyMemoryToImageInfoEXT
-> Int -> Ptr (Ptr MemoryToImageCopyEXT)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr MemoryToImageCopyEXT)))
Vector MemoryToImageCopyEXT
pRegions' <- Int
-> (Int -> IO MemoryToImageCopyEXT)
-> IO (Vector MemoryToImageCopyEXT)
forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (Flags -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Flags
regionCount) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @MemoryToImageCopyEXT ((Ptr MemoryToImageCopyEXT
pRegions Ptr MemoryToImageCopyEXT -> Int -> Ptr MemoryToImageCopyEXT
forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
72 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryToImageCopyEXT)))
CopyMemoryToImageInfoEXT -> IO CopyMemoryToImageInfoEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (CopyMemoryToImageInfoEXT -> IO CopyMemoryToImageInfoEXT)
-> CopyMemoryToImageInfoEXT -> IO CopyMemoryToImageInfoEXT
forall a b. (a -> b) -> a -> b
$ HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Vector MemoryToImageCopyEXT
-> CopyMemoryToImageInfoEXT
CopyMemoryToImageInfoEXT
HostImageCopyFlagsEXT
flags Image
dstImage ImageLayout
dstImageLayout Vector MemoryToImageCopyEXT
pRegions'
instance Zero CopyMemoryToImageInfoEXT where
zero :: CopyMemoryToImageInfoEXT
zero = HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Vector MemoryToImageCopyEXT
-> CopyMemoryToImageInfoEXT
CopyMemoryToImageInfoEXT
HostImageCopyFlagsEXT
forall a. Zero a => a
zero
Image
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
Vector MemoryToImageCopyEXT
forall a. Monoid a => a
mempty
data CopyImageToMemoryInfoEXT = CopyImageToMemoryInfoEXT
{
CopyImageToMemoryInfoEXT -> HostImageCopyFlagsEXT
flags :: HostImageCopyFlagsEXT
,
CopyImageToMemoryInfoEXT -> Image
srcImage :: Image
,
CopyImageToMemoryInfoEXT -> ImageLayout
srcImageLayout :: ImageLayout
,
CopyImageToMemoryInfoEXT -> Vector ImageToMemoryCopyEXT
regions :: Vector ImageToMemoryCopyEXT
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (CopyImageToMemoryInfoEXT)
#endif
deriving instance Show CopyImageToMemoryInfoEXT
instance ToCStruct CopyImageToMemoryInfoEXT where
withCStruct :: forall b.
CopyImageToMemoryInfoEXT
-> (Ptr CopyImageToMemoryInfoEXT -> IO b) -> IO b
withCStruct CopyImageToMemoryInfoEXT
x Ptr CopyImageToMemoryInfoEXT -> IO b
f = Int -> (Ptr CopyImageToMemoryInfoEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
48 ((Ptr CopyImageToMemoryInfoEXT -> IO b) -> IO b)
-> (Ptr CopyImageToMemoryInfoEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr CopyImageToMemoryInfoEXT
p -> Ptr CopyImageToMemoryInfoEXT
-> CopyImageToMemoryInfoEXT -> IO b -> IO b
forall b.
Ptr CopyImageToMemoryInfoEXT
-> CopyImageToMemoryInfoEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr CopyImageToMemoryInfoEXT
p CopyImageToMemoryInfoEXT
x (Ptr CopyImageToMemoryInfoEXT -> IO b
f Ptr CopyImageToMemoryInfoEXT
p)
pokeCStruct :: forall b.
Ptr CopyImageToMemoryInfoEXT
-> CopyImageToMemoryInfoEXT -> IO b -> IO b
pokeCStruct Ptr CopyImageToMemoryInfoEXT
p CopyImageToMemoryInfoEXT{Vector ImageToMemoryCopyEXT
ImageLayout
Image
HostImageCopyFlagsEXT
$sel:flags:CopyImageToMemoryInfoEXT :: CopyImageToMemoryInfoEXT -> HostImageCopyFlagsEXT
$sel:srcImage:CopyImageToMemoryInfoEXT :: CopyImageToMemoryInfoEXT -> Image
$sel:srcImageLayout:CopyImageToMemoryInfoEXT :: CopyImageToMemoryInfoEXT -> ImageLayout
$sel:regions:CopyImageToMemoryInfoEXT :: CopyImageToMemoryInfoEXT -> Vector ImageToMemoryCopyEXT
flags :: HostImageCopyFlagsEXT
srcImage :: Image
srcImageLayout :: ImageLayout
regions :: Vector ImageToMemoryCopyEXT
..} IO b
f = ContT b IO b -> IO b
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT b IO b -> IO b) -> ContT b IO b -> IO b
forall a b. (a -> b) -> a -> b
$ do
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_IMAGE_TO_MEMORY_INFO_EXT)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT)) (HostImageCopyFlagsEXT
flags)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
srcImage)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
srcImageLayout)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32)) ((Int -> Flags
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Vector ImageToMemoryCopyEXT -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector ImageToMemoryCopyEXT -> Int)
-> Vector ImageToMemoryCopyEXT -> Int
forall a b. (a -> b) -> a -> b
$ (Vector ImageToMemoryCopyEXT
regions)) :: Word32))
Ptr ImageToMemoryCopyEXT
pPRegions' <- ((Ptr ImageToMemoryCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr ImageToMemoryCopyEXT)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr ImageToMemoryCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr ImageToMemoryCopyEXT))
-> ((Ptr ImageToMemoryCopyEXT -> IO b) -> IO b)
-> ContT b IO (Ptr ImageToMemoryCopyEXT)
forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @ImageToMemoryCopyEXT ((Vector ImageToMemoryCopyEXT -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector ImageToMemoryCopyEXT
regions)) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
72)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ (Int -> ImageToMemoryCopyEXT -> IO ())
-> Vector ImageToMemoryCopyEXT -> IO ()
forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i ImageToMemoryCopyEXT
e -> Ptr ImageToMemoryCopyEXT -> ImageToMemoryCopyEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr ImageToMemoryCopyEXT
pPRegions' Ptr ImageToMemoryCopyEXT -> Int -> Ptr ImageToMemoryCopyEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
72 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr ImageToMemoryCopyEXT) (ImageToMemoryCopyEXT
e)) (Vector ImageToMemoryCopyEXT
regions)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr ImageToMemoryCopyEXT) -> Ptr ImageToMemoryCopyEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT
-> Int -> Ptr (Ptr ImageToMemoryCopyEXT)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr ImageToMemoryCopyEXT))) (Ptr ImageToMemoryCopyEXT
pPRegions')
IO b -> ContT b IO b
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO b -> ContT b IO b) -> IO b -> ContT b IO b
forall a b. (a -> b) -> a -> b
$ IO b
f
cStructSize :: Int
cStructSize = Int
48
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr CopyImageToMemoryInfoEXT -> IO b -> IO b
pokeZeroCStruct Ptr CopyImageToMemoryInfoEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_IMAGE_TO_MEMORY_INFO_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct CopyImageToMemoryInfoEXT where
peekCStruct :: Ptr CopyImageToMemoryInfoEXT -> IO CopyImageToMemoryInfoEXT
peekCStruct Ptr CopyImageToMemoryInfoEXT
p = do
HostImageCopyFlagsEXT
flags <- forall a. Storable a => Ptr a -> IO a
peek @HostImageCopyFlagsEXT ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT))
Image
srcImage <- forall a. Storable a => Ptr a -> IO a
peek @Image ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image))
ImageLayout
srcImageLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout))
Flags
regionCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32))
Ptr ImageToMemoryCopyEXT
pRegions <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ImageToMemoryCopyEXT) ((Ptr CopyImageToMemoryInfoEXT
p Ptr CopyImageToMemoryInfoEXT
-> Int -> Ptr (Ptr ImageToMemoryCopyEXT)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr ImageToMemoryCopyEXT)))
Vector ImageToMemoryCopyEXT
pRegions' <- Int
-> (Int -> IO ImageToMemoryCopyEXT)
-> IO (Vector ImageToMemoryCopyEXT)
forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (Flags -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Flags
regionCount) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageToMemoryCopyEXT ((Ptr ImageToMemoryCopyEXT
pRegions Ptr ImageToMemoryCopyEXT -> Int -> Ptr ImageToMemoryCopyEXT
forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
72 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr ImageToMemoryCopyEXT)))
CopyImageToMemoryInfoEXT -> IO CopyImageToMemoryInfoEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (CopyImageToMemoryInfoEXT -> IO CopyImageToMemoryInfoEXT)
-> CopyImageToMemoryInfoEXT -> IO CopyImageToMemoryInfoEXT
forall a b. (a -> b) -> a -> b
$ HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Vector ImageToMemoryCopyEXT
-> CopyImageToMemoryInfoEXT
CopyImageToMemoryInfoEXT
HostImageCopyFlagsEXT
flags Image
srcImage ImageLayout
srcImageLayout Vector ImageToMemoryCopyEXT
pRegions'
instance Zero CopyImageToMemoryInfoEXT where
zero :: CopyImageToMemoryInfoEXT
zero = HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Vector ImageToMemoryCopyEXT
-> CopyImageToMemoryInfoEXT
CopyImageToMemoryInfoEXT
HostImageCopyFlagsEXT
forall a. Zero a => a
zero
Image
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
Vector ImageToMemoryCopyEXT
forall a. Monoid a => a
mempty
data CopyImageToImageInfoEXT = CopyImageToImageInfoEXT
{
CopyImageToImageInfoEXT -> HostImageCopyFlagsEXT
flags :: HostImageCopyFlagsEXT
,
CopyImageToImageInfoEXT -> Image
srcImage :: Image
,
CopyImageToImageInfoEXT -> ImageLayout
srcImageLayout :: ImageLayout
,
CopyImageToImageInfoEXT -> Image
dstImage :: Image
,
CopyImageToImageInfoEXT -> ImageLayout
dstImageLayout :: ImageLayout
,
CopyImageToImageInfoEXT -> Vector ImageCopy2
regions :: Vector ImageCopy2
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (CopyImageToImageInfoEXT)
#endif
deriving instance Show CopyImageToImageInfoEXT
instance ToCStruct CopyImageToImageInfoEXT where
withCStruct :: forall b.
CopyImageToImageInfoEXT
-> (Ptr CopyImageToImageInfoEXT -> IO b) -> IO b
withCStruct CopyImageToImageInfoEXT
x Ptr CopyImageToImageInfoEXT -> IO b
f = Int -> (Ptr CopyImageToImageInfoEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
64 ((Ptr CopyImageToImageInfoEXT -> IO b) -> IO b)
-> (Ptr CopyImageToImageInfoEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr CopyImageToImageInfoEXT
p -> Ptr CopyImageToImageInfoEXT
-> CopyImageToImageInfoEXT -> IO b -> IO b
forall b.
Ptr CopyImageToImageInfoEXT
-> CopyImageToImageInfoEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr CopyImageToImageInfoEXT
p CopyImageToImageInfoEXT
x (Ptr CopyImageToImageInfoEXT -> IO b
f Ptr CopyImageToImageInfoEXT
p)
pokeCStruct :: forall b.
Ptr CopyImageToImageInfoEXT
-> CopyImageToImageInfoEXT -> IO b -> IO b
pokeCStruct Ptr CopyImageToImageInfoEXT
p CopyImageToImageInfoEXT{Vector ImageCopy2
ImageLayout
Image
HostImageCopyFlagsEXT
$sel:flags:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> HostImageCopyFlagsEXT
$sel:srcImage:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> Image
$sel:srcImageLayout:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> ImageLayout
$sel:dstImage:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> Image
$sel:dstImageLayout:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> ImageLayout
$sel:regions:CopyImageToImageInfoEXT :: CopyImageToImageInfoEXT -> Vector ImageCopy2
flags :: HostImageCopyFlagsEXT
srcImage :: Image
srcImageLayout :: ImageLayout
dstImage :: Image
dstImageLayout :: ImageLayout
regions :: Vector ImageCopy2
..} IO b
f = ContT b IO b -> IO b
forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT (ContT b IO b -> IO b) -> ContT b IO b -> IO b
forall a b. (a -> b) -> a -> b
$ do
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_IMAGE_TO_IMAGE_INFO_EXT)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT)) (HostImageCopyFlagsEXT
flags)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
srcImage)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
srcImageLayout)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Image)) (Image
dstImage)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr ImageLayout)) (ImageLayout
dstImageLayout)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr Flags -> Flags -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
52 :: Ptr Word32)) ((Int -> Flags
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Vector ImageCopy2 -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector ImageCopy2 -> Int) -> Vector ImageCopy2 -> Int
forall a b. (a -> b) -> a -> b
$ (Vector ImageCopy2
regions)) :: Word32))
Ptr ImageCopy2
pPRegions' <- ((Ptr ImageCopy2 -> IO b) -> IO b) -> ContT b IO (Ptr ImageCopy2)
forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (((Ptr ImageCopy2 -> IO b) -> IO b) -> ContT b IO (Ptr ImageCopy2))
-> ((Ptr ImageCopy2 -> IO b) -> IO b)
-> ContT b IO (Ptr ImageCopy2)
forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @ImageCopy2 ((Vector ImageCopy2 -> Int
forall a. Vector a -> Int
Data.Vector.length (Vector ImageCopy2
regions)) Int -> Int -> Int
forall a. Num a => a -> a -> a
* Int
88)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ (Int -> ImageCopy2 -> IO ()) -> Vector ImageCopy2 -> IO ()
forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i ImageCopy2
e -> Ptr ImageCopy2 -> ImageCopy2 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr ImageCopy2
pPRegions' Ptr ImageCopy2 -> Int -> Ptr ImageCopy2
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
88 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr ImageCopy2) (ImageCopy2
e)) (Vector ImageCopy2
regions)
IO () -> ContT b IO ()
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO () -> ContT b IO ()) -> IO () -> ContT b IO ()
forall a b. (a -> b) -> a -> b
$ Ptr (Ptr ImageCopy2) -> Ptr ImageCopy2 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr (Ptr ImageCopy2)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr (Ptr ImageCopy2))) (Ptr ImageCopy2
pPRegions')
IO b -> ContT b IO b
forall (m :: * -> *) a. Monad m => m a -> ContT b m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO b -> ContT b IO b) -> IO b -> ContT b IO b
forall a b. (a -> b) -> a -> b
$ IO b
f
cStructSize :: Int
cStructSize = Int
64
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr CopyImageToImageInfoEXT -> IO b -> IO b
pokeZeroCStruct Ptr CopyImageToImageInfoEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_COPY_IMAGE_TO_IMAGE_INFO_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image)) (Image
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Image)) (Image
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct CopyImageToImageInfoEXT where
peekCStruct :: Ptr CopyImageToImageInfoEXT -> IO CopyImageToImageInfoEXT
peekCStruct Ptr CopyImageToImageInfoEXT
p = do
HostImageCopyFlagsEXT
flags <- forall a. Storable a => Ptr a -> IO a
peek @HostImageCopyFlagsEXT ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr HostImageCopyFlagsEXT
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr HostImageCopyFlagsEXT))
Image
srcImage <- forall a. Storable a => Ptr a -> IO a
peek @Image ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Image))
ImageLayout
srcImageLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageLayout))
Image
dstImage <- forall a. Storable a => Ptr a -> IO a
peek @Image ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Image))
ImageLayout
dstImageLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr ImageLayout))
Flags
regionCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr Flags
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
52 :: Ptr Word32))
Ptr ImageCopy2
pRegions <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ImageCopy2) ((Ptr CopyImageToImageInfoEXT
p Ptr CopyImageToImageInfoEXT -> Int -> Ptr (Ptr ImageCopy2)
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr (Ptr ImageCopy2)))
Vector ImageCopy2
pRegions' <- Int -> (Int -> IO ImageCopy2) -> IO (Vector ImageCopy2)
forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (Flags -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Flags
regionCount) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageCopy2 ((Ptr ImageCopy2
pRegions Ptr ImageCopy2 -> Int -> Ptr ImageCopy2
forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
88 Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr ImageCopy2)))
CopyImageToImageInfoEXT -> IO CopyImageToImageInfoEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (CopyImageToImageInfoEXT -> IO CopyImageToImageInfoEXT)
-> CopyImageToImageInfoEXT -> IO CopyImageToImageInfoEXT
forall a b. (a -> b) -> a -> b
$ HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Image
-> ImageLayout
-> Vector ImageCopy2
-> CopyImageToImageInfoEXT
CopyImageToImageInfoEXT
HostImageCopyFlagsEXT
flags Image
srcImage ImageLayout
srcImageLayout Image
dstImage ImageLayout
dstImageLayout Vector ImageCopy2
pRegions'
instance Zero CopyImageToImageInfoEXT where
zero :: CopyImageToImageInfoEXT
zero = HostImageCopyFlagsEXT
-> Image
-> ImageLayout
-> Image
-> ImageLayout
-> Vector ImageCopy2
-> CopyImageToImageInfoEXT
CopyImageToImageInfoEXT
HostImageCopyFlagsEXT
forall a. Zero a => a
zero
Image
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
Image
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
Vector ImageCopy2
forall a. Monoid a => a
mempty
data HostImageLayoutTransitionInfoEXT = HostImageLayoutTransitionInfoEXT
{
HostImageLayoutTransitionInfoEXT -> Image
image :: Image
,
HostImageLayoutTransitionInfoEXT -> ImageLayout
oldLayout :: ImageLayout
,
HostImageLayoutTransitionInfoEXT -> ImageLayout
newLayout :: ImageLayout
,
HostImageLayoutTransitionInfoEXT -> ImageSubresourceRange
subresourceRange :: ImageSubresourceRange
}
deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (HostImageLayoutTransitionInfoEXT)
#endif
deriving instance Show HostImageLayoutTransitionInfoEXT
instance ToCStruct HostImageLayoutTransitionInfoEXT where
withCStruct :: forall b.
HostImageLayoutTransitionInfoEXT
-> (Ptr HostImageLayoutTransitionInfoEXT -> IO b) -> IO b
withCStruct HostImageLayoutTransitionInfoEXT
x Ptr HostImageLayoutTransitionInfoEXT -> IO b
f = Int -> (Ptr HostImageLayoutTransitionInfoEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
56 ((Ptr HostImageLayoutTransitionInfoEXT -> IO b) -> IO b)
-> (Ptr HostImageLayoutTransitionInfoEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr HostImageLayoutTransitionInfoEXT
p -> Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO b -> IO b
forall b.
Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr HostImageLayoutTransitionInfoEXT
p HostImageLayoutTransitionInfoEXT
x (Ptr HostImageLayoutTransitionInfoEXT -> IO b
f Ptr HostImageLayoutTransitionInfoEXT
p)
pokeCStruct :: forall b.
Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO b -> IO b
pokeCStruct Ptr HostImageLayoutTransitionInfoEXT
p HostImageLayoutTransitionInfoEXT{ImageLayout
Image
ImageSubresourceRange
$sel:image:HostImageLayoutTransitionInfoEXT :: HostImageLayoutTransitionInfoEXT -> Image
$sel:oldLayout:HostImageLayoutTransitionInfoEXT :: HostImageLayoutTransitionInfoEXT -> ImageLayout
$sel:newLayout:HostImageLayoutTransitionInfoEXT :: HostImageLayoutTransitionInfoEXT -> ImageLayout
$sel:subresourceRange:HostImageLayoutTransitionInfoEXT :: HostImageLayoutTransitionInfoEXT -> ImageSubresourceRange
image :: Image
oldLayout :: ImageLayout
newLayout :: ImageLayout
subresourceRange :: ImageSubresourceRange
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_HOST_IMAGE_LAYOUT_TRANSITION_INFO_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Image)) (Image
image)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr ImageLayout)) (ImageLayout
oldLayout)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr ImageLayout)) (ImageLayout
newLayout)
Ptr ImageSubresourceRange -> ImageSubresourceRange -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT
-> Int -> Ptr ImageSubresourceRange
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceRange)) (ImageSubresourceRange
subresourceRange)
IO b
f
cStructSize :: Int
cStructSize = Int
56
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr HostImageLayoutTransitionInfoEXT -> IO b -> IO b
pokeZeroCStruct Ptr HostImageLayoutTransitionInfoEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_HOST_IMAGE_LAYOUT_TRANSITION_INFO_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Image -> Image -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Image)) (Image
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
Ptr ImageLayout -> ImageLayout -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr ImageLayout)) (ImageLayout
forall a. Zero a => a
zero)
Ptr ImageSubresourceRange -> ImageSubresourceRange -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT
-> Int -> Ptr ImageSubresourceRange
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceRange)) (ImageSubresourceRange
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct HostImageLayoutTransitionInfoEXT where
peekCStruct :: Ptr HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT
peekCStruct Ptr HostImageLayoutTransitionInfoEXT
p = do
Image
image <- forall a. Storable a => Ptr a -> IO a
peek @Image ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr Image
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Image))
ImageLayout
oldLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr ImageLayout))
ImageLayout
newLayout <- forall a. Storable a => Ptr a -> IO a
peek @ImageLayout ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT -> Int -> Ptr ImageLayout
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr ImageLayout))
ImageSubresourceRange
subresourceRange <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageSubresourceRange ((Ptr HostImageLayoutTransitionInfoEXT
p Ptr HostImageLayoutTransitionInfoEXT
-> Int -> Ptr ImageSubresourceRange
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr ImageSubresourceRange))
HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT)
-> HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT
forall a b. (a -> b) -> a -> b
$ Image
-> ImageLayout
-> ImageLayout
-> ImageSubresourceRange
-> HostImageLayoutTransitionInfoEXT
HostImageLayoutTransitionInfoEXT
Image
image ImageLayout
oldLayout ImageLayout
newLayout ImageSubresourceRange
subresourceRange
instance Storable HostImageLayoutTransitionInfoEXT where
sizeOf :: HostImageLayoutTransitionInfoEXT -> Int
sizeOf ~HostImageLayoutTransitionInfoEXT
_ = Int
56
alignment :: HostImageLayoutTransitionInfoEXT -> Int
alignment ~HostImageLayoutTransitionInfoEXT
_ = Int
8
peek :: Ptr HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT
peek = Ptr HostImageLayoutTransitionInfoEXT
-> IO HostImageLayoutTransitionInfoEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO ()
poke Ptr HostImageLayoutTransitionInfoEXT
ptr HostImageLayoutTransitionInfoEXT
poked = Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO () -> IO ()
forall b.
Ptr HostImageLayoutTransitionInfoEXT
-> HostImageLayoutTransitionInfoEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr HostImageLayoutTransitionInfoEXT
ptr HostImageLayoutTransitionInfoEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero HostImageLayoutTransitionInfoEXT where
zero :: HostImageLayoutTransitionInfoEXT
zero = Image
-> ImageLayout
-> ImageLayout
-> ImageSubresourceRange
-> HostImageLayoutTransitionInfoEXT
HostImageLayoutTransitionInfoEXT
Image
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
ImageLayout
forall a. Zero a => a
zero
ImageSubresourceRange
forall a. Zero a => a
zero
data SubresourceHostMemcpySizeEXT = SubresourceHostMemcpySizeEXT
{
SubresourceHostMemcpySizeEXT -> DeviceSize
size :: DeviceSize }
deriving (Typeable, SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool
(SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool)
-> (SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool)
-> Eq SubresourceHostMemcpySizeEXT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool
== :: SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool
$c/= :: SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool
/= :: SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (SubresourceHostMemcpySizeEXT)
#endif
deriving instance Show SubresourceHostMemcpySizeEXT
instance ToCStruct SubresourceHostMemcpySizeEXT where
withCStruct :: forall b.
SubresourceHostMemcpySizeEXT
-> (Ptr SubresourceHostMemcpySizeEXT -> IO b) -> IO b
withCStruct SubresourceHostMemcpySizeEXT
x Ptr SubresourceHostMemcpySizeEXT -> IO b
f = Int -> (Ptr SubresourceHostMemcpySizeEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr SubresourceHostMemcpySizeEXT -> IO b) -> IO b)
-> (Ptr SubresourceHostMemcpySizeEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr SubresourceHostMemcpySizeEXT
p -> Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO b -> IO b
forall b.
Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr SubresourceHostMemcpySizeEXT
p SubresourceHostMemcpySizeEXT
x (Ptr SubresourceHostMemcpySizeEXT -> IO b
f Ptr SubresourceHostMemcpySizeEXT
p)
pokeCStruct :: forall b.
Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO b -> IO b
pokeCStruct Ptr SubresourceHostMemcpySizeEXT
p SubresourceHostMemcpySizeEXT{DeviceSize
$sel:size:SubresourceHostMemcpySizeEXT :: SubresourceHostMemcpySizeEXT -> DeviceSize
size :: DeviceSize
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_SUBRESOURCE_HOST_MEMCPY_SIZE_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr DeviceSize -> DeviceSize -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr DeviceSize
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr DeviceSize)) (DeviceSize
size)
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr SubresourceHostMemcpySizeEXT -> IO b -> IO b
pokeZeroCStruct Ptr SubresourceHostMemcpySizeEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_SUBRESOURCE_HOST_MEMCPY_SIZE_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr DeviceSize -> DeviceSize -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr DeviceSize
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr DeviceSize)) (DeviceSize
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct SubresourceHostMemcpySizeEXT where
peekCStruct :: Ptr SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT
peekCStruct Ptr SubresourceHostMemcpySizeEXT
p = do
DeviceSize
size <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr SubresourceHostMemcpySizeEXT
p Ptr SubresourceHostMemcpySizeEXT -> Int -> Ptr DeviceSize
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr DeviceSize))
SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT)
-> SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT
forall a b. (a -> b) -> a -> b
$ DeviceSize -> SubresourceHostMemcpySizeEXT
SubresourceHostMemcpySizeEXT
DeviceSize
size
instance Storable SubresourceHostMemcpySizeEXT where
sizeOf :: SubresourceHostMemcpySizeEXT -> Int
sizeOf ~SubresourceHostMemcpySizeEXT
_ = Int
24
alignment :: SubresourceHostMemcpySizeEXT -> Int
alignment ~SubresourceHostMemcpySizeEXT
_ = Int
8
peek :: Ptr SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT
peek = Ptr SubresourceHostMemcpySizeEXT -> IO SubresourceHostMemcpySizeEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO ()
poke Ptr SubresourceHostMemcpySizeEXT
ptr SubresourceHostMemcpySizeEXT
poked = Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO () -> IO ()
forall b.
Ptr SubresourceHostMemcpySizeEXT
-> SubresourceHostMemcpySizeEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr SubresourceHostMemcpySizeEXT
ptr SubresourceHostMemcpySizeEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero SubresourceHostMemcpySizeEXT where
zero :: SubresourceHostMemcpySizeEXT
zero = DeviceSize -> SubresourceHostMemcpySizeEXT
SubresourceHostMemcpySizeEXT
DeviceSize
forall a. Zero a => a
zero
data HostImageCopyDevicePerformanceQueryEXT = HostImageCopyDevicePerformanceQueryEXT
{
HostImageCopyDevicePerformanceQueryEXT -> Bool
optimalDeviceAccess :: Bool
,
HostImageCopyDevicePerformanceQueryEXT -> Bool
identicalMemoryLayout :: Bool
}
deriving (Typeable, HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool
(HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool)
-> (HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool)
-> Eq HostImageCopyDevicePerformanceQueryEXT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool
== :: HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool
$c/= :: HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool
/= :: HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (HostImageCopyDevicePerformanceQueryEXT)
#endif
deriving instance Show HostImageCopyDevicePerformanceQueryEXT
instance ToCStruct HostImageCopyDevicePerformanceQueryEXT where
withCStruct :: forall b.
HostImageCopyDevicePerformanceQueryEXT
-> (Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b) -> IO b
withCStruct HostImageCopyDevicePerformanceQueryEXT
x Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b
f = Int -> (Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b) -> IO b)
-> (Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr HostImageCopyDevicePerformanceQueryEXT
p -> Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO b -> IO b
forall b.
Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr HostImageCopyDevicePerformanceQueryEXT
p HostImageCopyDevicePerformanceQueryEXT
x (Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b
f Ptr HostImageCopyDevicePerformanceQueryEXT
p)
pokeCStruct :: forall b.
Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO b -> IO b
pokeCStruct Ptr HostImageCopyDevicePerformanceQueryEXT
p HostImageCopyDevicePerformanceQueryEXT{Bool
$sel:optimalDeviceAccess:HostImageCopyDevicePerformanceQueryEXT :: HostImageCopyDevicePerformanceQueryEXT -> Bool
$sel:identicalMemoryLayout:HostImageCopyDevicePerformanceQueryEXT :: HostImageCopyDevicePerformanceQueryEXT -> Bool
optimalDeviceAccess :: Bool
identicalMemoryLayout :: Bool
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
optimalDeviceAccess))
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
identicalMemoryLayout))
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b.
Ptr HostImageCopyDevicePerformanceQueryEXT -> IO b -> IO b
pokeZeroCStruct Ptr HostImageCopyDevicePerformanceQueryEXT
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_HOST_IMAGE_COPY_DEVICE_PERFORMANCE_QUERY_EXT)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
IO b
f
instance FromCStruct HostImageCopyDevicePerformanceQueryEXT where
peekCStruct :: Ptr HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT
peekCStruct Ptr HostImageCopyDevicePerformanceQueryEXT
p = do
Bool32
optimalDeviceAccess <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
Bool32
identicalMemoryLayout <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr HostImageCopyDevicePerformanceQueryEXT
p Ptr HostImageCopyDevicePerformanceQueryEXT -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32))
HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT)
-> HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT
forall a b. (a -> b) -> a -> b
$ Bool -> Bool -> HostImageCopyDevicePerformanceQueryEXT
HostImageCopyDevicePerformanceQueryEXT
(Bool32 -> Bool
bool32ToBool Bool32
optimalDeviceAccess)
(Bool32 -> Bool
bool32ToBool Bool32
identicalMemoryLayout)
instance Storable HostImageCopyDevicePerformanceQueryEXT where
sizeOf :: HostImageCopyDevicePerformanceQueryEXT -> Int
sizeOf ~HostImageCopyDevicePerformanceQueryEXT
_ = Int
24
alignment :: HostImageCopyDevicePerformanceQueryEXT -> Int
alignment ~HostImageCopyDevicePerformanceQueryEXT
_ = Int
8
peek :: Ptr HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT
peek = Ptr HostImageCopyDevicePerformanceQueryEXT
-> IO HostImageCopyDevicePerformanceQueryEXT
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO ()
poke Ptr HostImageCopyDevicePerformanceQueryEXT
ptr HostImageCopyDevicePerformanceQueryEXT
poked = Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO () -> IO ()
forall b.
Ptr HostImageCopyDevicePerformanceQueryEXT
-> HostImageCopyDevicePerformanceQueryEXT -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr HostImageCopyDevicePerformanceQueryEXT
ptr HostImageCopyDevicePerformanceQueryEXT
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero HostImageCopyDevicePerformanceQueryEXT where
zero :: HostImageCopyDevicePerformanceQueryEXT
zero = Bool -> Bool -> HostImageCopyDevicePerformanceQueryEXT
HostImageCopyDevicePerformanceQueryEXT
Bool
forall a. Zero a => a
zero
Bool
forall a. Zero a => a
zero
type HostImageCopyFlagsEXT = HostImageCopyFlagBitsEXT
newtype HostImageCopyFlagBitsEXT = HostImageCopyFlagBitsEXT Flags
deriving newtype (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
(HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> Eq HostImageCopyFlagsEXT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
== :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
$c/= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
/= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
Eq, Eq HostImageCopyFlagsEXT
Eq HostImageCopyFlagsEXT =>
(HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Ordering)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> Ord HostImageCopyFlagsEXT
HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Ordering
HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
forall a.
Eq a =>
(a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
$ccompare :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Ordering
compare :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Ordering
$c< :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
< :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
$c<= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
<= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
$c> :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
> :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
$c>= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
>= :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> Bool
$cmax :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
max :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
$cmin :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
min :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
Ord, Ptr HostImageCopyFlagsEXT -> IO HostImageCopyFlagsEXT
Ptr HostImageCopyFlagsEXT -> Int -> IO HostImageCopyFlagsEXT
Ptr HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT -> IO ()
Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
HostImageCopyFlagsEXT -> Int
(HostImageCopyFlagsEXT -> Int)
-> (HostImageCopyFlagsEXT -> Int)
-> (Ptr HostImageCopyFlagsEXT -> Int -> IO HostImageCopyFlagsEXT)
-> (Ptr HostImageCopyFlagsEXT
-> Int -> HostImageCopyFlagsEXT -> IO ())
-> (forall b. Ptr b -> Int -> IO HostImageCopyFlagsEXT)
-> (forall b. Ptr b -> Int -> HostImageCopyFlagsEXT -> IO ())
-> (Ptr HostImageCopyFlagsEXT -> IO HostImageCopyFlagsEXT)
-> (Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ())
-> Storable HostImageCopyFlagsEXT
forall b. Ptr b -> Int -> IO HostImageCopyFlagsEXT
forall b. Ptr b -> Int -> HostImageCopyFlagsEXT -> IO ()
forall a.
(a -> Int)
-> (a -> Int)
-> (Ptr a -> Int -> IO a)
-> (Ptr a -> Int -> a -> IO ())
-> (forall b. Ptr b -> Int -> IO a)
-> (forall b. Ptr b -> Int -> a -> IO ())
-> (Ptr a -> IO a)
-> (Ptr a -> a -> IO ())
-> Storable a
$csizeOf :: HostImageCopyFlagsEXT -> Int
sizeOf :: HostImageCopyFlagsEXT -> Int
$calignment :: HostImageCopyFlagsEXT -> Int
alignment :: HostImageCopyFlagsEXT -> Int
$cpeekElemOff :: Ptr HostImageCopyFlagsEXT -> Int -> IO HostImageCopyFlagsEXT
peekElemOff :: Ptr HostImageCopyFlagsEXT -> Int -> IO HostImageCopyFlagsEXT
$cpokeElemOff :: Ptr HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT -> IO ()
pokeElemOff :: Ptr HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT -> IO ()
$cpeekByteOff :: forall b. Ptr b -> Int -> IO HostImageCopyFlagsEXT
peekByteOff :: forall b. Ptr b -> Int -> IO HostImageCopyFlagsEXT
$cpokeByteOff :: forall b. Ptr b -> Int -> HostImageCopyFlagsEXT -> IO ()
pokeByteOff :: forall b. Ptr b -> Int -> HostImageCopyFlagsEXT -> IO ()
$cpeek :: Ptr HostImageCopyFlagsEXT -> IO HostImageCopyFlagsEXT
peek :: Ptr HostImageCopyFlagsEXT -> IO HostImageCopyFlagsEXT
$cpoke :: Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
poke :: Ptr HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT -> IO ()
Storable, HostImageCopyFlagsEXT
HostImageCopyFlagsEXT -> Zero HostImageCopyFlagsEXT
forall a. a -> Zero a
$czero :: HostImageCopyFlagsEXT
zero :: HostImageCopyFlagsEXT
Zero, Eq HostImageCopyFlagsEXT
HostImageCopyFlagsEXT
Eq HostImageCopyFlagsEXT =>
(HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> HostImageCopyFlagsEXT
-> (Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> Bool)
-> (HostImageCopyFlagsEXT -> Maybe Int)
-> (HostImageCopyFlagsEXT -> Int)
-> (HostImageCopyFlagsEXT -> Bool)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT)
-> (HostImageCopyFlagsEXT -> Int)
-> Bits HostImageCopyFlagsEXT
Int -> HostImageCopyFlagsEXT
HostImageCopyFlagsEXT -> Bool
HostImageCopyFlagsEXT -> Int
HostImageCopyFlagsEXT -> Maybe Int
HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
HostImageCopyFlagsEXT -> Int -> Bool
HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
forall a.
Eq a =>
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> a
-> (Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> Bool)
-> (a -> Maybe Int)
-> (a -> Int)
-> (a -> Bool)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int)
-> Bits a
$c.&. :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
.&. :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
$c.|. :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
.|. :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
$cxor :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
xor :: HostImageCopyFlagsEXT
-> HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
$ccomplement :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
complement :: HostImageCopyFlagsEXT -> HostImageCopyFlagsEXT
$cshift :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
shift :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$crotate :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
rotate :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$czeroBits :: HostImageCopyFlagsEXT
zeroBits :: HostImageCopyFlagsEXT
$cbit :: Int -> HostImageCopyFlagsEXT
bit :: Int -> HostImageCopyFlagsEXT
$csetBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
setBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$cclearBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
clearBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$ccomplementBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
complementBit :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$ctestBit :: HostImageCopyFlagsEXT -> Int -> Bool
testBit :: HostImageCopyFlagsEXT -> Int -> Bool
$cbitSizeMaybe :: HostImageCopyFlagsEXT -> Maybe Int
bitSizeMaybe :: HostImageCopyFlagsEXT -> Maybe Int
$cbitSize :: HostImageCopyFlagsEXT -> Int
bitSize :: HostImageCopyFlagsEXT -> Int
$cisSigned :: HostImageCopyFlagsEXT -> Bool
isSigned :: HostImageCopyFlagsEXT -> Bool
$cshiftL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
shiftL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$cunsafeShiftL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
unsafeShiftL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$cshiftR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
shiftR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$cunsafeShiftR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
unsafeShiftR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$crotateL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
rotateL :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$crotateR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
rotateR :: HostImageCopyFlagsEXT -> Int -> HostImageCopyFlagsEXT
$cpopCount :: HostImageCopyFlagsEXT -> Int
popCount :: HostImageCopyFlagsEXT -> Int
Bits, Bits HostImageCopyFlagsEXT
Bits HostImageCopyFlagsEXT =>
(HostImageCopyFlagsEXT -> Int)
-> (HostImageCopyFlagsEXT -> Int)
-> (HostImageCopyFlagsEXT -> Int)
-> FiniteBits HostImageCopyFlagsEXT
HostImageCopyFlagsEXT -> Int
forall b.
Bits b =>
(b -> Int) -> (b -> Int) -> (b -> Int) -> FiniteBits b
$cfiniteBitSize :: HostImageCopyFlagsEXT -> Int
finiteBitSize :: HostImageCopyFlagsEXT -> Int
$ccountLeadingZeros :: HostImageCopyFlagsEXT -> Int
countLeadingZeros :: HostImageCopyFlagsEXT -> Int
$ccountTrailingZeros :: HostImageCopyFlagsEXT -> Int
countTrailingZeros :: HostImageCopyFlagsEXT -> Int
FiniteBits)
pattern $bHOST_IMAGE_COPY_MEMCPY_EXT :: HostImageCopyFlagsEXT
$mHOST_IMAGE_COPY_MEMCPY_EXT :: forall {r}.
HostImageCopyFlagsEXT -> ((# #) -> r) -> ((# #) -> r) -> r
HOST_IMAGE_COPY_MEMCPY_EXT = HostImageCopyFlagBitsEXT 0x00000001
conNameHostImageCopyFlagBitsEXT :: String
conNameHostImageCopyFlagBitsEXT :: String
conNameHostImageCopyFlagBitsEXT = String
"HostImageCopyFlagBitsEXT"
enumPrefixHostImageCopyFlagBitsEXT :: String
enumPrefixHostImageCopyFlagBitsEXT :: String
enumPrefixHostImageCopyFlagBitsEXT = String
"HOST_IMAGE_COPY_MEMCPY_EXT"
showTableHostImageCopyFlagBitsEXT :: [(HostImageCopyFlagBitsEXT, String)]
showTableHostImageCopyFlagBitsEXT :: [(HostImageCopyFlagsEXT, String)]
showTableHostImageCopyFlagBitsEXT = [(HostImageCopyFlagsEXT
HOST_IMAGE_COPY_MEMCPY_EXT, String
"")]
instance Show HostImageCopyFlagBitsEXT where
showsPrec :: Int -> HostImageCopyFlagsEXT -> ShowS
showsPrec =
String
-> [(HostImageCopyFlagsEXT, String)]
-> String
-> (HostImageCopyFlagsEXT -> Flags)
-> (Flags -> ShowS)
-> Int
-> HostImageCopyFlagsEXT
-> ShowS
forall a i.
Eq a =>
String
-> [(a, String)]
-> String
-> (a -> i)
-> (i -> ShowS)
-> Int
-> a
-> ShowS
enumShowsPrec
String
enumPrefixHostImageCopyFlagBitsEXT
[(HostImageCopyFlagsEXT, String)]
showTableHostImageCopyFlagBitsEXT
String
conNameHostImageCopyFlagBitsEXT
(\(HostImageCopyFlagBitsEXT Flags
x) -> Flags
x)
(\Flags
x -> String -> ShowS
showString String
"0x" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Flags -> ShowS
forall a. Integral a => a -> ShowS
showHex Flags
x)
instance Read HostImageCopyFlagBitsEXT where
readPrec :: ReadPrec HostImageCopyFlagsEXT
readPrec =
String
-> [(HostImageCopyFlagsEXT, String)]
-> String
-> (Flags -> HostImageCopyFlagsEXT)
-> ReadPrec HostImageCopyFlagsEXT
forall i a.
Read i =>
String -> [(a, String)] -> String -> (i -> a) -> ReadPrec a
enumReadPrec
String
enumPrefixHostImageCopyFlagBitsEXT
[(HostImageCopyFlagsEXT, String)]
showTableHostImageCopyFlagBitsEXT
String
conNameHostImageCopyFlagBitsEXT
Flags -> HostImageCopyFlagsEXT
HostImageCopyFlagBitsEXT
type ImageSubresource2EXT = ImageSubresource2KHR
type SubresourceLayout2EXT = SubresourceLayout2KHR
type EXT_HOST_IMAGE_COPY_SPEC_VERSION = 1
pattern EXT_HOST_IMAGE_COPY_SPEC_VERSION :: forall a . Integral a => a
pattern $bEXT_HOST_IMAGE_COPY_SPEC_VERSION :: forall a. Integral a => a
$mEXT_HOST_IMAGE_COPY_SPEC_VERSION :: forall {r} {a}.
Integral a =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
EXT_HOST_IMAGE_COPY_SPEC_VERSION = 1
type EXT_HOST_IMAGE_COPY_EXTENSION_NAME = "VK_EXT_host_image_copy"
pattern EXT_HOST_IMAGE_COPY_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $bEXT_HOST_IMAGE_COPY_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
$mEXT_HOST_IMAGE_COPY_EXTENSION_NAME :: forall {r} {a}.
(Eq a, IsString a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
EXT_HOST_IMAGE_COPY_EXTENSION_NAME = "VK_EXT_host_image_copy"