{-# language CPP #-}
module Vulkan.Extensions.VK_NV_fragment_shader_barycentric ( PhysicalDeviceFragmentShaderBarycentricFeaturesNV(..)
, NV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION
, pattern NV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION
, NV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME
, pattern NV_FRAGMENT_SHADER_BARYCENTRIC_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_FRAGMENT_SHADER_BARYCENTRIC_FEATURES_NV))
data PhysicalDeviceFragmentShaderBarycentricFeaturesNV = PhysicalDeviceFragmentShaderBarycentricFeaturesNV
{
PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
fragmentShaderBarycentric :: Bool }
deriving (Typeable, PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
(PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool)
-> (PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool)
-> Eq PhysicalDeviceFragmentShaderBarycentricFeaturesNV
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
$c/= :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
== :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
$c== :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceFragmentShaderBarycentricFeaturesNV)
#endif
deriving instance Show PhysicalDeviceFragmentShaderBarycentricFeaturesNV
instance ToCStruct PhysicalDeviceFragmentShaderBarycentricFeaturesNV where
withCStruct :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> (Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b)
-> IO b
withCStruct PhysicalDeviceFragmentShaderBarycentricFeaturesNV
x Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b
f = Int
-> (Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b)
-> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b)
-> IO b)
-> (Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b)
-> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p -> Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO b
-> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p PhysicalDeviceFragmentShaderBarycentricFeaturesNV
x (Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO b
f Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p)
pokeCStruct :: Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO b
-> IO b
pokeCStruct Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p PhysicalDeviceFragmentShaderBarycentricFeaturesNV{Bool
fragmentShaderBarycentric :: Bool
$sel:fragmentShaderBarycentric:PhysicalDeviceFragmentShaderBarycentricFeaturesNV :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Bool
..} IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_FRAGMENT_SHADER_BARYCENTRIC_FEATURES_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> 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 PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
fragmentShaderBarycentric))
IO b
f
cStructSize :: Int
cStructSize = Int
24
cStructAlignment :: Int
cStructAlignment = Int
8
pokeZeroCStruct :: Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p IO b
f = do
Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_FRAGMENT_SHADER_BARYCENTRIC_FEATURES_NV)
Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> 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 PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> 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 PhysicalDeviceFragmentShaderBarycentricFeaturesNV where
peekCStruct :: Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV
peekCStruct Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p = do
Bool32
fragmentShaderBarycentric <- Ptr Bool32 -> IO Bool32
forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
p Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV
forall (f :: * -> *) a. Applicative f => a -> f a
pure (PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV)
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV
forall a b. (a -> b) -> a -> b
$ Bool -> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
PhysicalDeviceFragmentShaderBarycentricFeaturesNV
(Bool32 -> Bool
bool32ToBool Bool32
fragmentShaderBarycentric)
instance Storable PhysicalDeviceFragmentShaderBarycentricFeaturesNV where
sizeOf :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Int
sizeOf ~PhysicalDeviceFragmentShaderBarycentricFeaturesNV
_ = Int
24
alignment :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> Int
alignment ~PhysicalDeviceFragmentShaderBarycentricFeaturesNV
_ = Int
8
peek :: Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV
peek = Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO PhysicalDeviceFragmentShaderBarycentricFeaturesNV
forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
poke :: Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV -> IO ()
poke Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
poked = Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
-> IO ()
-> IO ()
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
ptr PhysicalDeviceFragmentShaderBarycentricFeaturesNV
poked (() -> IO ()
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
instance Zero PhysicalDeviceFragmentShaderBarycentricFeaturesNV where
zero :: PhysicalDeviceFragmentShaderBarycentricFeaturesNV
zero = Bool -> PhysicalDeviceFragmentShaderBarycentricFeaturesNV
PhysicalDeviceFragmentShaderBarycentricFeaturesNV
Bool
forall a. Zero a => a
zero
type NV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION = 1
pattern NV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION :: forall a . Integral a => a
pattern $bNV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION :: a
$mNV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION :: forall r a. Integral a => a -> (Void# -> r) -> (Void# -> r) -> r
NV_FRAGMENT_SHADER_BARYCENTRIC_SPEC_VERSION = 1
type NV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME = "VK_NV_fragment_shader_barycentric"
pattern NV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $bNV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME :: a
$mNV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME :: forall r a.
(Eq a, IsString a) =>
a -> (Void# -> r) -> (Void# -> r) -> r
NV_FRAGMENT_SHADER_BARYCENTRIC_EXTENSION_NAME = "VK_NV_fragment_shader_barycentric"