2022-12-04 22:48:57 -05:00
|
|
|
//! Binding types for the librashader C API.
|
2022-12-03 18:32:10 -05:00
|
|
|
use crate::error::LibrashaderError;
|
2024-02-09 02:07:02 -05:00
|
|
|
use librashader::presets::context::{Orientation, VideoDriver, WildcardContext};
|
2022-12-05 00:06:37 -05:00
|
|
|
use librashader::presets::ShaderPreset;
|
2023-02-09 23:36:09 -05:00
|
|
|
use std::mem::MaybeUninit;
|
2022-12-05 00:06:37 -05:00
|
|
|
use std::ptr::NonNull;
|
2022-12-03 18:32:10 -05:00
|
|
|
|
2023-01-13 18:10:09 -05:00
|
|
|
/// A handle to a shader preset object.
|
2022-12-03 19:55:27 -05:00
|
|
|
pub type libra_shader_preset_t = Option<NonNull<ShaderPreset>>;
|
2023-01-13 18:10:09 -05:00
|
|
|
|
2024-02-09 02:07:02 -05:00
|
|
|
/// A handle to a preset wildcard context object.
|
|
|
|
pub type libra_preset_ctx_t = Option<NonNull<WildcardContext>>;
|
|
|
|
|
2023-01-13 18:10:09 -05:00
|
|
|
/// A handle to a librashader error object.
|
2022-12-04 22:37:03 -05:00
|
|
|
pub type libra_error_t = Option<NonNull<LibrashaderError>>;
|
2022-12-03 18:32:10 -05:00
|
|
|
|
2024-02-09 02:07:02 -05:00
|
|
|
/// An enum representing orientation for use in preset contexts.
|
|
|
|
#[repr(u32)]
|
|
|
|
#[derive(Debug, Copy, Clone)]
|
|
|
|
pub enum LIBRA_PRESET_CTX_ORIENTATION {
|
|
|
|
Vertical = 0,
|
|
|
|
Horizontal,
|
|
|
|
}
|
|
|
|
impl From<LIBRA_PRESET_CTX_ORIENTATION> for Orientation {
|
|
|
|
fn from(value: LIBRA_PRESET_CTX_ORIENTATION) -> Self {
|
|
|
|
match value {
|
|
|
|
LIBRA_PRESET_CTX_ORIENTATION::Vertical => Orientation::Vertical,
|
|
|
|
LIBRA_PRESET_CTX_ORIENTATION::Horizontal => Orientation::Horizontal,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// An enum representing graphics runtimes (video drivers) for use in preset contexts.
|
|
|
|
#[repr(u32)]
|
|
|
|
#[derive(Debug, Copy, Clone)]
|
|
|
|
pub enum LIBRA_PRESET_CTX_RUNTIME {
|
|
|
|
None = 0,
|
|
|
|
GlCore,
|
|
|
|
Vulkan,
|
|
|
|
D3D11,
|
|
|
|
D3D12,
|
|
|
|
Metal,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<LIBRA_PRESET_CTX_RUNTIME> for VideoDriver {
|
|
|
|
fn from(value: LIBRA_PRESET_CTX_RUNTIME) -> Self {
|
|
|
|
match value {
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::None => VideoDriver::None,
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::GlCore => VideoDriver::GlCore,
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::Vulkan => VideoDriver::Vulkan,
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::D3D11 => VideoDriver::Direct3D11,
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::D3D12 => VideoDriver::Direct3D12,
|
|
|
|
LIBRA_PRESET_CTX_RUNTIME::Metal => VideoDriver::Metal,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-09 17:48:20 -05:00
|
|
|
#[cfg(feature = "runtime-opengl")]
|
|
|
|
use librashader::runtime::gl::FilterChain as FilterChainGL;
|
|
|
|
|
2023-01-13 18:10:09 -05:00
|
|
|
/// A handle to a OpenGL filter chain.
|
2022-12-04 22:37:03 -05:00
|
|
|
#[cfg(feature = "runtime-opengl")]
|
2024-09-15 02:10:06 -04:00
|
|
|
#[cfg_attr(feature = "docsrs", doc(cfg(feature = "runtime-opengl")))]
|
2024-02-09 17:48:20 -05:00
|
|
|
pub type libra_gl_filter_chain_t = Option<NonNull<FilterChainGL>>;
|
|
|
|
|
|
|
|
/// A handle to a Direct3D 11 filter chain.
|
2024-02-14 19:22:25 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d11")
|
|
|
|
))]
|
2024-02-09 17:48:20 -05:00
|
|
|
use librashader::runtime::d3d11::FilterChain as FilterChainD3D11;
|
2022-12-03 18:56:57 -05:00
|
|
|
|
2023-02-06 02:17:30 -05:00
|
|
|
/// A handle to a Direct3D 11 filter chain.
|
2024-09-15 02:10:06 -04:00
|
|
|
#[cfg_attr(
|
|
|
|
feature = "docsrs",
|
|
|
|
doc(cfg(all(target_os = "windows", feature = "runtime-d3d11")))
|
|
|
|
)]
|
2024-02-14 19:22:25 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d11")
|
|
|
|
))]
|
2024-02-10 18:54:57 -05:00
|
|
|
pub type libra_d3d11_filter_chain_t = Option<NonNull<FilterChainD3D11>>;
|
2022-12-04 22:48:57 -05:00
|
|
|
|
2024-02-14 19:22:25 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d12")
|
|
|
|
))]
|
2024-02-09 17:48:20 -05:00
|
|
|
use librashader::runtime::d3d12::FilterChain as FilterChainD3D12;
|
2023-02-06 02:17:30 -05:00
|
|
|
/// A handle to a Direct3D 12 filter chain.
|
2024-02-14 19:22:25 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d12")
|
|
|
|
))]
|
2024-02-10 18:54:57 -05:00
|
|
|
pub type libra_d3d12_filter_chain_t = Option<NonNull<FilterChainD3D12>>;
|
2023-02-06 02:17:30 -05:00
|
|
|
|
2024-03-07 19:37:39 -05:00
|
|
|
/// A handle to a Direct3D 9 filter chain.
|
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d9")
|
|
|
|
))]
|
|
|
|
use librashader::runtime::d3d9::FilterChain as FilterChainD3D9;
|
|
|
|
|
|
|
|
/// A handle to a Direct3D 11 filter chain.
|
2024-09-15 02:10:06 -04:00
|
|
|
#[cfg_attr(
|
|
|
|
feature = "docsrs",
|
|
|
|
doc(cfg(all(target_os = "windows", feature = "runtime-d3d9")))
|
|
|
|
)]
|
2024-03-07 19:37:39 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(target_os = "windows", feature = "runtime-d3d9")
|
|
|
|
))]
|
|
|
|
pub type libra_d3d9_filter_chain_t = Option<NonNull<FilterChainD3D9>>;
|
|
|
|
|
2024-02-09 17:48:20 -05:00
|
|
|
#[cfg(feature = "runtime-vulkan")]
|
|
|
|
use librashader::runtime::vk::FilterChain as FilterChainVulkan;
|
2023-01-13 18:10:09 -05:00
|
|
|
/// A handle to a Vulkan filter chain.
|
2023-01-13 17:59:22 -05:00
|
|
|
#[cfg(feature = "runtime-vulkan")]
|
2024-09-15 02:10:06 -04:00
|
|
|
#[cfg_attr(feature = "docsrs", doc(cfg(feature = "runtime-vulkan")))]
|
2024-02-10 18:54:57 -05:00
|
|
|
pub type libra_vk_filter_chain_t = Option<NonNull<FilterChainVulkan>>;
|
2023-01-13 17:59:22 -05:00
|
|
|
|
2024-02-13 03:03:45 -05:00
|
|
|
#[cfg(all(target_os = "macos", feature = "runtime-metal"))]
|
|
|
|
use librashader::runtime::mtl::FilterChain as FilterChainMetal;
|
2024-09-15 02:10:06 -04:00
|
|
|
#[cfg_attr(
|
|
|
|
feature = "docsrs",
|
|
|
|
doc(cfg(all(target_vendor = "apple", feature = "runtime-metal")))
|
|
|
|
)]
|
2024-02-14 19:22:25 -05:00
|
|
|
#[cfg(any(
|
|
|
|
feature = "__cbindgen_internal",
|
|
|
|
all(
|
|
|
|
target_vendor = "apple",
|
|
|
|
feature = "runtime-metal",
|
|
|
|
feature = "__cbindgen_internal_objc"
|
|
|
|
)
|
|
|
|
))]
|
2024-02-13 03:03:45 -05:00
|
|
|
pub type libra_mtl_filter_chain_t = Option<NonNull<FilterChainMetal>>;
|
|
|
|
|
2023-01-13 18:10:09 -05:00
|
|
|
/// Defines the output viewport for a rendered frame.
|
2022-12-03 18:56:57 -05:00
|
|
|
#[repr(C)]
|
|
|
|
pub struct libra_viewport_t {
|
2023-01-13 18:10:09 -05:00
|
|
|
/// The x offset in the viewport framebuffer to begin rendering from.
|
2022-12-03 18:56:57 -05:00
|
|
|
pub x: f32,
|
2023-01-13 18:10:09 -05:00
|
|
|
/// The y offset in the viewport framebuffer to begin rendering from.
|
2022-12-03 18:56:57 -05:00
|
|
|
pub y: f32,
|
2023-01-21 00:31:29 -05:00
|
|
|
/// The width of the viewport framebuffer.
|
|
|
|
pub width: u32,
|
2023-01-27 18:17:35 -05:00
|
|
|
/// The height of the viewport framebuffer.
|
|
|
|
pub height: u32,
|
2022-12-05 00:06:37 -05:00
|
|
|
}
|
2023-02-09 23:36:09 -05:00
|
|
|
|
|
|
|
pub(crate) trait FromUninit<T>
|
|
|
|
where
|
|
|
|
Self: Sized,
|
|
|
|
{
|
|
|
|
fn from_uninit(value: MaybeUninit<Self>) -> T;
|
|
|
|
}
|
|
|
|
|
|
|
|
macro_rules! config_set_field {
|
2024-02-26 22:18:12 -05:00
|
|
|
(@POINTER $options:ident.$field:ident <- $ptr:ident) => {
|
2023-02-09 23:36:09 -05:00
|
|
|
$options.$field = unsafe { ::std::ptr::addr_of!((*$ptr).$field).read() };
|
|
|
|
};
|
2024-02-26 22:18:12 -05:00
|
|
|
(@POINTER @NEGATIVE $options:ident.$field:ident <- $ptr:ident) => {
|
|
|
|
$options.$field = unsafe { !::std::ptr::addr_of!((*$ptr).$field).read() };
|
|
|
|
};
|
|
|
|
(@LITERAL $options:ident.$field:ident <- $value:literal) => {
|
|
|
|
$options.$field = $value;
|
|
|
|
};
|
2023-02-09 23:36:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
macro_rules! config_version_set {
|
2024-02-26 22:18:12 -05:00
|
|
|
// "optimized" version for normal behaviour
|
|
|
|
(@ROOT $realver:ident $version:literal => [$($field:ident),+ $(,)?] ($options:ident <- $ptr:ident)) => {
|
2023-02-09 23:36:09 -05:00
|
|
|
#[allow(unused_comparisons)]
|
2024-02-26 22:18:12 -05:00
|
|
|
if $realver >= $version {
|
|
|
|
$($crate::ctypes::config_set_field!(@POINTER $options.$field <- $ptr);)+
|
2023-02-09 23:36:09 -05:00
|
|
|
}
|
2024-02-26 22:18:12 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
// Repeater
|
|
|
|
(@ROOT $realver:ident $version:literal => [$($field:tt),+ $(,)?] ($options:ident <- $ptr:ident)) => {
|
|
|
|
$(crate::ctypes::config_version_set!(@SINGLE $realver $version => [$field] ($options <- $ptr));)+
|
|
|
|
};
|
|
|
|
|
|
|
|
// Allow overriding default value with a literal for older versions
|
|
|
|
(@SINGLE $realver:ident $version:literal => [($field:ident: $value:literal)] ($options:ident <- $ptr:ident)) => {
|
|
|
|
#[allow(unused_comparisons)]
|
|
|
|
if $realver >= $version {
|
|
|
|
$crate::ctypes::config_set_field!(@LITERAL $options.$field <- $value);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Allow negation of prior variables that is version dependent.
|
|
|
|
(@SINGLE $realver:ident $version:literal => [(!$field:ident)] ($options:ident <- $ptr:ident)) => {
|
|
|
|
#[allow(unused_comparisons)]
|
|
|
|
if $realver >= $version {
|
|
|
|
$crate::ctypes::config_set_field!(@POINTER @NEGATIVE $options.$field <- $ptr);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
(@SINGLE $realver:ident $version:literal => [$field:ident] ($options:ident <- $ptr:ident)) => {
|
|
|
|
#[allow(unused_comparisons)]
|
|
|
|
if $realver >= $version {
|
|
|
|
$crate::ctypes::config_set_field!(@POINTER $options.$field <- $ptr);
|
|
|
|
}
|
|
|
|
};
|
2023-02-09 23:36:09 -05:00
|
|
|
}
|
|
|
|
|
2024-02-26 22:18:12 -05:00
|
|
|
/// Macro to declare a configuration struct, with options to change behaviour based on
|
|
|
|
/// API version.
|
|
|
|
///
|
|
|
|
/// For example following declaration does the following
|
|
|
|
///
|
|
|
|
/// * Declare `frames_in_flight`, `use_dynamic_rendering` for API version 0, with the following forward compatibility statements
|
|
|
|
/// * Inverts the behaviour of `use_dynamic_rendering` compared to API version 1.
|
|
|
|
/// * `disable_cache` is defaulted to `true` for API version 0, regardless of `Default::default`
|
|
|
|
/// but is not declared for API 0.
|
|
|
|
/// * Declare `use_dynamic_rendering` with normal behaviour, and `disable_cache` for API version 1.
|
|
|
|
/// * All fields that are undeclared inherit `Default::default`
|
|
|
|
///
|
|
|
|
/// ```rust
|
|
|
|
/// config_struct! {
|
|
|
|
/// impl FilterChainOptions => filter_chain_vk_opt_t {
|
|
|
|
/// 0 => [frames_in_flight, (!use_dynamic_rendering), (disable_cache: true)];
|
|
|
|
/// 1 => [use_dynamic_rendering, disable_cache];
|
|
|
|
/// }
|
|
|
|
/// }
|
|
|
|
/// ```
|
2023-02-09 23:36:09 -05:00
|
|
|
macro_rules! config_struct {
|
2024-02-26 22:18:12 -05:00
|
|
|
(impl $rust:ty => $capi:ty {$($version:literal => [$($field:tt),+]);+ $(;)?}) => {
|
2023-02-09 23:36:09 -05:00
|
|
|
impl $crate::ctypes::FromUninit<$rust> for $capi {
|
|
|
|
fn from_uninit(value: ::std::mem::MaybeUninit<Self>) -> $rust {
|
|
|
|
let ptr = value.as_ptr();
|
2024-02-26 22:18:12 -05:00
|
|
|
let version = unsafe { ::std::ptr::addr_of!((*ptr).version).read() };
|
|
|
|
|
2023-02-09 23:36:09 -05:00
|
|
|
let mut options = <$rust>::default();
|
|
|
|
$(
|
2024-02-26 22:18:12 -05:00
|
|
|
$crate::ctypes::config_version_set!(@ROOT version $version => [$($field),+] (options <- ptr));
|
2023-02-09 23:36:09 -05:00
|
|
|
)+
|
|
|
|
options
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) use config_set_field;
|
|
|
|
pub(crate) use config_struct;
|
|
|
|
pub(crate) use config_version_set;
|
2024-02-09 17:48:20 -05:00
|
|
|
|
|
|
|
#[doc(hidden)]
|
2024-06-15 01:10:35 -04:00
|
|
|
#[deny(deprecated)]
|
2024-02-09 17:48:20 -05:00
|
|
|
#[deprecated = "Forward declarations for cbindgen, do not use."]
|
|
|
|
mod __cbindgen_opaque_forward_declarations {
|
|
|
|
macro_rules! typedef_struct {
|
|
|
|
($($(#[$($attrss:tt)*])* $name:ident;)*) => {
|
|
|
|
$($(#[$($attrss)*])*
|
|
|
|
#[allow(unused)]
|
|
|
|
#[doc(hidden)]
|
2024-06-15 01:10:35 -04:00
|
|
|
#[deny(deprecated)]
|
2024-02-09 17:48:20 -05:00
|
|
|
#[deprecated]
|
|
|
|
pub struct $name;
|
|
|
|
)*
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
typedef_struct! {
|
|
|
|
/// Opaque struct for a preset context.
|
|
|
|
WildcardContext;
|
|
|
|
/// Opaque struct for a shader preset.
|
|
|
|
ShaderPreset;
|
|
|
|
/// Opaque struct for an OpenGL filter chain.
|
|
|
|
FilterChainGL;
|
|
|
|
/// Opaque struct for a Direct3D 11 filter chain.
|
|
|
|
FilterChainD3D11;
|
|
|
|
/// Opaque struct for a Direct3D 12 filter chain.
|
|
|
|
FilterChainD3D12;
|
2024-03-07 19:37:39 -05:00
|
|
|
/// Opaque struct for a Direct3D 9 filter chain.
|
|
|
|
FilterChainD3D9;
|
2024-02-09 17:48:20 -05:00
|
|
|
/// Opaque struct for a Vulkan filter chain.
|
|
|
|
FilterChainVulkan;
|
2024-02-13 03:03:45 -05:00
|
|
|
/// Opaque struct for a Metal filter chain.
|
|
|
|
FilterChainMetal;
|
2024-02-09 17:48:20 -05:00
|
|
|
}
|
2024-02-10 18:54:57 -05:00
|
|
|
}
|