module Graphics.Vulkan.Types.Struct.StencilOpState
(VkStencilOpState(..)) where
import Foreign.Storable (Storable (..))
import GHC.Base (Addr#, ByteArray#,
byteArrayContents#,
plusAddr#)
import Graphics.Vulkan.Marshal
import Graphics.Vulkan.Marshal.Internal
import Graphics.Vulkan.Types.Enum.CompareOp (VkCompareOp)
import Graphics.Vulkan.Types.Enum.Stencil (VkStencilOp)
import System.IO.Unsafe (unsafeDupablePerformIO)
data VkStencilOpState = VkStencilOpState# Addr# ByteArray#
instance Eq VkStencilOpState where
(VkStencilOpState# a _) == x@(VkStencilOpState# b _)
= EQ == cmpBytes# (sizeOf x) a b
instance Ord VkStencilOpState where
(VkStencilOpState# a _) `compare` x@(VkStencilOpState# b _)
= cmpBytes# (sizeOf x) a b
instance Storable VkStencilOpState where
sizeOf ~_ = (28)
alignment ~_ = (4)
peek = peekVkData#
poke = pokeVkData#
instance VulkanMarshalPrim VkStencilOpState where
unsafeAddr (VkStencilOpState# a _) = a
unsafeByteArray (VkStencilOpState# _ b) = b
unsafeFromByteArrayOffset off b
= VkStencilOpState# (plusAddr# (byteArrayContents# b) off) b
instance VulkanMarshal VkStencilOpState where
type StructFields VkStencilOpState =
'["failOp", "passOp", "depthFailOp", "compareOp", "compareMask",
"writeMask", "reference"]
type CUnionType VkStencilOpState = 'False
type ReturnedOnly VkStencilOpState = 'False
type StructExtends VkStencilOpState = '[]
instance HasField "failOp" VkStencilOpState
where
type FieldType "failOp" VkStencilOpState = VkStencilOp
type FieldOptional "failOp" VkStencilOpState = 'False
type FieldOffset "failOp" VkStencilOpState =
(0)
type FieldIsArray "failOp" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (0)
instance CanReadField "failOp" VkStencilOpState
where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (0))
readField p
= peekByteOff p (0)
instance
CanWriteField "failOp" VkStencilOpState where
writeField p
= pokeByteOff p (0)
instance HasField "passOp" VkStencilOpState
where
type FieldType "passOp" VkStencilOpState = VkStencilOp
type FieldOptional "passOp" VkStencilOpState = 'False
type FieldOffset "passOp" VkStencilOpState =
(4)
type FieldIsArray "passOp" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (4)
instance CanReadField "passOp" VkStencilOpState
where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (4))
readField p
= peekByteOff p (4)
instance
CanWriteField "passOp" VkStencilOpState where
writeField p
= pokeByteOff p (4)
instance
HasField "depthFailOp" VkStencilOpState where
type FieldType "depthFailOp" VkStencilOpState = VkStencilOp
type FieldOptional "depthFailOp" VkStencilOpState = 'False
type FieldOffset "depthFailOp" VkStencilOpState =
(8)
type FieldIsArray "depthFailOp" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (8)
instance
CanReadField "depthFailOp" VkStencilOpState where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (8))
readField p
= peekByteOff p (8)
instance
CanWriteField "depthFailOp" VkStencilOpState where
writeField p
= pokeByteOff p (8)
instance HasField "compareOp" VkStencilOpState
where
type FieldType "compareOp" VkStencilOpState = VkCompareOp
type FieldOptional "compareOp" VkStencilOpState = 'False
type FieldOffset "compareOp" VkStencilOpState =
(12)
type FieldIsArray "compareOp" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (12)
instance
CanReadField "compareOp" VkStencilOpState where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (12))
readField p
= peekByteOff p (12)
instance
CanWriteField "compareOp" VkStencilOpState where
writeField p
= pokeByteOff p (12)
instance
HasField "compareMask" VkStencilOpState where
type FieldType "compareMask" VkStencilOpState = Word32
type FieldOptional "compareMask" VkStencilOpState = 'False
type FieldOffset "compareMask" VkStencilOpState =
(16)
type FieldIsArray "compareMask" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (16)
instance
CanReadField "compareMask" VkStencilOpState where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (16))
readField p
= peekByteOff p (16)
instance
CanWriteField "compareMask" VkStencilOpState where
writeField p
= pokeByteOff p (16)
instance HasField "writeMask" VkStencilOpState
where
type FieldType "writeMask" VkStencilOpState = Word32
type FieldOptional "writeMask" VkStencilOpState = 'False
type FieldOffset "writeMask" VkStencilOpState =
(20)
type FieldIsArray "writeMask" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (20)
instance
CanReadField "writeMask" VkStencilOpState where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (20))
readField p
= peekByteOff p (20)
instance
CanWriteField "writeMask" VkStencilOpState where
writeField p
= pokeByteOff p (20)
instance HasField "reference" VkStencilOpState
where
type FieldType "reference" VkStencilOpState = Word32
type FieldOptional "reference" VkStencilOpState = 'False
type FieldOffset "reference" VkStencilOpState =
(24)
type FieldIsArray "reference" VkStencilOpState = 'False
fieldOptional = False
fieldOffset = (24)
instance
CanReadField "reference" VkStencilOpState where
getField x
= unsafeDupablePerformIO
(peekByteOff (unsafePtr x) (24))
readField p
= peekByteOff p (24)
instance
CanWriteField "reference" VkStencilOpState where
writeField p
= pokeByteOff p (24)
instance Show VkStencilOpState where
showsPrec d x
= showString "VkStencilOpState {" .
showString "failOp = " .
showsPrec d (getField @"failOp" x) .
showString ", " .
showString "passOp = " .
showsPrec d (getField @"passOp" x) .
showString ", " .
showString "depthFailOp = " .
showsPrec d (getField @"depthFailOp" x) .
showString ", " .
showString "compareOp = " .
showsPrec d (getField @"compareOp" x) .
showString ", " .
showString "compareMask = " .
showsPrec d (getField @"compareMask" x) .
showString ", " .
showString "writeMask = " .
showsPrec d (getField @"writeMask" x) .
showString ", " .
showString "reference = " .
showsPrec d (getField @"reference" x) .
showChar '}'