{-# language CPP #-}
module Vulkan.Extensions.VK_EXT_ycbcr_image_arrays ( PhysicalDeviceYcbcrImageArraysFeaturesEXT(..)
, EXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION
, pattern EXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION
, EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME
, pattern EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME
) where
import Foreign.Marshal.Alloc (allocaBytes)
import Foreign.Ptr (nullPtr)
import Foreign.Ptr (plusPtr)
import Vulkan.CStruct (FromCStruct)
import Vulkan.CStruct (FromCStruct(..))
import Vulkan.CStruct (ToCStruct)
import Vulkan.CStruct (ToCStruct(..))
import Vulkan.Zero (Zero(..))
import Data.String (IsString)
import Data.Typeable (Typeable)
import Foreign.Storable (Storable)
import Foreign.Storable (Storable(peek))
import Foreign.Storable (Storable(poke))
import qualified Foreign.Storable (Storable(..))
import GHC.Generics (Generic)
import Foreign.Ptr (Ptr)
import Data.Kind (Type)
import Vulkan.Core10.FundamentalTypes (bool32ToBool)
import Vulkan.Core10.FundamentalTypes (boolToBool32)
import Vulkan.Core10.FundamentalTypes (Bool32)
import Vulkan.Core10.Enums.StructureType (StructureType)
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_PHYSICAL_DEVICE_YCBCR_IMAGE_ARRAYS_FEATURES_EXT))
data PhysicalDeviceYcbcrImageArraysFeaturesEXT = PhysicalDeviceYcbcrImageArraysFeaturesEXT
{
PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
ycbcrImageArrays :: Bool }
deriving (Typeable, PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
$c/= :: PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
== :: PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
$c== :: PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceYcbcrImageArraysFeaturesEXT)
#endif
deriving instance Show PhysicalDeviceYcbcrImageArraysFeaturesEXT
instance ToCStruct PhysicalDeviceYcbcrImageArraysFeaturesEXT where
withCStruct :: forall b.
PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> (Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO b) -> IO b
withCStruct PhysicalDeviceYcbcrImageArraysFeaturesEXT
x Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p PhysicalDeviceYcbcrImageArraysFeaturesEXT
x (Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO b
f Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p)
pokeCStruct :: forall b.
Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p PhysicalDeviceYcbcrImageArraysFeaturesEXT{Bool
ycbcrImageArrays :: Bool
$sel:ycbcrImageArrays:PhysicalDeviceYcbcrImageArraysFeaturesEXT :: PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Bool
..} IO b
f = do
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_YCBCR_IMAGE_ARRAYS_FEATURES_EXT)
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (forall a. Ptr a
nullPtr)
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
ycbcrImageArrays))
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b.
Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p IO b
f = do
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_YCBCR_IMAGE_ARRAYS_FEATURES_EXT)
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (forall a. Ptr a
nullPtr)
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
IO b
f
instance FromCStruct PhysicalDeviceYcbcrImageArraysFeaturesEXT where
peekCStruct :: Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> IO PhysicalDeviceYcbcrImageArraysFeaturesEXT
peekCStruct Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p = do
Bool32
ycbcrImageArrays <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Bool -> PhysicalDeviceYcbcrImageArraysFeaturesEXT
PhysicalDeviceYcbcrImageArraysFeaturesEXT
(Bool32 -> Bool
bool32ToBool Bool32
ycbcrImageArrays)
instance Storable PhysicalDeviceYcbcrImageArraysFeaturesEXT where
sizeOf :: PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Int
sizeOf ~PhysicalDeviceYcbcrImageArraysFeaturesEXT
_ = Int
24
alignment :: PhysicalDeviceYcbcrImageArraysFeaturesEXT -> Int
alignment ~PhysicalDeviceYcbcrImageArraysFeaturesEXT
_ = Int
8
peek :: Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> IO PhysicalDeviceYcbcrImageArraysFeaturesEXT
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
-> PhysicalDeviceYcbcrImageArraysFeaturesEXT -> IO ()
poke Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
ptr PhysicalDeviceYcbcrImageArraysFeaturesEXT
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero PhysicalDeviceYcbcrImageArraysFeaturesEXT where
zero :: PhysicalDeviceYcbcrImageArraysFeaturesEXT
zero = Bool -> PhysicalDeviceYcbcrImageArraysFeaturesEXT
PhysicalDeviceYcbcrImageArraysFeaturesEXT
forall a. Zero a => a
zero
type EXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION = 1
pattern EXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION :: forall a . Integral a => a
pattern $bEXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION :: forall a. Integral a => a
$mEXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION :: forall {r} {a}.
Integral a =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
EXT_YCBCR_IMAGE_ARRAYS_SPEC_VERSION = 1
type EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME = "VK_EXT_ycbcr_image_arrays"
pattern EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $bEXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
$mEXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME :: forall {r} {a}.
(Eq a, IsString a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
EXT_YCBCR_IMAGE_ARRAYS_EXTENSION_NAME = "VK_EXT_ycbcr_image_arrays"