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


{-# LANGUAGE DataKinds             #-}
{-# LANGUAGE FlexibleInstances     #-}
{-# LANGUAGE MagicHash             #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE Strict                #-}
{-# LANGUAGE TypeApplications      #-}
{-# LANGUAGE TypeFamilies          #-}
module Graphics.Vulkan.Types.Struct.DrawInd
       (VkDrawIndexedIndirectCommand(..), VkDrawIndirectCommand(..)) 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 VkDrawIndexedIndirectCommand {
--   >     uint32_t               indexCount;
--   >     uint32_t               instanceCount;
--   >     uint32_t               firstIndex;
--   >     int32_t                vertexOffset;
--   >     uint32_t               firstInstance;
--   > } VkDrawIndexedIndirectCommand;
--
--   <https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VkDrawIndexedIndirectCommand VkDrawIndexedIndirectCommand registry at www.khronos.org>
data VkDrawIndexedIndirectCommand = VkDrawIndexedIndirectCommand# Addr#
                                                                  ByteArray#

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

        {-# INLINE (==) #-}

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

        {-# INLINE compare #-}

instance Storable VkDrawIndexedIndirectCommand where
        sizeOf :: VkDrawIndexedIndirectCommand -> Int
sizeOf ~VkDrawIndexedIndirectCommand
_ = (Int
20)
{-# LINE 47 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

        {-# INLINE sizeOf #-}
        alignment :: VkDrawIndexedIndirectCommand -> Int
alignment ~VkDrawIndexedIndirectCommand
_
          = Int
4
{-# LINE 51 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

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

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

        {-# INLINE poke #-}

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

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

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

        {-# INLINE unsafeFromByteArrayOffset #-}

instance VulkanMarshal VkDrawIndexedIndirectCommand where
        type StructFields VkDrawIndexedIndirectCommand =
             '["indexCount", "instanceCount", "firstIndex", "vertexOffset", -- ' closing tick for hsc2hs
               "firstInstance"]
        type CUnionType VkDrawIndexedIndirectCommand = 'False -- ' closing tick for hsc2hs
        type ReturnedOnly VkDrawIndexedIndirectCommand = 'False -- ' closing tick for hsc2hs
        type StructExtends VkDrawIndexedIndirectCommand = '[] -- ' closing tick for hsc2hs

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

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

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

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

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

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

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

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

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

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

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

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

instance {-# OVERLAPPING #-}
         HasField "firstIndex" VkDrawIndexedIndirectCommand where
        type FieldType "firstIndex" VkDrawIndexedIndirectCommand = Word32
        type FieldOptional "firstIndex" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs
        type FieldOffset "firstIndex" VkDrawIndexedIndirectCommand =
             (8)
{-# LINE 158 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}
        type FieldIsArray "firstIndex" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs

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

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

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

        {-# INLINE readField #-}
        readField :: Ptr VkDrawIndexedIndirectCommand
-> IO (FieldType "firstIndex" VkDrawIndexedIndirectCommand)
readField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
8)
{-# LINE 178 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "firstIndex" VkDrawIndexedIndirectCommand where
        {-# INLINE writeField #-}
        writeField :: Ptr VkDrawIndexedIndirectCommand
-> FieldType "firstIndex" VkDrawIndexedIndirectCommand -> IO ()
writeField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
8)
{-# LINE 184 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "vertexOffset" VkDrawIndexedIndirectCommand where
        type FieldType "vertexOffset" VkDrawIndexedIndirectCommand = Int32
        type FieldOptional "vertexOffset" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs
        type FieldOffset "vertexOffset" VkDrawIndexedIndirectCommand =
             (12)
{-# LINE 192 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}
        type FieldIsArray "vertexOffset" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs

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

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
12)
{-# LINE 201 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanReadField "vertexOffset" VkDrawIndexedIndirectCommand where
        {-# NOINLINE getField #-}
        getField :: VkDrawIndexedIndirectCommand
-> FieldType "vertexOffset" VkDrawIndexedIndirectCommand
getField VkDrawIndexedIndirectCommand
x
          = IO Int32 -> Int32
forall a. IO a -> a
unsafeDupablePerformIO
              (Ptr VkDrawIndexedIndirectCommand -> Int -> IO Int32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkDrawIndexedIndirectCommand -> Ptr VkDrawIndexedIndirectCommand
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkDrawIndexedIndirectCommand
x) (Int
12))
{-# LINE 208 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

        {-# INLINE readField #-}
        readField :: Ptr VkDrawIndexedIndirectCommand
-> IO (FieldType "vertexOffset" VkDrawIndexedIndirectCommand)
readField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> IO Int32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
12)
{-# LINE 212 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "vertexOffset" VkDrawIndexedIndirectCommand where
        {-# INLINE writeField #-}
        writeField :: Ptr VkDrawIndexedIndirectCommand
-> FieldType "vertexOffset" VkDrawIndexedIndirectCommand -> IO ()
writeField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> Int32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
12)
{-# LINE 218 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "firstInstance" VkDrawIndexedIndirectCommand where
        type FieldType "firstInstance" VkDrawIndexedIndirectCommand =
             Word32
        type FieldOptional "firstInstance" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs
        type FieldOffset "firstInstance" VkDrawIndexedIndirectCommand =
             (16)
{-# LINE 227 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}
        type FieldIsArray "firstInstance" VkDrawIndexedIndirectCommand =
             'False -- ' closing tick for hsc2hs

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

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

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

        {-# INLINE readField #-}
        readField :: Ptr VkDrawIndexedIndirectCommand
-> IO (FieldType "firstInstance" VkDrawIndexedIndirectCommand)
readField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
16)
{-# LINE 247 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "firstInstance" VkDrawIndexedIndirectCommand where
        {-# INLINE writeField #-}
        writeField :: Ptr VkDrawIndexedIndirectCommand
-> FieldType "firstInstance" VkDrawIndexedIndirectCommand -> IO ()
writeField Ptr VkDrawIndexedIndirectCommand
p
          = Ptr VkDrawIndexedIndirectCommand -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkDrawIndexedIndirectCommand
p (Int
16)
{-# LINE 253 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance Show VkDrawIndexedIndirectCommand where
        showsPrec :: Int -> VkDrawIndexedIndirectCommand -> ShowS
showsPrec Int
d VkDrawIndexedIndirectCommand
x
          = String -> ShowS
showString String
"VkDrawIndexedIndirectCommand {" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
              String -> ShowS
showString String
"indexCount = " 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 (VkDrawIndexedIndirectCommand
-> FieldType "indexCount" VkDrawIndexedIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"indexCount" VkDrawIndexedIndirectCommand
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
"instanceCount = " 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 (VkDrawIndexedIndirectCommand
-> FieldType "instanceCount" VkDrawIndexedIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"instanceCount" VkDrawIndexedIndirectCommand
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
"firstIndex = " 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 (VkDrawIndexedIndirectCommand
-> FieldType "firstIndex" VkDrawIndexedIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"firstIndex" VkDrawIndexedIndirectCommand
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
"vertexOffset = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
                                  Int -> Int32 -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkDrawIndexedIndirectCommand
-> FieldType "vertexOffset" VkDrawIndexedIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"vertexOffset" VkDrawIndexedIndirectCommand
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
"firstInstance = " 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 (VkDrawIndexedIndirectCommand
-> FieldType "firstInstance" VkDrawIndexedIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"firstInstance" VkDrawIndexedIndirectCommand
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> ShowS
showChar Char
'}'

-- | > typedef struct VkDrawIndirectCommand {
--   >     uint32_t               vertexCount;
--   >     uint32_t               instanceCount;
--   >     uint32_t               firstVertex;
--   >     uint32_t               firstInstance;
--   > } VkDrawIndirectCommand;
--
--   <https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VkDrawIndirectCommand VkDrawIndirectCommand registry at www.khronos.org>
data VkDrawIndirectCommand = VkDrawIndirectCommand# Addr#
                                                    ByteArray#

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

        {-# INLINE (==) #-}

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

        {-# INLINE compare #-}

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

        {-# INLINE sizeOf #-}
        alignment :: VkDrawIndirectCommand -> Int
alignment ~VkDrawIndirectCommand
_ = Int
4
{-# LINE 300 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

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

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

        {-# INLINE poke #-}

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

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

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

        {-# INLINE unsafeFromByteArrayOffset #-}

instance VulkanMarshal VkDrawIndirectCommand where
        type StructFields VkDrawIndirectCommand =
             '["vertexCount", "instanceCount", "firstVertex", "firstInstance"] -- ' closing tick for hsc2hs
        type CUnionType VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs
        type ReturnedOnly VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs
        type StructExtends VkDrawIndirectCommand = '[] -- ' closing tick for hsc2hs

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

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

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

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

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

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

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

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

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

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

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

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

instance {-# OVERLAPPING #-}
         HasField "firstVertex" VkDrawIndirectCommand where
        type FieldType "firstVertex" VkDrawIndirectCommand = Word32
        type FieldOptional "firstVertex" VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs
        type FieldOffset "firstVertex" VkDrawIndirectCommand =
             (8)
{-# LINE 398 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}
        type FieldIsArray "firstVertex" VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs

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

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

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

        {-# INLINE readField #-}
        readField :: Ptr VkDrawIndirectCommand
-> IO (FieldType "firstVertex" VkDrawIndirectCommand)
readField Ptr VkDrawIndirectCommand
p
          = Ptr VkDrawIndirectCommand -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkDrawIndirectCommand
p (Int
8)
{-# LINE 417 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "firstVertex" VkDrawIndirectCommand where
        {-# INLINE writeField #-}
        writeField :: Ptr VkDrawIndirectCommand
-> FieldType "firstVertex" VkDrawIndirectCommand -> IO ()
writeField Ptr VkDrawIndirectCommand
p
          = Ptr VkDrawIndirectCommand -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkDrawIndirectCommand
p (Int
8)
{-# LINE 423 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         HasField "firstInstance" VkDrawIndirectCommand where
        type FieldType "firstInstance" VkDrawIndirectCommand = Word32
        type FieldOptional "firstInstance" VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs
        type FieldOffset "firstInstance" VkDrawIndirectCommand =
             (12)
{-# LINE 430 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}
        type FieldIsArray "firstInstance" VkDrawIndirectCommand = 'False -- ' closing tick for hsc2hs

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

        {-# INLINE fieldOffset #-}
        fieldOffset :: Int
fieldOffset
          = (Int
12)
{-# LINE 438 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

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

        {-# INLINE readField #-}
        readField :: Ptr VkDrawIndirectCommand
-> IO (FieldType "firstInstance" VkDrawIndirectCommand)
readField Ptr VkDrawIndirectCommand
p
          = Ptr VkDrawIndirectCommand -> Int -> IO Word32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkDrawIndirectCommand
p (Int
12)
{-# LINE 449 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance {-# OVERLAPPING #-}
         CanWriteField "firstInstance" VkDrawIndirectCommand where
        {-# INLINE writeField #-}
        writeField :: Ptr VkDrawIndirectCommand
-> FieldType "firstInstance" VkDrawIndirectCommand -> IO ()
writeField Ptr VkDrawIndirectCommand
p
          = Ptr VkDrawIndirectCommand -> Int -> Word32 -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkDrawIndirectCommand
p (Int
12)
{-# LINE 455 "src-gen/Graphics/Vulkan/Types/Struct/DrawInd.hsc" #-}

instance Show VkDrawIndirectCommand where
        showsPrec :: Int -> VkDrawIndirectCommand -> ShowS
showsPrec Int
d VkDrawIndirectCommand
x
          = String -> ShowS
showString String
"VkDrawIndirectCommand {" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
              String -> ShowS
showString String
"vertexCount = " 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 (VkDrawIndirectCommand
-> FieldType "vertexCount" VkDrawIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"vertexCount" VkDrawIndirectCommand
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
"instanceCount = " 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 (VkDrawIndirectCommand
-> FieldType "instanceCount" VkDrawIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"instanceCount" VkDrawIndirectCommand
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
"firstVertex = " 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 (VkDrawIndirectCommand
-> FieldType "firstVertex" VkDrawIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"firstVertex" VkDrawIndirectCommand
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
"firstInstance = " 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 (VkDrawIndirectCommand
-> FieldType "firstInstance" VkDrawIndirectCommand
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"firstInstance" VkDrawIndirectCommand
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> ShowS
showChar Char
'}'