#include "vulkan/vulkan.h" {-# LANGUAGE DataKinds #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE MagicHash #-} {-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE Strict #-} {-# LANGUAGE TypeFamilies #-} module Graphics.Vulkan.Types.Struct.VkImagePlaneMemoryRequirementsInfoKHR (VkImagePlaneMemoryRequirementsInfoKHR(..)) where import Foreign.Storable (Storable (..)) import GHC.Prim import Graphics.Vulkan.Marshal import Graphics.Vulkan.Marshal.Internal import Graphics.Vulkan.Types.Enum.VkImageAspectFlags (VkImageAspectFlagBits) import Graphics.Vulkan.Types.Enum.VkStructureType (VkStructureType) import Graphics.Vulkan.Types.Struct.VkImageMemoryRequirementsInfo2KHR (VkImageMemoryRequirementsInfo2KHR) import Graphics.Vulkan.Types.StructMembers import System.IO.Unsafe (unsafeDupablePerformIO) -- | > typedef struct VkImagePlaneMemoryRequirementsInfoKHR { -- > VkStructureType sType; -- > const void* pNext; -- > VkImageAspectFlagBits planeAspect; -- > } VkImagePlaneMemoryRequirementsInfoKHR; -- -- data VkImagePlaneMemoryRequirementsInfoKHR = VkImagePlaneMemoryRequirementsInfoKHR## Addr## ByteArray## instance Eq VkImagePlaneMemoryRequirementsInfoKHR where (VkImagePlaneMemoryRequirementsInfoKHR## a _) == x@(VkImagePlaneMemoryRequirementsInfoKHR## b _) = EQ == cmpBytes## (sizeOf x) a b {-# INLINE (==) #-} instance Ord VkImagePlaneMemoryRequirementsInfoKHR where (VkImagePlaneMemoryRequirementsInfoKHR## a _) `compare` x@(VkImagePlaneMemoryRequirementsInfoKHR## b _) = cmpBytes## (sizeOf x) a b {-# INLINE compare #-} instance Storable VkImagePlaneMemoryRequirementsInfoKHR where sizeOf ~_ = #{size VkImagePlaneMemoryRequirementsInfoKHR} {-# INLINE sizeOf #-} alignment ~_ = #{alignment VkImagePlaneMemoryRequirementsInfoKHR} {-# INLINE alignment #-} peek = peekVkData## {-# INLINE peek #-} poke = pokeVkData## {-# INLINE poke #-} instance VulkanMarshalPrim VkImagePlaneMemoryRequirementsInfoKHR where unsafeAddr (VkImagePlaneMemoryRequirementsInfoKHR## a _) = a {-# INLINE unsafeAddr #-} unsafeByteArray (VkImagePlaneMemoryRequirementsInfoKHR## _ b) = b {-# INLINE unsafeByteArray #-} unsafeFromByteArrayOffset off b = VkImagePlaneMemoryRequirementsInfoKHR## (plusAddr## (byteArrayContents## b) off) b {-# INLINE unsafeFromByteArrayOffset #-} instance VulkanMarshal VkImagePlaneMemoryRequirementsInfoKHR where type StructFields VkImagePlaneMemoryRequirementsInfoKHR = '["sType", "pNext", "planeAspect"] -- ' closing tick for hsc2hs type CUnionType VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs type ReturnedOnly VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs type StructExtends VkImagePlaneMemoryRequirementsInfoKHR = '[VkImageMemoryRequirementsInfo2KHR] -- ' closing tick for hsc2hs instance {-# OVERLAPPING #-} HasVkSType VkImagePlaneMemoryRequirementsInfoKHR where type VkSTypeMType VkImagePlaneMemoryRequirementsInfoKHR = VkStructureType {-# NOINLINE vkSType #-} vkSType x = unsafeDupablePerformIO (peekByteOff (unsafePtr x) #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType}) {-# INLINE vkSTypeByteOffset #-} vkSTypeByteOffset ~_ = #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType} {-# INLINE readVkSType #-} readVkSType p = peekByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType} {-# INLINE writeVkSType #-} writeVkSType p = pokeByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType} instance {-# OVERLAPPING #-} HasField "sType" VkImagePlaneMemoryRequirementsInfoKHR where type FieldType "sType" VkImagePlaneMemoryRequirementsInfoKHR = VkStructureType type FieldOptional "sType" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs type FieldOffset "sType" VkImagePlaneMemoryRequirementsInfoKHR = #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType} type FieldIsArray "sType" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs {-# INLINE fieldOptional #-} fieldOptional = False {-# INLINE fieldOffset #-} fieldOffset = #{offset VkImagePlaneMemoryRequirementsInfoKHR, sType} instance CanReadField "sType" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE getField #-} getField = vkSType {-# INLINE readField #-} readField = readVkSType instance CanWriteField "sType" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE writeField #-} writeField = writeVkSType instance {-# OVERLAPPING #-} HasVkPNext VkImagePlaneMemoryRequirementsInfoKHR where type VkPNextMType VkImagePlaneMemoryRequirementsInfoKHR = Ptr Void {-# NOINLINE vkPNext #-} vkPNext x = unsafeDupablePerformIO (peekByteOff (unsafePtr x) #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext}) {-# INLINE vkPNextByteOffset #-} vkPNextByteOffset ~_ = #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext} {-# INLINE readVkPNext #-} readVkPNext p = peekByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext} {-# INLINE writeVkPNext #-} writeVkPNext p = pokeByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext} instance {-# OVERLAPPING #-} HasField "pNext" VkImagePlaneMemoryRequirementsInfoKHR where type FieldType "pNext" VkImagePlaneMemoryRequirementsInfoKHR = Ptr Void type FieldOptional "pNext" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs type FieldOffset "pNext" VkImagePlaneMemoryRequirementsInfoKHR = #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext} type FieldIsArray "pNext" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs {-# INLINE fieldOptional #-} fieldOptional = False {-# INLINE fieldOffset #-} fieldOffset = #{offset VkImagePlaneMemoryRequirementsInfoKHR, pNext} instance CanReadField "pNext" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE getField #-} getField = vkPNext {-# INLINE readField #-} readField = readVkPNext instance CanWriteField "pNext" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE writeField #-} writeField = writeVkPNext instance {-# OVERLAPPING #-} HasVkPlaneAspect VkImagePlaneMemoryRequirementsInfoKHR where type VkPlaneAspectMType VkImagePlaneMemoryRequirementsInfoKHR = VkImageAspectFlagBits {-# NOINLINE vkPlaneAspect #-} vkPlaneAspect x = unsafeDupablePerformIO (peekByteOff (unsafePtr x) #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect}) {-# INLINE vkPlaneAspectByteOffset #-} vkPlaneAspectByteOffset ~_ = #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect} {-# INLINE readVkPlaneAspect #-} readVkPlaneAspect p = peekByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect} {-# INLINE writeVkPlaneAspect #-} writeVkPlaneAspect p = pokeByteOff p #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect} instance {-# OVERLAPPING #-} HasField "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR where type FieldType "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR = VkImageAspectFlagBits type FieldOptional "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs type FieldOffset "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR = #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect} type FieldIsArray "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR = 'False -- ' closing tick for hsc2hs {-# INLINE fieldOptional #-} fieldOptional = False {-# INLINE fieldOffset #-} fieldOffset = #{offset VkImagePlaneMemoryRequirementsInfoKHR, planeAspect} instance CanReadField "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE getField #-} getField = vkPlaneAspect {-# INLINE readField #-} readField = readVkPlaneAspect instance CanWriteField "planeAspect" VkImagePlaneMemoryRequirementsInfoKHR where {-# INLINE writeField #-} writeField = writeVkPlaneAspect instance Show VkImagePlaneMemoryRequirementsInfoKHR where showsPrec d x = showString "VkImagePlaneMemoryRequirementsInfoKHR {" . showString "vkSType = " . showsPrec d (vkSType x) . showString ", " . showString "vkPNext = " . showsPrec d (vkPNext x) . showString ", " . showString "vkPlaneAspect = " . showsPrec d (vkPlaneAspect x) . showChar '}'