{-# LINE 1 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE Strict #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
module Graphics.Vulkan.Types.Struct.EventCreateInfo
(VkEventCreateInfo(..)) 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.Bitmasks (VkEventCreateFlags)
import Graphics.Vulkan.Types.Enum.StructureType (VkStructureType)
import System.IO.Unsafe (unsafeDupablePerformIO)
data VkEventCreateInfo = VkEventCreateInfo# Addr# ByteArray#
instance Eq VkEventCreateInfo where
(VkEventCreateInfo# Addr#
a ByteArray#
_) == :: VkEventCreateInfo -> VkEventCreateInfo -> Bool
== x :: VkEventCreateInfo
x@(VkEventCreateInfo# Addr#
b ByteArray#
_)
= Ordering
EQ Ordering -> Ordering -> Bool
forall a. Eq a => a -> a -> Bool
== Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkEventCreateInfo -> Int
forall a. Storable a => a -> Int
sizeOf VkEventCreateInfo
x) Addr#
a Addr#
b
{-# INLINE (==) #-}
instance Ord VkEventCreateInfo where
(VkEventCreateInfo# Addr#
a ByteArray#
_) compare :: VkEventCreateInfo -> VkEventCreateInfo -> Ordering
`compare` x :: VkEventCreateInfo
x@(VkEventCreateInfo# Addr#
b ByteArray#
_)
= Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkEventCreateInfo -> Int
forall a. Storable a => a -> Int
sizeOf VkEventCreateInfo
x) Addr#
a Addr#
b
{-# INLINE compare #-}
instance Storable VkEventCreateInfo where
sizeOf :: VkEventCreateInfo -> Int
sizeOf ~VkEventCreateInfo
_ = (Int
24)
{-# LINE 45 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# INLINE sizeOf #-}
alignment :: VkEventCreateInfo -> Int
alignment ~VkEventCreateInfo
_ = Int
8
{-# LINE 48 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# INLINE alignment #-}
peek :: Ptr VkEventCreateInfo -> IO VkEventCreateInfo
peek = Ptr VkEventCreateInfo -> IO VkEventCreateInfo
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> IO a
peekVkData#
{-# INLINE peek #-}
poke :: Ptr VkEventCreateInfo -> VkEventCreateInfo -> IO ()
poke = Ptr VkEventCreateInfo -> VkEventCreateInfo -> IO ()
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> a -> IO ()
pokeVkData#
{-# INLINE poke #-}
instance VulkanMarshalPrim VkEventCreateInfo where
unsafeAddr :: VkEventCreateInfo -> Addr#
unsafeAddr (VkEventCreateInfo# Addr#
a ByteArray#
_) = Addr#
a
{-# INLINE unsafeAddr #-}
unsafeByteArray :: VkEventCreateInfo -> ByteArray#
unsafeByteArray (VkEventCreateInfo# Addr#
_ ByteArray#
b) = ByteArray#
b
{-# INLINE unsafeByteArray #-}
unsafeFromByteArrayOffset :: Int# -> ByteArray# -> VkEventCreateInfo
unsafeFromByteArrayOffset Int#
off ByteArray#
b
= Addr# -> ByteArray# -> VkEventCreateInfo
VkEventCreateInfo# (Addr# -> Int# -> Addr#
plusAddr# (ByteArray# -> Addr#
byteArrayContents# ByteArray#
b) Int#
off) ByteArray#
b
{-# INLINE unsafeFromByteArrayOffset #-}
instance VulkanMarshal VkEventCreateInfo where
type StructFields VkEventCreateInfo = '["sType", "pNext", "flags"]
type CUnionType VkEventCreateInfo = 'False
type ReturnedOnly VkEventCreateInfo = 'False
type StructExtends VkEventCreateInfo = '[]
instance {-# OVERLAPPING #-} HasField "sType" VkEventCreateInfo
where
type FieldType "sType" VkEventCreateInfo = VkStructureType
type FieldOptional "sType" VkEventCreateInfo = 'False
type FieldOffset "sType" VkEventCreateInfo =
(0)
{-# LINE 81 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
type FieldIsArray "sType" VkEventCreateInfo = 'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
False
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset = (Int
0)
{-# LINE 88 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-} CanReadField "sType" VkEventCreateInfo
where
{-# NOINLINE getField #-}
getField :: VkEventCreateInfo -> FieldType "sType" VkEventCreateInfo
getField VkEventCreateInfo
x
= IO VkStructureType -> VkStructureType
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkEventCreateInfo -> Int -> IO VkStructureType
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkEventCreateInfo -> Ptr VkEventCreateInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkEventCreateInfo
x) (Int
0))
{-# LINE 95 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkEventCreateInfo -> IO (FieldType "sType" VkEventCreateInfo)
readField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> IO VkStructureType
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkEventCreateInfo
p (Int
0)
{-# LINE 99 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "sType" VkEventCreateInfo where
{-# INLINE writeField #-}
writeField :: Ptr VkEventCreateInfo
-> FieldType "sType" VkEventCreateInfo -> IO ()
writeField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> VkStructureType -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkEventCreateInfo
p (Int
0)
{-# LINE 105 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-} HasField "pNext" VkEventCreateInfo
where
type FieldType "pNext" VkEventCreateInfo = Ptr Void
type FieldOptional "pNext" VkEventCreateInfo = 'False
type FieldOffset "pNext" VkEventCreateInfo =
(8)
{-# LINE 112 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
type FieldIsArray "pNext" VkEventCreateInfo = 'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
False
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset = (Int
8)
{-# LINE 119 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-} CanReadField "pNext" VkEventCreateInfo
where
{-# NOINLINE getField #-}
getField :: VkEventCreateInfo -> FieldType "pNext" VkEventCreateInfo
getField VkEventCreateInfo
x
= IO (Ptr Void) -> Ptr Void
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkEventCreateInfo -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkEventCreateInfo -> Ptr VkEventCreateInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkEventCreateInfo
x) (Int
8))
{-# LINE 126 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkEventCreateInfo -> IO (FieldType "pNext" VkEventCreateInfo)
readField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkEventCreateInfo
p (Int
8)
{-# LINE 130 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "pNext" VkEventCreateInfo where
{-# INLINE writeField #-}
writeField :: Ptr VkEventCreateInfo
-> FieldType "pNext" VkEventCreateInfo -> IO ()
writeField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> Ptr Void -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkEventCreateInfo
p (Int
8)
{-# LINE 136 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-} HasField "flags" VkEventCreateInfo
where
type FieldType "flags" VkEventCreateInfo = VkEventCreateFlags
type FieldOptional "flags" VkEventCreateInfo = 'True
type FieldOffset "flags" VkEventCreateInfo =
(16)
{-# LINE 143 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
type FieldIsArray "flags" VkEventCreateInfo = 'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
True
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset = (Int
16)
{-# LINE 150 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-} CanReadField "flags" VkEventCreateInfo
where
{-# NOINLINE getField #-}
getField :: VkEventCreateInfo -> FieldType "flags" VkEventCreateInfo
getField VkEventCreateInfo
x
= IO VkEventCreateFlags -> VkEventCreateFlags
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkEventCreateInfo -> Int -> IO VkEventCreateFlags
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkEventCreateInfo -> Ptr VkEventCreateInfo
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkEventCreateInfo
x) (Int
16))
{-# LINE 157 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkEventCreateInfo -> IO (FieldType "flags" VkEventCreateInfo)
readField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> IO VkEventCreateFlags
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkEventCreateInfo
p (Int
16)
{-# LINE 161 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "flags" VkEventCreateInfo where
{-# INLINE writeField #-}
writeField :: Ptr VkEventCreateInfo
-> FieldType "flags" VkEventCreateInfo -> IO ()
writeField Ptr VkEventCreateInfo
p
= Ptr VkEventCreateInfo -> Int -> VkEventCreateFlags -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkEventCreateInfo
p (Int
16)
{-# LINE 167 "src-gen/Graphics/Vulkan/Types/Struct/EventCreateInfo.hsc" #-}
instance Show VkEventCreateInfo where
showsPrec :: Int -> VkEventCreateInfo -> ShowS
showsPrec Int
d VkEventCreateInfo
x
= String -> ShowS
showString String
"VkEventCreateInfo {" ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
String -> ShowS
showString String
"sType = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
Int -> VkStructureType -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkEventCreateInfo -> FieldType "sType" VkEventCreateInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"sType" VkEventCreateInfo
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
"pNext = " 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 (VkEventCreateInfo -> FieldType "pNext" VkEventCreateInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"pNext" VkEventCreateInfo
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
"flags = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
Int -> VkEventCreateFlags -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkEventCreateInfo -> FieldType "flags" VkEventCreateInfo
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"flags" VkEventCreateInfo
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> ShowS
showChar Char
'}'