Compare commits

..

2 commits

Author SHA1 Message Date
Alex Janka 71584cd9af fix double free 2024-02-09 10:14:23 +11:00
Alex Janka 5d59f70649 shaders can be either a path or a string 2024-02-09 10:14:23 +11:00
4 changed files with 18 additions and 21 deletions

10
Cargo.lock generated
View file

@ -1343,9 +1343,9 @@ dependencies = [
[[package]] [[package]]
name = "glslang" name = "glslang"
version = "0.3.1" version = "0.2.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c5df6491e5d4c222a6373b892c1bea8d697fca0c087890f64f0e2975b3f8bb48" checksum = "ffa3b9c49e9b4270061e25e7e3946d979a9394a21ac51edcb72e7c17874d3a54"
dependencies = [ dependencies = [
"glslang-sys", "glslang-sys",
"once_cell", "once_cell",
@ -1355,9 +1355,9 @@ dependencies = [
[[package]] [[package]]
name = "glslang-sys" name = "glslang-sys"
version = "0.3.1" version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6d76f2d75ad6e8a12c26e77ed6443a9369ef7957daf361e751c3489a97f8b816" checksum = "a3c81cefc876b4fd65354162037a464768bc5bada8b02d93b64e18186ae5cb7e"
dependencies = [ dependencies = [
"cc", "cc",
"glob", "glob",
@ -1843,7 +1843,7 @@ dependencies = [
name = "librashader-reflect" name = "librashader-reflect"
version = "0.2.0-beta.7" version = "0.2.0-beta.7"
dependencies = [ dependencies = [
"bitflags 2.4.2", "bitflags 1.3.2",
"bytemuck", "bytemuck",
"glslang", "glslang",
"indexmap 2.2.2", "indexmap 2.2.2",

View file

@ -12,11 +12,11 @@ keywords = ["shader", "retroarch", "SPIR-V"]
description = "RetroArch shaders for all." description = "RetroArch shaders for all."
[dependencies] [dependencies]
glslang = "0.3" glslang = "0.2"
bytemuck = "1.13.0" bytemuck = "1.13.0"
thiserror = "1.0.37" thiserror = "1.0.37"
bitflags = "2.4.2" bitflags = "1.3.2"
rustc-hash = "1.1.0" rustc-hash = "1.1.0"
librashader-common = { path = "../librashader-common", version = "0.2.0-beta.7" } librashader-common = { path = "../librashader-common", version = "0.2.0-beta.7" }

View file

@ -1,5 +1,6 @@
use glslang::{CompilerOptions, ShaderInput};
use crate::error::ShaderCompileError; use crate::error::ShaderCompileError;
use glslang::input::{CompilerOptions, ShaderInput};
use glslang::limits::ResourceLimits;
use librashader_preprocess::ShaderSource; use librashader_preprocess::ShaderSource;
#[cfg(feature = "serialize")] #[cfg(feature = "serialize")]
@ -33,31 +34,28 @@ pub(crate) fn compile_spirv(
source: &ShaderSource, source: &ShaderSource,
) -> Result<GlslangCompilation, ShaderCompileError> { ) -> Result<GlslangCompilation, ShaderCompileError> {
let compiler = glslang::Compiler::acquire().ok_or(ShaderCompileError::CompilerInitError)?; let compiler = glslang::Compiler::acquire().ok_or(ShaderCompileError::CompilerInitError)?;
let options = CompilerOptions {
source_language: glslang::SourceLanguage::GLSL,
target: glslang::Target::Vulkan {
version: glslang::VulkanVersion::Vulkan1_0,
spirv_version: glslang::SpirvVersion::SPIRV1_0
},
version_profile: None,
};
let vertex = glslang::ShaderSource::from(source.vertex.as_str()); let limits = ResourceLimits::default();
let options = CompilerOptions::default();
let vertex = glslang::input::ShaderSource::from(source.vertex.as_str());
let vertex = ShaderInput::new( let vertex = ShaderInput::new(
&vertex, &vertex,
&limits,
glslang::ShaderStage::Vertex, glslang::ShaderStage::Vertex,
&options, &options,
None, None,
)?; );
let vertex = compiler.create_shader(vertex)?; let vertex = compiler.create_shader(vertex)?;
let fragment = glslang::ShaderSource::from(source.fragment.as_str()); let fragment = glslang::input::ShaderSource::from(source.fragment.as_str());
let fragment = ShaderInput::new( let fragment = ShaderInput::new(
&fragment, &fragment,
&limits,
glslang::ShaderStage::Fragment, glslang::ShaderStage::Fragment,
&options, &options,
None, None,
)?; );
let fragment = compiler.create_shader(fragment)?; let fragment = compiler.create_shader(fragment)?;
let vertex = Vec::from(vertex.compile()?); let vertex = Vec::from(vertex.compile()?);

View file

@ -162,7 +162,6 @@ pub struct Semantic<T, I = usize> {
bitflags! { bitflags! {
/// The pipeline stage for which a uniform is bound. /// The pipeline stage for which a uniform is bound.
#[derive(PartialEq, Eq, PartialOrd, Ord, Hash, Debug, Clone, Copy)]
pub struct BindingStage: u8 { pub struct BindingStage: u8 {
const NONE = 0b00000000; const NONE = 0b00000000;
const VERTEX = 0b00000001; const VERTEX = 0b00000001;