{-# LINE 1 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}


{-# LANGUAGE DataKinds             #-}
{-# LANGUAGE FlexibleInstances     #-}
{-# LANGUAGE MagicHash             #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE Strict                #-}
{-# LANGUAGE TypeApplications      #-}
{-# LANGUAGE TypeFamilies          #-}
module Graphics.Vulkan.Types.Struct.Specialization
       (VkSpecializationInfo(..), VkSpecializationMapEntry(..)) where
import           Foreign.Storable                 (Storable (..))
import           GHC.Base                         (Addr#, ByteArray#,
                                                   byteArrayContents#,
                                                   plusAddr#)
import           Graphics.Vulkan.Marshal
import           Graphics.Vulkan.Marshal.Internal
import           System.IO.Unsafe                 (unsafeDupablePerformIO)

-- | > typedef struct VkSpecializationInfo {
--   >     uint32_t               mapEntryCount;
--   >     const VkSpecializationMapEntry* pMapEntries;
--   >     size_t                 dataSize;
--   >     const void*            pData;
--   > } VkSpecializationInfo;
--
--   <https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VkSpecializationInfo VkSpecializationInfo registry at www.khronos.org>
data VkSpecializationInfo = VkSpecializationInfo# Addr# ByteArray#

instance Eq VkSpecializationInfo where
        (VkSpecializationInfo# Addr#
a ByteArray#
_) == :: VkSpecializationInfo -> VkSpecializationInfo -> Bool
== x :: VkSpecializationInfo
x@(VkSpecializationInfo# Addr#
b ByteArray#
_)
          = Ordering
EQ Ordering -> Ordering -> Bool
forall a. Eq a => a -> a -> Bool
== Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSpecializationInfo -> Int
forall a. Storable a => a -> Int
sizeOf VkSpecializationInfo
x) Addr#
a Addr#
b

        {-# INLINE (==) #-}

instance Ord VkSpecializationInfo where
        (VkSpecializationInfo# Addr#
a ByteArray#
_) compare :: VkSpecializationInfo -> VkSpecializationInfo -> Ordering
`compare` x :: VkSpecializationInfo
x@(VkSpecializationInfo# Addr#
b ByteArray#
_)
          = Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSpecializationInfo -> Int
forall a. Storable a => a -> Int
sizeOf VkSpecializationInfo
x) Addr#
a Addr#
b

        {-# INLINE compare #-}

instance Storable VkSpecializationInfo where
        sizeOf :: VkSpecializationInfo -> Int
sizeOf ~VkSpecializationInfo
_ = (Int
32)
{-# LINE 44 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE sizeOf #-}
        alignment :: VkSpecializationInfo -> Int
alignment ~VkSpecializationInfo
_ = Int
8
{-# LINE 47 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE alignment #-}
        peek :: Ptr VkSpecializationInfo -> IO VkSpecializationInfo
peek = Ptr VkSpecializationInfo -> IO VkSpecializationInfo
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> IO a
peekVkData#

        {-# INLINE peek #-}
        poke :: Ptr VkSpecializationInfo -> VkSpecializationInfo -> IO ()
poke = Ptr VkSpecializationInfo -> VkSpecializationInfo -> IO ()
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> a -> IO ()
pokeVkData#

        {-# INLINE poke #-}

instance VulkanMarshalPrim VkSpecializationInfo where
        unsafeAddr :: VkSpecializationInfo -> Addr#
unsafeAddr (VkSpecializationInfo# Addr#
a ByteArray#
_) = Addr#
a

        {-# INLINE unsafeAddr #-}
        unsafeByteArray :: VkSpecializationInfo -> ByteArray#
unsafeByteArray (VkSpecializationInfo# Addr#
_ ByteArray#
b) = ByteArray#
b

        {-# INLINE unsafeByteArray #-}
        unsafeFromByteArrayOffset :: Int# -> ByteArray# -> VkSpecializationInfo
unsafeFromByteArrayOffset Int#
off ByteArray#
b
          = Addr# -> ByteArray# -> VkSpecializationInfo
VkSpecializationInfo# (Addr# -> Int# -> Addr#
plusAddr# (ByteArray# -> Addr#
byteArrayContents# ByteArray#
b) Int#
off) ByteArray#
b

        {-# INLINE unsafeFromByteArrayOffset #-}

instance VulkanMarshal VkSpecializationInfo where
        type StructFields VkSpecializationInfo =
             '["mapEntryCount", "pMapEntries", "dataSize", "pData"] -- ' closing tick for hsc2hs
        type CUnionType VkSpecializationInfo = 'False -- ' closing tick for hsc2hs
        type ReturnedOnly VkSpecializationInfo = 'False -- ' closing tick for hsc2hs
        type StructExtends VkSpecializationInfo = '[] -- ' closing tick for hsc2hs

instance {-# OVERLAPPING #-}
         HasField "mapEntryCount" VkSpecializationInfo where
        type FieldType "mapEntryCount" VkSpecializationInfo = Word32
        type FieldOptional "mapEntryCount" VkSpecializationInfo = 'True -- ' closing tick for hsc2hs
        type FieldOffset "mapEntryCount" VkSpecializationInfo =
             (0)
{-# LINE 81 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "mapEntryCount" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
True

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
0)
{-# LINE 89 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "mapEntryCount" VkSpecializationInfo where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationInfo
-> FieldType "mapEntryCount" VkSpecializationInfo
getField VkSpecializationInfo
x
          = IO Word32 -> Word32
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationInfo -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationInfo -> Ptr VkSpecializationInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationInfo
x) (Int
0))
{-# LINE 96 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationInfo
-> IO (FieldType "mapEntryCount" VkSpecializationInfo)
readField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationInfo
p (Int
0)
{-# LINE 100 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "mapEntryCount" VkSpecializationInfo where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationInfo
-> FieldType "mapEntryCount" VkSpecializationInfo -> IO ()
writeField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationInfo
p (Int
0)
{-# LINE 106 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "pMapEntries" VkSpecializationInfo where
        type FieldType "pMapEntries" VkSpecializationInfo =
             Ptr VkSpecializationMapEntry
        type FieldOptional "pMapEntries" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs
        type FieldOffset "pMapEntries" VkSpecializationInfo =
             (8)
{-# LINE 114 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "pMapEntries" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
False

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
8)
{-# LINE 122 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "pMapEntries" VkSpecializationInfo where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationInfo
-> FieldType "pMapEntries" VkSpecializationInfo
getField VkSpecializationInfo
x
          = IO (Ptr VkSpecializationMapEntry) -> Ptr VkSpecializationMapEntry
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationInfo
-> Int -> IO (Ptr VkSpecializationMapEntry)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationInfo -> Ptr VkSpecializationInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationInfo
x) (Int
8))
{-# LINE 129 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationInfo
-> IO (FieldType "pMapEntries" VkSpecializationInfo)
readField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo
-> Int -> IO (Ptr VkSpecializationMapEntry)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationInfo
p (Int
8)
{-# LINE 133 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "pMapEntries" VkSpecializationInfo where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationInfo
-> FieldType "pMapEntries" VkSpecializationInfo -> IO ()
writeField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo
-> Int -> Ptr VkSpecializationMapEntry -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationInfo
p (Int
8)
{-# LINE 139 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "dataSize" VkSpecializationInfo where
        type FieldType "dataSize" VkSpecializationInfo = CSize
        type FieldOptional "dataSize" VkSpecializationInfo = 'True -- ' closing tick for hsc2hs
        type FieldOffset "dataSize" VkSpecializationInfo =
             (16)
{-# LINE 146 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "dataSize" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
True

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset = (Int
16)
{-# LINE 153 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "dataSize" VkSpecializationInfo where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationInfo -> FieldType "dataSize" VkSpecializationInfo
getField VkSpecializationInfo
x
          = IO CSize -> CSize
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationInfo -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationInfo -> Ptr VkSpecializationInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationInfo
x) (Int
16))
{-# LINE 160 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationInfo
-> IO (FieldType "dataSize" VkSpecializationInfo)
readField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationInfo
p (Int
16)
{-# LINE 164 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "dataSize" VkSpecializationInfo where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationInfo
-> FieldType "dataSize" VkSpecializationInfo -> IO ()
writeField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> CSize -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationInfo
p (Int
16)
{-# LINE 170 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-} HasField "pData" VkSpecializationInfo
         where
        type FieldType "pData" VkSpecializationInfo = Ptr Void
        type FieldOptional "pData" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs
        type FieldOffset "pData" VkSpecializationInfo =
             (24)
{-# LINE 177 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "pData" VkSpecializationInfo = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
False

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset = (Int
24)
{-# LINE 184 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "pData" VkSpecializationInfo where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationInfo -> FieldType "pData" VkSpecializationInfo
getField VkSpecializationInfo
x
          = IO (Ptr Void) -> Ptr Void
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationInfo -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationInfo -> Ptr VkSpecializationInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationInfo
x) (Int
24))
{-# LINE 191 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationInfo
-> IO (FieldType "pData" VkSpecializationInfo)
readField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationInfo
p (Int
24)
{-# LINE 195 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "pData" VkSpecializationInfo where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationInfo
-> FieldType "pData" VkSpecializationInfo -> IO ()
writeField Ptr VkSpecializationInfo
p
          = Ptr VkSpecializationInfo -> Int -> Ptr Void -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationInfo
p (Int
24)
{-# LINE 201 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance Show VkSpecializationInfo where
        showsPrec :: Int -> VkSpecializationInfo -> ShowS
showsPrec Int
d VkSpecializationInfo
x
          = String -> ShowS
showString String
"VkSpecializationInfo {" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
              String -> ShowS
showString String
"mapEntryCount = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                Int -> Word32 -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationInfo
-> FieldType "mapEntryCount" VkSpecializationInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"mapEntryCount" VkSpecializationInfo
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                  String -> ShowS
showString String
", " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                    String -> ShowS
showString String
"pMapEntries = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                      Int -> Ptr VkSpecializationMapEntry -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationInfo
-> FieldType "pMapEntries" VkSpecializationInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"pMapEntries" VkSpecializationInfo
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                        String -> ShowS
showString String
", " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                          String -> ShowS
showString String
"dataSize = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                            Int -> CSize -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationInfo -> FieldType "dataSize" VkSpecializationInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"dataSize" VkSpecializationInfo
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                              String -> ShowS
showString String
", " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                                String -> ShowS
showString String
"pData = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                                  Int -> Ptr Void -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationInfo -> FieldType "pData" VkSpecializationInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"pData" VkSpecializationInfo
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> ShowS
showChar Char
'}'

-- | > typedef struct VkSpecializationMapEntry {
--   >     uint32_t               constantID;
--   >     uint32_t               offset;
--   >     size_t                 size;
--   > } VkSpecializationMapEntry;
--
--   <https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VkSpecializationMapEntry VkSpecializationMapEntry registry at www.khronos.org>
data VkSpecializationMapEntry = VkSpecializationMapEntry# Addr#
                                                          ByteArray#

instance Eq VkSpecializationMapEntry where
        (VkSpecializationMapEntry# Addr#
a ByteArray#
_) == :: VkSpecializationMapEntry -> VkSpecializationMapEntry -> Bool
==
          x :: VkSpecializationMapEntry
x@(VkSpecializationMapEntry# Addr#
b ByteArray#
_) = Ordering
EQ Ordering -> Ordering -> Bool
forall a. Eq a => a -> a -> Bool
== Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSpecializationMapEntry -> Int
forall a. Storable a => a -> Int
sizeOf VkSpecializationMapEntry
x) Addr#
a Addr#
b

        {-# INLINE (==) #-}

instance Ord VkSpecializationMapEntry where
        (VkSpecializationMapEntry# Addr#
a ByteArray#
_) compare :: VkSpecializationMapEntry -> VkSpecializationMapEntry -> Ordering
`compare`
          x :: VkSpecializationMapEntry
x@(VkSpecializationMapEntry# Addr#
b ByteArray#
_) = Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSpecializationMapEntry -> Int
forall a. Storable a => a -> Int
sizeOf VkSpecializationMapEntry
x) Addr#
a Addr#
b

        {-# INLINE compare #-}

instance Storable VkSpecializationMapEntry where
        sizeOf :: VkSpecializationMapEntry -> Int
sizeOf ~VkSpecializationMapEntry
_ = (Int
16)
{-# LINE 241 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE sizeOf #-}
        alignment :: VkSpecializationMapEntry -> Int
alignment ~VkSpecializationMapEntry
_ = Int
8
{-# LINE 244 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE alignment #-}
        peek :: Ptr VkSpecializationMapEntry -> IO VkSpecializationMapEntry
peek = Ptr VkSpecializationMapEntry -> IO VkSpecializationMapEntry
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> IO a
peekVkData#

        {-# INLINE peek #-}
        poke :: Ptr VkSpecializationMapEntry -> VkSpecializationMapEntry -> IO ()
poke = Ptr VkSpecializationMapEntry -> VkSpecializationMapEntry -> IO ()
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> a -> IO ()
pokeVkData#

        {-# INLINE poke #-}

instance VulkanMarshalPrim VkSpecializationMapEntry where
        unsafeAddr :: VkSpecializationMapEntry -> Addr#
unsafeAddr (VkSpecializationMapEntry# Addr#
a ByteArray#
_) = Addr#
a

        {-# INLINE unsafeAddr #-}
        unsafeByteArray :: VkSpecializationMapEntry -> ByteArray#
unsafeByteArray (VkSpecializationMapEntry# Addr#
_ ByteArray#
b) = ByteArray#
b

        {-# INLINE unsafeByteArray #-}
        unsafeFromByteArrayOffset :: Int# -> ByteArray# -> VkSpecializationMapEntry
unsafeFromByteArrayOffset Int#
off ByteArray#
b
          = Addr# -> ByteArray# -> VkSpecializationMapEntry
VkSpecializationMapEntry# (Addr# -> Int# -> Addr#
plusAddr# (ByteArray# -> Addr#
byteArrayContents# ByteArray#
b) Int#
off)
              ByteArray#
b

        {-# INLINE unsafeFromByteArrayOffset #-}

instance VulkanMarshal VkSpecializationMapEntry where
        type StructFields VkSpecializationMapEntry =
             '["constantID", "offset", "size"] -- ' closing tick for hsc2hs
        type CUnionType VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs
        type ReturnedOnly VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs
        type StructExtends VkSpecializationMapEntry = '[] -- ' closing tick for hsc2hs

instance {-# OVERLAPPING #-}
         HasField "constantID" VkSpecializationMapEntry where
        type FieldType "constantID" VkSpecializationMapEntry = Word32
        type FieldOptional "constantID" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs
        type FieldOffset "constantID" VkSpecializationMapEntry =
             (0)
{-# LINE 279 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "constantID" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
False

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
0)
{-# LINE 287 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "constantID" VkSpecializationMapEntry where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationMapEntry
-> FieldType "constantID" VkSpecializationMapEntry
getField VkSpecializationMapEntry
x
          = IO Word32 -> Word32
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationMapEntry -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationMapEntry -> Ptr VkSpecializationMapEntry
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationMapEntry
x) (Int
0))
{-# LINE 294 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationMapEntry
-> IO (FieldType "constantID" VkSpecializationMapEntry)
readField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationMapEntry
p (Int
0)
{-# LINE 298 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "constantID" VkSpecializationMapEntry where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationMapEntry
-> FieldType "constantID" VkSpecializationMapEntry -> IO ()
writeField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationMapEntry
p (Int
0)
{-# LINE 304 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "offset" VkSpecializationMapEntry where
        type FieldType "offset" VkSpecializationMapEntry = Word32
        type FieldOptional "offset" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs
        type FieldOffset "offset" VkSpecializationMapEntry =
             (4)
{-# LINE 311 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "offset" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
False

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
4)
{-# LINE 319 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "offset" VkSpecializationMapEntry where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationMapEntry
-> FieldType "offset" VkSpecializationMapEntry
getField VkSpecializationMapEntry
x
          = IO Word32 -> Word32
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationMapEntry -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationMapEntry -> Ptr VkSpecializationMapEntry
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationMapEntry
x) (Int
4))
{-# LINE 326 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationMapEntry
-> IO (FieldType "offset" VkSpecializationMapEntry)
readField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationMapEntry
p (Int
4)
{-# LINE 330 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "offset" VkSpecializationMapEntry where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationMapEntry
-> FieldType "offset" VkSpecializationMapEntry -> IO ()
writeField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationMapEntry
p (Int
4)
{-# LINE 336 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "size" VkSpecializationMapEntry where
        type FieldType "size" VkSpecializationMapEntry = CSize
        type FieldOptional "size" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs
        type FieldOffset "size" VkSpecializationMapEntry =
             (8)
{-# LINE 343 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}
        type FieldIsArray "size" VkSpecializationMapEntry = 'False -- ' closing tick for hsc2hs

        {-# INLINE fieldOptional #-}
        fieldOptional :: Bool
fieldOptional = Bool
False

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset = (Int
8)
{-# LINE 350 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "size" VkSpecializationMapEntry where
        {-# NOINLINE getField #-}
        getField :: VkSpecializationMapEntry
-> FieldType "size" VkSpecializationMapEntry
getField VkSpecializationMapEntry
x
          = IO CSize -> CSize
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkSpecializationMapEntry -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSpecializationMapEntry -> Ptr VkSpecializationMapEntry
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSpecializationMapEntry
x) (Int
8))
{-# LINE 357 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkSpecializationMapEntry
-> IO (FieldType "size" VkSpecializationMapEntry)
readField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSpecializationMapEntry
p (Int
8)
{-# LINE 361 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "size" VkSpecializationMapEntry where
        {-# INLINE writeField #-}
        writeField :: Ptr VkSpecializationMapEntry
-> FieldType "size" VkSpecializationMapEntry -> IO ()
writeField Ptr VkSpecializationMapEntry
p
          = Ptr VkSpecializationMapEntry -> Int -> CSize -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSpecializationMapEntry
p (Int
8)
{-# LINE 367 "src-gen/Graphics/Vulkan/Types/Struct/Specialization.hsc" #-}

instance Show VkSpecializationMapEntry where
        showsPrec :: Int -> VkSpecializationMapEntry -> ShowS
showsPrec Int
d VkSpecializationMapEntry
x
          = String -> ShowS
showString String
"VkSpecializationMapEntry {" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
              String -> ShowS
showString String
"constantID = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                Int -> Word32 -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationMapEntry
-> FieldType "constantID" VkSpecializationMapEntry
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"constantID" VkSpecializationMapEntry
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                  String -> ShowS
showString String
", " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                    String -> ShowS
showString String
"offset = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                      Int -> Word32 -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationMapEntry
-> FieldType "offset" VkSpecializationMapEntry
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"offset" VkSpecializationMapEntry
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                        String -> ShowS
showString String
", " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                          String -> ShowS
showString String
"size = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                            Int -> CSize -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSpecializationMapEntry
-> FieldType "size" VkSpecializationMapEntry
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"size" VkSpecializationMapEntry
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> ShowS
showChar Char
'}'