mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-24 02:16:32 +11:00
[shaders] Shader path look up fixes for hermetic builds
* Bazel builds seem to fail to open relative paths to parent directories due to hermetic sandboxing of third-party repositories. This adds a WORKSPACE_MANIFEST_FILE environment variable that allows the caller to optionally provide an absolute path to the workspace root manifest file. * The existing code processed a shader file only if `FileType::is_file` returns true for it. This is not the case when sources are accessed via symbolic links, which is possible in a Bazel sandbox. The code now filters for the ".wgsl" file extension instead of the file type which should generally be safe.
This commit is contained in:
parent
b0303ccf98
commit
d82bd409ff
3 changed files with 44 additions and 30 deletions
|
@ -8,14 +8,26 @@ mod types;
|
||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::fmt::Write;
|
use std::fmt::Write;
|
||||||
use std::path::Path;
|
use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
use compile::ShaderInfo;
|
use compile::ShaderInfo;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let out_dir = env::var_os("OUT_DIR").unwrap();
|
let out_dir = env::var_os("OUT_DIR").unwrap();
|
||||||
let dest_path = Path::new(&out_dir).join("shaders.rs");
|
let dest_path = Path::new(&out_dir).join("shaders.rs");
|
||||||
let mut shaders = compile::ShaderInfo::from_dir("../../shader");
|
|
||||||
|
// The shaders are defined under the workspace root and not in this crate so we need to locate
|
||||||
|
// them somehow. Cargo doesn't define an environment variable that points at the root workspace
|
||||||
|
// directory. In hermetic build environments that don't support relative paths (such as Bazel)
|
||||||
|
// we support supplying a `WORKSPACE_MANIFEST_FILE` that is expected to be an absolute path to
|
||||||
|
// the Cargo.toml file at the workspace root. If that's not present, we use a relative path.
|
||||||
|
let workspace_dir = env::var("WORKSPACE_MANIFEST_FILE")
|
||||||
|
.ok()
|
||||||
|
.and_then(|p| Path::new(&p).parent().map(|p| p.to_owned()))
|
||||||
|
.unwrap_or(PathBuf::from("../../"));
|
||||||
|
let shader_dir = Path::new(&workspace_dir).join("shader");
|
||||||
|
let mut shaders = compile::ShaderInfo::from_dir(&shader_dir);
|
||||||
|
|
||||||
// Drop the HashMap and sort by name so that we get deterministic order.
|
// Drop the HashMap and sort by name so that we get deterministic order.
|
||||||
let mut shaders = shaders.drain().collect::<Vec<_>>();
|
let mut shaders = shaders.drain().collect::<Vec<_>>();
|
||||||
shaders.sort_by(|x, y| x.0.cmp(&y.0));
|
shaders.sort_by(|x, y| x.0.cmp(&y.0));
|
||||||
|
|
|
@ -166,28 +166,29 @@ impl ShaderInfo {
|
||||||
for entry in shader_dir
|
for entry in shader_dir
|
||||||
.read_dir()
|
.read_dir()
|
||||||
.expect("Can read shader import directory")
|
.expect("Can read shader import directory")
|
||||||
|
.filter_map(move |e| {
|
||||||
|
e.ok()
|
||||||
|
.filter(|e| e.path().extension().map(|e| e == "wgsl").unwrap_or(false))
|
||||||
|
})
|
||||||
{
|
{
|
||||||
let entry = entry.expect("Can continue reading shader import directory");
|
let file_name = entry.file_name();
|
||||||
if entry.file_type().unwrap().is_file() {
|
if let Some(name) = file_name.to_str() {
|
||||||
let file_name = entry.file_name();
|
let suffix = ".wgsl";
|
||||||
if let Some(name) = file_name.to_str() {
|
if let Some(shader_name) = name.strip_suffix(suffix) {
|
||||||
let suffix = ".wgsl";
|
let contents = fs::read_to_string(shader_dir.join(&file_name))
|
||||||
if let Some(shader_name) = name.strip_suffix(suffix) {
|
.expect("Could read shader {shader_name} contents");
|
||||||
let contents = fs::read_to_string(shader_dir.join(&file_name))
|
if let Some(permutations) = permutation_map.get(shader_name) {
|
||||||
.expect("Could read shader {shader_name} contents");
|
for permutation in permutations {
|
||||||
if let Some(permutations) = permutation_map.get(shader_name) {
|
let mut defines = defines.clone();
|
||||||
for permutation in permutations {
|
defines.extend(permutation.defines.iter().cloned());
|
||||||
let mut defines = defines.clone();
|
|
||||||
defines.extend(permutation.defines.iter().cloned());
|
|
||||||
let source = preprocess::preprocess(&contents, &defines, &imports);
|
|
||||||
let shader_info = Self::new(source.clone(), "main").unwrap();
|
|
||||||
info.insert(permutation.name.clone(), shader_info);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
let source = preprocess::preprocess(&contents, &defines, &imports);
|
let source = preprocess::preprocess(&contents, &defines, &imports);
|
||||||
let shader_info = Self::new(source.clone(), "main").unwrap();
|
let shader_info = Self::new(source.clone(), "main").unwrap();
|
||||||
info.insert(shader_name.to_string(), shader_info);
|
info.insert(permutation.name.clone(), shader_info);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
let source = preprocess::preprocess(&contents, &defines, &imports);
|
||||||
|
let shader_info = Self::new(source.clone(), "main").unwrap();
|
||||||
|
info.insert(shader_name.to_string(), shader_info);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,17 +14,18 @@ pub fn get_imports(shader_dir: &Path) -> HashMap<String, String> {
|
||||||
for entry in imports_dir
|
for entry in imports_dir
|
||||||
.read_dir()
|
.read_dir()
|
||||||
.expect("Can read shader import directory")
|
.expect("Can read shader import directory")
|
||||||
|
.filter_map(move |e| {
|
||||||
|
e.ok()
|
||||||
|
.filter(|e| e.path().extension().map(|e| e == "wgsl").unwrap_or(false))
|
||||||
|
})
|
||||||
{
|
{
|
||||||
let entry = entry.expect("Can continue reading shader import directory");
|
let file_name = entry.file_name();
|
||||||
if entry.file_type().unwrap().is_file() {
|
if let Some(name) = file_name.to_str() {
|
||||||
let file_name = entry.file_name();
|
let suffix = ".wgsl";
|
||||||
if let Some(name) = file_name.to_str() {
|
if let Some(import_name) = name.strip_suffix(suffix) {
|
||||||
let suffix = ".wgsl";
|
let contents = fs::read_to_string(imports_dir.join(&file_name))
|
||||||
if let Some(import_name) = name.strip_suffix(suffix) {
|
.expect("Could read shader {import_name} contents");
|
||||||
let contents = fs::read_to_string(imports_dir.join(&file_name))
|
imports.insert(import_name.to_owned(), contents);
|
||||||
.expect("Could read shader {import_name} contents");
|
|
||||||
imports.insert(import_name.to_owned(), contents);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue