{-# LINE 1 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE Strict #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
module Graphics.Vulkan.Types.Struct.SharedPresentSurfaceCapabilitiesKHR
(VkSharedPresentSurfaceCapabilitiesKHR(..)) 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.Image (VkImageUsageFlags)
import Graphics.Vulkan.Types.Enum.StructureType (VkStructureType)
import Graphics.Vulkan.Types.Struct.Surface (VkSurfaceCapabilities2KHR)
import System.IO.Unsafe (unsafeDupablePerformIO)
data VkSharedPresentSurfaceCapabilitiesKHR = VkSharedPresentSurfaceCapabilitiesKHR# Addr#
ByteArray#
instance Eq VkSharedPresentSurfaceCapabilitiesKHR where
(VkSharedPresentSurfaceCapabilitiesKHR# Addr#
a ByteArray#
_) == :: VkSharedPresentSurfaceCapabilitiesKHR
-> VkSharedPresentSurfaceCapabilitiesKHR -> Bool
==
x :: VkSharedPresentSurfaceCapabilitiesKHR
x@(VkSharedPresentSurfaceCapabilitiesKHR# Addr#
b ByteArray#
_)
= Ordering
EQ Ordering -> Ordering -> Bool
forall a. Eq a => a -> a -> Bool
== Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSharedPresentSurfaceCapabilitiesKHR -> Int
forall a. Storable a => a -> Int
sizeOf VkSharedPresentSurfaceCapabilitiesKHR
x) Addr#
a Addr#
b
{-# INLINE (==) #-}
instance Ord VkSharedPresentSurfaceCapabilitiesKHR where
(VkSharedPresentSurfaceCapabilitiesKHR# Addr#
a ByteArray#
_) compare :: VkSharedPresentSurfaceCapabilitiesKHR
-> VkSharedPresentSurfaceCapabilitiesKHR -> Ordering
`compare`
x :: VkSharedPresentSurfaceCapabilitiesKHR
x@(VkSharedPresentSurfaceCapabilitiesKHR# Addr#
b ByteArray#
_)
= Int -> Addr# -> Addr# -> Ordering
cmpBytes# (VkSharedPresentSurfaceCapabilitiesKHR -> Int
forall a. Storable a => a -> Int
sizeOf VkSharedPresentSurfaceCapabilitiesKHR
x) Addr#
a Addr#
b
{-# INLINE compare #-}
instance Storable VkSharedPresentSurfaceCapabilitiesKHR where
sizeOf :: VkSharedPresentSurfaceCapabilitiesKHR -> Int
sizeOf ~VkSharedPresentSurfaceCapabilitiesKHR
_
= (Int
24)
{-# LINE 50 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# INLINE sizeOf #-}
alignment :: VkSharedPresentSurfaceCapabilitiesKHR -> Int
alignment ~VkSharedPresentSurfaceCapabilitiesKHR
_
= Int
8
{-# LINE 54 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# INLINE alignment #-}
peek :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> IO VkSharedPresentSurfaceCapabilitiesKHR
peek = Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> IO VkSharedPresentSurfaceCapabilitiesKHR
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> IO a
peekVkData#
{-# INLINE peek #-}
poke :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> VkSharedPresentSurfaceCapabilitiesKHR -> IO ()
poke = Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> VkSharedPresentSurfaceCapabilitiesKHR -> IO ()
forall a. (Storable a, VulkanMarshalPrim a) => Ptr a -> a -> IO ()
pokeVkData#
{-# INLINE poke #-}
instance VulkanMarshalPrim VkSharedPresentSurfaceCapabilitiesKHR
where
unsafeAddr :: VkSharedPresentSurfaceCapabilitiesKHR -> Addr#
unsafeAddr (VkSharedPresentSurfaceCapabilitiesKHR# Addr#
a ByteArray#
_) = Addr#
a
{-# INLINE unsafeAddr #-}
unsafeByteArray :: VkSharedPresentSurfaceCapabilitiesKHR -> ByteArray#
unsafeByteArray (VkSharedPresentSurfaceCapabilitiesKHR# Addr#
_ ByteArray#
b) = ByteArray#
b
{-# INLINE unsafeByteArray #-}
unsafeFromByteArrayOffset :: Int# -> ByteArray# -> VkSharedPresentSurfaceCapabilitiesKHR
unsafeFromByteArrayOffset Int#
off ByteArray#
b
= Addr# -> ByteArray# -> VkSharedPresentSurfaceCapabilitiesKHR
VkSharedPresentSurfaceCapabilitiesKHR#
(Addr# -> Int# -> Addr#
plusAddr# (ByteArray# -> Addr#
byteArrayContents# ByteArray#
b) Int#
off)
ByteArray#
b
{-# INLINE unsafeFromByteArrayOffset #-}
instance VulkanMarshal VkSharedPresentSurfaceCapabilitiesKHR where
type StructFields VkSharedPresentSurfaceCapabilitiesKHR =
'["sType", "pNext", "sharedPresentSupportedUsageFlags"]
type CUnionType VkSharedPresentSurfaceCapabilitiesKHR = 'False
type ReturnedOnly VkSharedPresentSurfaceCapabilitiesKHR = 'True
type StructExtends VkSharedPresentSurfaceCapabilitiesKHR =
'[VkSurfaceCapabilities2KHR]
instance {-# OVERLAPPING #-}
HasField "sType" VkSharedPresentSurfaceCapabilitiesKHR where
type FieldType "sType" VkSharedPresentSurfaceCapabilitiesKHR =
VkStructureType
type FieldOptional "sType" VkSharedPresentSurfaceCapabilitiesKHR =
'False
type FieldOffset "sType" VkSharedPresentSurfaceCapabilitiesKHR =
(0)
{-# LINE 94 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
type FieldIsArray "sType" VkSharedPresentSurfaceCapabilitiesKHR =
'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
False
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset
= (Int
0)
{-# LINE 103 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanReadField "sType" VkSharedPresentSurfaceCapabilitiesKHR where
{-# NOINLINE getField #-}
getField :: VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "sType" VkSharedPresentSurfaceCapabilitiesKHR
getField VkSharedPresentSurfaceCapabilitiesKHR
x
= IO VkStructureType -> VkStructureType
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> IO VkStructureType
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSharedPresentSurfaceCapabilitiesKHR
-> Ptr VkSharedPresentSurfaceCapabilitiesKHR
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSharedPresentSurfaceCapabilitiesKHR
x) (Int
0))
{-# LINE 110 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> IO (FieldType "sType" VkSharedPresentSurfaceCapabilitiesKHR)
readField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> IO VkStructureType
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
0)
{-# LINE 114 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "sType" VkSharedPresentSurfaceCapabilitiesKHR where
{-# INLINE writeField #-}
writeField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "sType" VkSharedPresentSurfaceCapabilitiesKHR -> IO ()
writeField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> VkStructureType -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
0)
{-# LINE 120 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
HasField "pNext" VkSharedPresentSurfaceCapabilitiesKHR where
type FieldType "pNext" VkSharedPresentSurfaceCapabilitiesKHR =
Ptr Void
type FieldOptional "pNext" VkSharedPresentSurfaceCapabilitiesKHR =
'False
type FieldOffset "pNext" VkSharedPresentSurfaceCapabilitiesKHR =
(8)
{-# LINE 129 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
type FieldIsArray "pNext" VkSharedPresentSurfaceCapabilitiesKHR =
'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
False
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset
= (Int
8)
{-# LINE 138 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanReadField "pNext" VkSharedPresentSurfaceCapabilitiesKHR where
{-# NOINLINE getField #-}
getField :: VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "pNext" VkSharedPresentSurfaceCapabilitiesKHR
getField VkSharedPresentSurfaceCapabilitiesKHR
x
= IO (Ptr Void) -> Ptr Void
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkSharedPresentSurfaceCapabilitiesKHR -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSharedPresentSurfaceCapabilitiesKHR
-> Ptr VkSharedPresentSurfaceCapabilitiesKHR
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSharedPresentSurfaceCapabilitiesKHR
x) (Int
8))
{-# LINE 145 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> IO (FieldType "pNext" VkSharedPresentSurfaceCapabilitiesKHR)
readField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR -> Int -> IO (Ptr Void)
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
8)
{-# LINE 149 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "pNext" VkSharedPresentSurfaceCapabilitiesKHR where
{-# INLINE writeField #-}
writeField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "pNext" VkSharedPresentSurfaceCapabilitiesKHR -> IO ()
writeField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> Ptr Void -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
8)
{-# LINE 155 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
HasField "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
where
type FieldType "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
= VkImageUsageFlags
type FieldOptional "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
= 'True
type FieldOffset "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
=
(16)
{-# LINE 170 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
type FieldIsArray "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
= 'False
{-# INLINE fieldOptional #-}
fieldOptional :: Bool
fieldOptional = Bool
True
{-# INLINE fieldOffset #-}
fieldOffset :: Int
fieldOffset
= (Int
16)
{-# LINE 180 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanReadField "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
where
{-# NOINLINE getField #-}
getField :: VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType
"sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
getField VkSharedPresentSurfaceCapabilitiesKHR
x
= IO VkImageUsageFlags -> VkImageUsageFlags
forall a. IO a -> a
unsafeDupablePerformIO
(Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> IO VkImageUsageFlags
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff (VkSharedPresentSurfaceCapabilitiesKHR
-> Ptr VkSharedPresentSurfaceCapabilitiesKHR
forall a. VulkanMarshal a => a -> Ptr a
unsafePtr VkSharedPresentSurfaceCapabilitiesKHR
x) (Int
16))
{-# LINE 189 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
{-# INLINE readField #-}
readField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> IO
(FieldType
"sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR)
readField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> IO VkImageUsageFlags
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
16)
{-# LINE 193 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance {-# OVERLAPPING #-}
CanWriteField "sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
where
{-# INLINE writeField #-}
writeField :: Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType
"sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
-> IO ()
writeField Ptr VkSharedPresentSurfaceCapabilitiesKHR
p
= Ptr VkSharedPresentSurfaceCapabilitiesKHR
-> Int -> VkImageUsageFlags -> IO ()
forall a b. Storable a => Ptr b -> Int -> a -> IO ()
pokeByteOff Ptr VkSharedPresentSurfaceCapabilitiesKHR
p (Int
16)
{-# LINE 201 "src-gen/Graphics/Vulkan/Types/Struct/SharedPresentSurfaceCapabilitiesKHR.hsc" #-}
instance Show VkSharedPresentSurfaceCapabilitiesKHR where
showsPrec :: Int -> VkSharedPresentSurfaceCapabilitiesKHR -> ShowS
showsPrec Int
d VkSharedPresentSurfaceCapabilitiesKHR
x
= String -> ShowS
showString String
"VkSharedPresentSurfaceCapabilitiesKHR {" 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 (VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "sType" VkSharedPresentSurfaceCapabilitiesKHR
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"sType" VkSharedPresentSurfaceCapabilitiesKHR
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 (VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType "pNext" VkSharedPresentSurfaceCapabilitiesKHR
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"pNext" VkSharedPresentSurfaceCapabilitiesKHR
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
"sharedPresentSupportedUsageFlags = " ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
Int -> VkImageUsageFlags -> ShowS
forall a. Show a => Int -> a -> ShowS
showsPrec Int
d (VkSharedPresentSurfaceCapabilitiesKHR
-> FieldType
"sharedPresentSupportedUsageFlags"
VkSharedPresentSurfaceCapabilitiesKHR
forall (fname :: Symbol) a.
CanReadField fname a =>
a -> FieldType fname a
getField @"sharedPresentSupportedUsageFlags" VkSharedPresentSurfaceCapabilitiesKHR
x) ShowS -> ShowS -> ShowS
forall b c a. (b -> c) -> (a -> b) -> a -> c
.
Char -> ShowS
showChar Char
'}'