{-# language CPP #-}
module Vulkan.Extensions.VK_NV_present_metering ( SetPresentConfigNV(..)
, PhysicalDevicePresentMeteringFeaturesNV(..)
, NV_PRESENT_METERING_SPEC_VERSION
, pattern NV_PRESENT_METERING_SPEC_VERSION
, NV_PRESENT_METERING_EXTENSION_NAME
, pattern NV_PRESENT_METERING_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.Word (Word32)
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_PRESENT_METERING_FEATURES_NV))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_SET_PRESENT_CONFIG_NV))
data SetPresentConfigNV = SetPresentConfigNV
{
SetPresentConfigNV -> Word32
numFramesPerBatch :: Word32
,
SetPresentConfigNV -> Word32
presentConfigFeedback :: Word32
}
deriving (Typeable, SetPresentConfigNV -> SetPresentConfigNV -> Bool
(SetPresentConfigNV -> SetPresentConfigNV -> Bool)
-> (SetPresentConfigNV -> SetPresentConfigNV -> Bool)
-> Eq SetPresentConfigNV
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SetPresentConfigNV -> SetPresentConfigNV -> Bool
== :: SetPresentConfigNV -> SetPresentConfigNV -> Bool
$c/= :: SetPresentConfigNV -> SetPresentConfigNV -> Bool
/= :: SetPresentConfigNV -> SetPresentConfigNV -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (SetPresentConfigNV)
#endif
deriving instance Show SetPresentConfigNV
instance ToCStruct SetPresentConfigNV where
withCStruct :: forall b.
SetPresentConfigNV -> (Ptr SetPresentConfigNV -> IO b) -> IO b
withCStruct SetPresentConfigNV
x Ptr SetPresentConfigNV -> IO b
f = Int -> (Ptr SetPresentConfigNV -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr SetPresentConfigNV -> IO b) -> IO b)
-> (Ptr SetPresentConfigNV -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr SetPresentConfigNV
p -> Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO b -> IO b
forall b.
Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr SetPresentConfigNV
p SetPresentConfigNV
x (Ptr SetPresentConfigNV -> IO b
f Ptr SetPresentConfigNV
p)
pokeCStruct :: forall b.
Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO b -> IO b
pokeCStruct Ptr SetPresentConfigNV
p SetPresentConfigNV{Word32
numFramesPerBatch :: SetPresentConfigNV -> Word32
presentConfigFeedback :: SetPresentConfigNV -> Word32
numFramesPerBatch :: Word32
presentConfigFeedback :: Word32
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_SET_PRESENT_CONFIG_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Word32 -> Word32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr Word32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (Word32
numFramesPerBatch)
Ptr Word32 -> Word32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr Word32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Word32)) (Word32
presentConfigFeedback)
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b. Ptr SetPresentConfigNV -> IO b -> IO b
pokeZeroCStruct Ptr SetPresentConfigNV
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_SET_PRESENT_CONFIG_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Word32 -> Word32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr Word32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (Word32
forall a. Zero a => a
zero)
Ptr Word32 -> Word32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr Word32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Word32)) (Word32
forall a. Zero a => a
zero)
IO b
f
instance FromCStruct SetPresentConfigNV where
peekCStruct :: Ptr SetPresentConfigNV -> IO SetPresentConfigNV
peekCStruct Ptr SetPresentConfigNV
p = do
numFramesPerBatch <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr SetPresentConfigNV
p Ptr SetPresentConfigNV -> Int -> Ptr Word32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32))
presentConfigFeedback <- peek @Word32 ((p `plusPtr` 20 :: Ptr Word32))
pure $ SetPresentConfigNV
numFramesPerBatch presentConfigFeedback
instance Storable SetPresentConfigNV where
sizeOf :: SetPresentConfigNV -> Int
sizeOf ~SetPresentConfigNV
_ = Int
24
alignment :: SetPresentConfigNV -> Int
alignment ~SetPresentConfigNV
_ = Int
8
peek :: Ptr SetPresentConfigNV -> IO SetPresentConfigNV
peek = Ptr SetPresentConfigNV -> IO SetPresentConfigNV
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO ()
poke Ptr SetPresentConfigNV
ptr SetPresentConfigNV
poked = Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO () -> IO ()
forall b.
Ptr SetPresentConfigNV -> SetPresentConfigNV -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr SetPresentConfigNV
ptr SetPresentConfigNV
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero SetPresentConfigNV where
zero :: SetPresentConfigNV
zero = Word32 -> Word32 -> SetPresentConfigNV
SetPresentConfigNV
Word32
forall a. Zero a => a
zero
Word32
forall a. Zero a => a
zero
data PhysicalDevicePresentMeteringFeaturesNV = PhysicalDevicePresentMeteringFeaturesNV
{
PhysicalDevicePresentMeteringFeaturesNV -> Bool
presentMetering :: Bool }
deriving (Typeable, PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool
(PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool)
-> (PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool)
-> Eq PhysicalDevicePresentMeteringFeaturesNV
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool
== :: PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool
$c/= :: PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool
/= :: PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDevicePresentMeteringFeaturesNV)
#endif
deriving instance Show PhysicalDevicePresentMeteringFeaturesNV
instance ToCStruct PhysicalDevicePresentMeteringFeaturesNV where
withCStruct :: forall b.
PhysicalDevicePresentMeteringFeaturesNV
-> (Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b) -> IO b
withCStruct PhysicalDevicePresentMeteringFeaturesNV
x Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b
f = Int
-> (Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b) -> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b) -> IO b)
-> (Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b) -> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDevicePresentMeteringFeaturesNV
p -> Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO b -> IO b
forall b.
Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDevicePresentMeteringFeaturesNV
p PhysicalDevicePresentMeteringFeaturesNV
x (Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b
f Ptr PhysicalDevicePresentMeteringFeaturesNV
p)
pokeCStruct :: forall b.
Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO b -> IO b
pokeCStruct Ptr PhysicalDevicePresentMeteringFeaturesNV
p PhysicalDevicePresentMeteringFeaturesNV{Bool
presentMetering :: PhysicalDevicePresentMeteringFeaturesNV -> Bool
presentMetering :: Bool
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_PRESENT_METERING_FEATURES_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
presentMetering))
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: forall b.
Ptr PhysicalDevicePresentMeteringFeaturesNV -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDevicePresentMeteringFeaturesNV
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_PRESENT_METERING_FEATURES_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV -> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
IO b
f
instance FromCStruct PhysicalDevicePresentMeteringFeaturesNV where
peekCStruct :: Ptr PhysicalDevicePresentMeteringFeaturesNV
-> IO PhysicalDevicePresentMeteringFeaturesNV
peekCStruct Ptr PhysicalDevicePresentMeteringFeaturesNV
p = do
presentMetering <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDevicePresentMeteringFeaturesNV
p Ptr PhysicalDevicePresentMeteringFeaturesNV -> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
pure $ PhysicalDevicePresentMeteringFeaturesNV
(bool32ToBool presentMetering)
instance Storable PhysicalDevicePresentMeteringFeaturesNV where
sizeOf :: PhysicalDevicePresentMeteringFeaturesNV -> Int
sizeOf ~PhysicalDevicePresentMeteringFeaturesNV
_ = Int
24
alignment :: PhysicalDevicePresentMeteringFeaturesNV -> Int
alignment ~PhysicalDevicePresentMeteringFeaturesNV
_ = Int
8
peek :: Ptr PhysicalDevicePresentMeteringFeaturesNV
-> IO PhysicalDevicePresentMeteringFeaturesNV
peek = Ptr PhysicalDevicePresentMeteringFeaturesNV
-> IO PhysicalDevicePresentMeteringFeaturesNV
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO ()
poke Ptr PhysicalDevicePresentMeteringFeaturesNV
ptr PhysicalDevicePresentMeteringFeaturesNV
poked = Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO () -> IO ()
forall b.
Ptr PhysicalDevicePresentMeteringFeaturesNV
-> PhysicalDevicePresentMeteringFeaturesNV -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDevicePresentMeteringFeaturesNV
ptr PhysicalDevicePresentMeteringFeaturesNV
poked (() -> IO ()
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero PhysicalDevicePresentMeteringFeaturesNV where
zero :: PhysicalDevicePresentMeteringFeaturesNV
zero = Bool -> PhysicalDevicePresentMeteringFeaturesNV
PhysicalDevicePresentMeteringFeaturesNV
Bool
forall a. Zero a => a
zero
type NV_PRESENT_METERING_SPEC_VERSION = 1
pattern NV_PRESENT_METERING_SPEC_VERSION :: forall a . Integral a => a
pattern $mNV_PRESENT_METERING_SPEC_VERSION :: forall {r} {a}.
Integral a =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bNV_PRESENT_METERING_SPEC_VERSION :: forall a. Integral a => a
NV_PRESENT_METERING_SPEC_VERSION = 1
type NV_PRESENT_METERING_EXTENSION_NAME = "VK_NV_present_metering"
pattern NV_PRESENT_METERING_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $mNV_PRESENT_METERING_EXTENSION_NAME :: forall {r} {a}.
(Eq a, IsString a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bNV_PRESENT_METERING_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
NV_PRESENT_METERING_EXTENSION_NAME = "VK_NV_present_metering"