use std::hash::Hash;
#[cfg(feature = "serde-support")]
use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
#[cfg_attr(feature = "serde-support", derive(Serialize, Deserialize))]
pub enum RafxShaderPackageMetal {
Src(String),
#[cfg_attr(feature = "serde-support", serde(with = "serde_bytes"))]
LibBytes(Vec<u8>),
}
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
#[cfg_attr(feature = "serde-support", derive(Serialize, Deserialize))]
pub enum RafxShaderPackageVulkan {
#[cfg_attr(feature = "serde-support", serde(with = "serde_bytes"))]
SpvBytes(Vec<u8>),
}
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
#[cfg_attr(feature = "serde-support", derive(Serialize, Deserialize))]
#[doc(hidden)]
pub enum RafxShaderPackageEmpty {
Empty,
}
#[derive(Debug, Clone, PartialEq, Eq, Hash, Default)]
#[cfg_attr(feature = "serde-support", derive(Serialize, Deserialize))]
pub struct RafxShaderPackage {
pub metal: Option<RafxShaderPackageMetal>,
pub vk: Option<RafxShaderPackageVulkan>,
}
impl RafxShaderPackage {
#[cfg(feature = "rafx-metal")]
pub fn metal_module_def(&self) -> Option<RafxShaderModuleDefMetal> {
if let Some(metal) = self.metal.as_ref() {
Some(match metal {
RafxShaderPackageMetal::Src(src) => RafxShaderModuleDefMetal::MetalSrc(src),
RafxShaderPackageMetal::LibBytes(lib) => {
RafxShaderModuleDefMetal::MetalLibBytes(lib)
}
})
} else {
None
}
}
#[cfg(feature = "rafx-vulkan")]
pub fn vulkan_module_def(&self) -> Option<RafxShaderModuleDefVulkan> {
if let Some(vk) = self.vk.as_ref() {
Some(match vk {
RafxShaderPackageVulkan::SpvBytes(bytes) => {
RafxShaderModuleDefVulkan::VkSpvBytes(bytes)
}
})
} else {
None
}
}
#[cfg(any(
feature = "rafx-empty",
not(any(feature = "rafx-metal", feature = "rafx-vulkan"))
))]
#[doc(hidden)]
pub fn empty_module_def(&self) -> Option<RafxShaderModuleDefEmpty> {
Some(RafxShaderModuleDefEmpty::Empty(Default::default()))
}
pub fn module_def(&self) -> RafxShaderModuleDef {
RafxShaderModuleDef {
#[cfg(feature = "rafx-metal")]
metal: self.metal_module_def(),
#[cfg(feature = "rafx-vulkan")]
vk: self.vulkan_module_def(),
#[cfg(any(
feature = "rafx-empty",
not(any(feature = "rafx-metal", feature = "rafx-vulkan"))
))]
#[doc(hidden)]
empty: self.empty_module_def(),
}
}
}
#[derive(Copy, Clone, Hash)]
#[cfg(feature = "rafx-metal")]
pub enum RafxShaderModuleDefMetal<'a> {
MetalSrc(&'a str),
MetalLibBytes(&'a [u8]),
}
#[derive(Copy, Clone, Hash)]
#[cfg(feature = "rafx-vulkan")]
pub enum RafxShaderModuleDefVulkan<'a> {
VkSpvBytes(&'a [u8]),
VkSpvPrepared(&'a [u32]),
}
#[cfg(any(
feature = "rafx-empty",
not(any(feature = "rafx-metal", feature = "rafx-vulkan"))
))]
#[derive(Copy, Clone, Hash)]
#[doc(hidden)]
pub enum RafxShaderModuleDefEmpty<'a> {
Empty(std::marker::PhantomData<&'a u32>),
}
#[derive(Copy, Clone, Hash)]
pub struct RafxShaderModuleDef<'a> {
#[cfg(feature = "rafx-metal")]
pub metal: Option<RafxShaderModuleDefMetal<'a>>,
#[cfg(feature = "rafx-vulkan")]
pub vk: Option<RafxShaderModuleDefVulkan<'a>>,
#[cfg(any(
feature = "rafx-empty",
not(any(feature = "rafx-metal", feature = "rafx-vulkan"))
))]
#[doc(hidden)]
pub empty: Option<RafxShaderModuleDefEmpty<'a>>,
}