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


{-# LANGUAGE DataKinds             #-}
{-# LANGUAGE FlexibleInstances     #-}
{-# LANGUAGE MagicHash             #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE Strict                #-}
{-# LANGUAGE TypeApplications      #-}
{-# LANGUAGE TypeFamilies          #-}
module Graphics.Vulkan.Types.Struct.DispatchIndirectCommand
       (VkDispatchIndirectCommand(..)) 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 VkDispatchIndirectCommand {
--   >     uint32_t               x;
--   >     uint32_t               y;
--   >     uint32_t               z;
--   > } VkDispatchIndirectCommand;
--
--   <https://www.khronos.org/registry/vulkan/specs/1.1-extensions/html/vkspec.html#VkDispatchIndirectCommand VkDispatchIndirectCommand registry at www.khronos.org>
data VkDispatchIndirectCommand = VkDispatchIndirectCommand# Addr#
                                                            ByteArray#

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

        {-# INLINE (==) #-}

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

        {-# INLINE compare #-}

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

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

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

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

        {-# INLINE poke #-}

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

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

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

        {-# INLINE unsafeFromByteArrayOffset #-}

instance VulkanMarshal VkDispatchIndirectCommand where
        type StructFields VkDispatchIndirectCommand = '["x", "y", "z"] -- ' closing tick for hsc2hs
        type CUnionType VkDispatchIndirectCommand = 'False -- ' closing tick for hsc2hs
        type ReturnedOnly VkDispatchIndirectCommand = 'False -- ' closing tick for hsc2hs
        type StructExtends VkDispatchIndirectCommand = '[] -- ' closing tick for hsc2hs

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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