From 470f94d19e087d6927dd01de5c0927636ec692ef Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois?= Date: Sun, 9 Jan 2022 18:52:18 +0000 Subject: [PATCH] support all line endings in shader preprocessor (#3603) # Objective - Advance uses of shaders seems to often fail for Windows users - Bevy split lines on `'\n'` which messes with windows line endings ## Solution - Uses Rust built in https://doc.rust-lang.org/std/primitive.str.html#method.lines --- crates/bevy_render/src/render_resource/shader.rs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/crates/bevy_render/src/render_resource/shader.rs b/crates/bevy_render/src/render_resource/shader.rs index 3f229594035b4..7f71488aef379 100644 --- a/crates/bevy_render/src/render_resource/shader.rs +++ b/crates/bevy_render/src/render_resource/shader.rs @@ -308,7 +308,7 @@ impl ShaderImportProcessor { pub fn get_imports_from_str(&self, shader: &str) -> Vec { let mut imports = Vec::new(); - for line in shader.split('\n') { + for line in shader.lines() { if let Some(cap) = self.import_asset_path_regex.captures(line) { let import = cap.get(1).unwrap(); imports.push(ShaderImport::AssetPath(import.as_str().to_string())); @@ -366,7 +366,7 @@ impl ShaderProcessor { let shader_defs_unique = HashSet::::from_iter(shader_defs.iter().cloned()); let mut scopes = vec![true]; let mut final_string = String::new(); - for line in shader_str.split('\n') { + for line in shader_str.lines() { if let Some(cap) = self.ifdef_regex.captures(line) { let def = cap.get(1).unwrap(); scopes.push(*scopes.last().unwrap() && shader_defs_unique.contains(def.as_str())); @@ -417,7 +417,6 @@ impl ShaderProcessor { final_string.push('\n'); } } - final_string.pop(); if scopes.len() != 1 { return Err(ProcessShaderError::NotEnoughEndIfs);