diff --git a/wgpu-core/src/device/mod.rs b/wgpu-core/src/device/mod.rs index 9f8433db9b..6f5e999399 100644 --- a/wgpu-core/src/device/mod.rs +++ b/wgpu-core/src/device/mod.rs @@ -895,7 +895,12 @@ impl Device { Ok(module) => module, Err(err) => { log::error!("Failed to parse WGSL code for {:?}: {}", desc.label, err); - return Err(pipeline::CreateShaderModuleError::Parsing); + return Err(pipeline::CreateShaderModuleError::Parsing( + pipeline::NagaParseError { + shader_source: code.to_string(), + error: err, + }, + )); } } } diff --git a/wgpu-core/src/pipeline.rs b/wgpu-core/src/pipeline.rs index f090bffd8e..81d90ed711 100644 --- a/wgpu-core/src/pipeline.rs +++ b/wgpu-core/src/pipeline.rs @@ -44,10 +44,25 @@ impl Resource for ShaderModule { } } +#[derive(Clone, Debug, Error)] +pub struct NagaParseError { + pub shader_source: String, + pub error: naga::front::wgsl::ParseError, +} +impl std::fmt::Display for NagaParseError { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + write!( + f, + "\nShader error:\n{}", + self.error.emit_to_string(&self.shader_source) + ) + } +} + #[derive(Clone, Debug, Error)] pub enum CreateShaderModuleError { #[error("Failed to parse a shader")] - Parsing, + Parsing(#[from] NagaParseError), #[error("Failed to generate the backend-specific code")] Generation, #[error(transparent)]