librashader/librashader-common/src/lib.rs
2022-12-05 21:01:15 -05:00

180 lines
4.5 KiB
Rust

/// OpenGL common conversions.
#[cfg(feature = "opengl")]
pub mod gl;
/// Vulkan common conversions.
#[cfg(feature = "vulkan")]
pub mod vk;
/// DXGI common conversions.
#[cfg(feature = "dxgi")]
pub mod dxgi;
/// Direct3D 11 common conversions.
#[cfg(feature = "d3d11")]
pub mod d3d11;
use num_traits::AsPrimitive;
use std::convert::Infallible;
use std::str::FromStr;
#[repr(u32)]
#[derive(Default, Copy, Clone, Debug, Eq, PartialEq, Hash)]
/// Supported image formats for textures.
pub enum ImageFormat {
#[default]
Unknown = 0,
/* 8-bit */
R8Unorm,
R8Uint,
R8Sint,
R8G8Unorm,
R8G8Uint,
R8G8Sint,
R8G8B8A8Unorm,
R8G8B8A8Uint,
R8G8B8A8Sint,
R8G8B8A8Srgb,
/* 10-bit */
A2B10G10R10UnormPack32,
A2B10G10R10UintPack32,
/* 16-bit */
R16Uint,
R16Sint,
R16Sfloat,
R16G16Uint,
R16G16Sint,
R16G16Sfloat,
R16G16B16A16Uint,
R16G16B16A16Sint,
R16G16B16A16Sfloat,
/* 32-bit */
R32Uint,
R32Sint,
R32Sfloat,
R32G32Uint,
R32G32Sint,
R32G32Sfloat,
R32G32B32A32Uint,
R32G32B32A32Sint,
R32G32B32A32Sfloat,
}
#[repr(i32)]
#[derive(Copy, Clone, Default, Debug, Eq, PartialEq, Hash)]
/// The filtering mode for a texture sampler.
pub enum FilterMode {
#[default]
/// Linear filtering.
Linear = 0,
/// Nearest-neighbour (point) filtering.
Nearest,
}
impl FromStr for WrapMode {
type Err = Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
Ok(match s {
"clamp_to_border" => WrapMode::ClampToBorder,
"clamp_to_edge" => WrapMode::ClampToEdge,
"repeat" => WrapMode::Repeat,
"mirrored_repeat" => WrapMode::MirroredRepeat,
_ => WrapMode::ClampToBorder,
})
}
}
#[repr(i32)]
#[derive(Copy, Clone, Default, Debug, Eq, PartialEq, Hash)]
/// The wrapping (address) mode for a texture sampler.
pub enum WrapMode {
#[default]
/// Clamp txture to border.
ClampToBorder = 0,
/// Clamp texture to edge.
ClampToEdge,
/// Repeat addressing mode.
Repeat,
/// Mirrored repeat addressing mode.
MirroredRepeat,
}
impl FromStr for ImageFormat {
type Err = Infallible;
fn from_str(s: &str) -> Result<Self, Self::Err> {
Ok(match s {
"UNKNOWN" => Self::Unknown,
"R8_UNORM" => Self::R8Unorm,
"R8_UINT" => Self::R8Uint,
"R8_SINT" => Self::R8Sint,
"R8G8_UNORM" => Self::R8G8Unorm,
"R8G8_UINT" => Self::R8Uint,
"R8G8_SINT" => Self::R8G8Sint,
"R8G8B8A8_UNORM" => Self::R8G8B8A8Unorm,
"R8G8B8A8_UINT" => Self::R8G8B8A8Uint,
"R8G8B8A8_SINT" => Self::R8G8B8A8Sint,
"R8G8B8A8_SRGB" => Self::R8G8B8A8Srgb,
"A2B10G10R10_UNORM_PACK32" => Self::A2B10G10R10UnormPack32,
"A2B10G10R10_UINT_PACK32" => Self::A2B10G10R10UintPack32,
"R16_UINT" => Self::R16Uint,
"R16_SINT" => Self::R16Sint,
"R16_SFLOAT" => Self::R16Sfloat,
"R16G16_UINT" => Self::R16G16Uint,
"R16G16_SINT" => Self::R16G16Sint,
"R16G16_SFLOAT" => Self::R16G16Sfloat,
"R16G16B16A16_UINT" => Self::R16G16B16A16Uint,
"R16G16B16A16_SINT" => Self::R16G16B16A16Sint,
"R16G16B16A16_SFLOAT" => Self::R16G16B16A16Sfloat,
"R32_UINT" => Self::R32Uint,
"R32_SINT" => Self::R32Sint,
"R32_SFLOAT" => Self::R32Sfloat,
"R32G32_UINT" => Self::R32G32Uint,
"R32G32_SINT" => Self::R32G32Sint,
"R32G32_SFLOAT" => Self::R32G32Sfloat,
"R32G32B32A32_UINT" => Self::R32G32B32A32Uint,
"R32G32B32A32_SINT" => Self::R32G32B32A32Sint,
"R32G32B32A32_SFLOAT" => Self::R32G32B32A32Sfloat,
_ => Self::Unknown,
})
}
}
/// A size with a width and height.
#[derive(Default, Debug, Copy, Clone, PartialEq, Eq)]
pub struct Size<T> {
pub width: T,
pub height: T,
}
impl<T> Size<T> {
/// Create a new `Size<T>` with the given width and height.
pub fn new(width: T, height: T) -> Self {
Size { width, height }
}
}
impl<T> From<Size<T>> for [f32; 4]
where
T: Copy + AsPrimitive<f32>,
{
/// Convert a `Size<T>` to a `vec4` uniform.
fn from(value: Size<T>) -> Self {
[
value.width.as_(),
value.height.as_(),
1.0 / value.width.as_(),
1.0 / value.height.as_(),
]
}
}