mirror of
https://github.com/italicsjenga/ash-molten.git
synced 2025-01-11 05:31:30 +11:00
Added build with prebuilt libs (#33)
This commit is contained in:
parent
704078a107
commit
e2d54cc5d9
11
.github/workflows/ci.yaml
vendored
11
.github/workflows/ci.yaml
vendored
|
@ -25,7 +25,11 @@ jobs:
|
||||||
- uses: actions-rs/cargo@v1
|
- uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: clippy
|
command: clippy
|
||||||
args: --all-features -- -D warnings
|
args: -- -D warnings
|
||||||
|
- uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: clippy
|
||||||
|
args: --features pre-built -- -D warnings
|
||||||
|
|
||||||
cargo-deny:
|
cargo-deny:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
@ -47,4 +51,7 @@ jobs:
|
||||||
- uses: actions-rs/cargo@v1
|
- uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: build
|
command: build
|
||||||
|
- uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --features pre-built
|
||||||
|
|
|
@ -17,6 +17,7 @@ ash = "0.31"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
external = []
|
external = []
|
||||||
|
pre-built = []
|
||||||
|
|
||||||
[package.metadata.docs.rs]
|
[package.metadata.docs.rs]
|
||||||
default-target = "x86_64-apple-darwin"
|
default-target = "x86_64-apple-darwin"
|
||||||
|
|
131
build.rs
131
build.rs
|
@ -3,11 +3,11 @@ mod mac {
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
// MoltenVK git tagged release to use
|
// MoltenVK git tagged release to use
|
||||||
pub static TAG: &str = "v1.1.0";
|
pub static VERSION: &str = "1.1.0";
|
||||||
|
|
||||||
// Features are not used inside build scripts, so we have to explicitly query them from the
|
// Features are not used inside build scripts, so we have to explicitly query them from the
|
||||||
// enviroment
|
// enviroment
|
||||||
pub(crate) fn is_external_enabled() -> bool {
|
pub(crate) fn is_feature_enabled(feature: &str) -> bool {
|
||||||
std::env::vars()
|
std::env::vars()
|
||||||
.filter_map(|(flag, _)| {
|
.filter_map(|(flag, _)| {
|
||||||
const NAME: &str = "CARGO_FEATURE_";
|
const NAME: &str = "CARGO_FEATURE_";
|
||||||
|
@ -18,7 +18,7 @@ mod mac {
|
||||||
}
|
}
|
||||||
None
|
None
|
||||||
})
|
})
|
||||||
.any(|f| f == "EXTERNAL")
|
.any(|f| f == feature)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn build_molten<P: AsRef<Path>>(_target_dir: &P) -> &'static str {
|
pub(crate) fn build_molten<P: AsRef<Path>>(_target_dir: &P) -> &'static str {
|
||||||
|
@ -31,7 +31,7 @@ mod mac {
|
||||||
};
|
};
|
||||||
|
|
||||||
let checkout_dir = Path::new(&std::env::var("OUT_DIR").expect("Couldn't find OUT_DIR"))
|
let checkout_dir = Path::new(&std::env::var("OUT_DIR").expect("Couldn't find OUT_DIR"))
|
||||||
.join(format!("MoltenVK-{}", TAG));
|
.join(format!("MoltenVK-{}", VERSION));
|
||||||
|
|
||||||
let exit = Arc::new(AtomicBool::new(false));
|
let exit = Arc::new(AtomicBool::new(false));
|
||||||
let wants_exit = exit.clone();
|
let wants_exit = exit.clone();
|
||||||
|
@ -62,7 +62,7 @@ mod mac {
|
||||||
Command::new("git")
|
Command::new("git")
|
||||||
.arg("clone")
|
.arg("clone")
|
||||||
.arg("--branch")
|
.arg("--branch")
|
||||||
.arg(TAG.to_owned())
|
.arg(format!("v{}", VERSION.to_owned()))
|
||||||
.arg("--depth")
|
.arg("--depth")
|
||||||
.arg("1")
|
.arg("1")
|
||||||
.arg("https://github.com/KhronosGroup/MoltenVK.git")
|
.arg("https://github.com/KhronosGroup/MoltenVK.git")
|
||||||
|
@ -110,6 +110,81 @@ mod mac {
|
||||||
handle.join().unwrap();
|
handle.join().unwrap();
|
||||||
target_name
|
target_name
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) fn download_prebuilt_molten<P: AsRef<Path>>(target_dir: &P) {
|
||||||
|
use std::process::{Command, Stdio};
|
||||||
|
|
||||||
|
std::fs::create_dir_all(&target_dir).expect("Couldn't create directory");
|
||||||
|
|
||||||
|
std::env::set_current_dir(&target_dir).expect("Couldn't change current directory");
|
||||||
|
|
||||||
|
let curl = Command::new("curl")
|
||||||
|
.arg("-s")
|
||||||
|
.arg(format!(
|
||||||
|
"https://api.github.com/repos/EmbarkStudios/ash-molten/releases/tags/MoltenVK-{}",
|
||||||
|
VERSION
|
||||||
|
))
|
||||||
|
.stdout(Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch curl");
|
||||||
|
|
||||||
|
let curl_out = curl.stdout.expect("Failed to open curl stdout");
|
||||||
|
|
||||||
|
let grep = Command::new("grep")
|
||||||
|
.arg("browser_download_url.*zip")
|
||||||
|
.stdin(Stdio::from(curl_out))
|
||||||
|
.stdout(Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch grep");
|
||||||
|
|
||||||
|
let grep_out = grep.stdout.expect("Failed to open grep stdout");
|
||||||
|
|
||||||
|
let cut = Command::new("cut")
|
||||||
|
.args(&["-d", ":", "-f", "2,3"])
|
||||||
|
.stdin(Stdio::from(grep_out))
|
||||||
|
.stdout(Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch cut");
|
||||||
|
|
||||||
|
let cut_out = cut.stdout.expect("Failed to open grep stdout");
|
||||||
|
|
||||||
|
let tr = Command::new("tr")
|
||||||
|
.args(&["-d", "\""])
|
||||||
|
.stdin(Stdio::from(cut_out))
|
||||||
|
.stdout(Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch cut");
|
||||||
|
|
||||||
|
let tr_out = tr.stdout.expect("Failed to open grep stdout");
|
||||||
|
|
||||||
|
let output = Command::new("xargs")
|
||||||
|
.args(&["-n", "1", "curl", "-LO", "--silent"])
|
||||||
|
.stdin(Stdio::from(tr_out))
|
||||||
|
.stdout(Stdio::piped())
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch cut")
|
||||||
|
.wait_with_output()
|
||||||
|
.expect("failed to wait on xargs");
|
||||||
|
|
||||||
|
assert!(output.status.success());
|
||||||
|
|
||||||
|
for path in std::fs::read_dir(&target_dir).expect("Couldn't read dir") {
|
||||||
|
let path = path.unwrap().path();
|
||||||
|
if let Some("zip") = path.extension().and_then(std::ffi::OsStr::to_str) {
|
||||||
|
let status = Command::new("unzip")
|
||||||
|
.arg("-o")
|
||||||
|
.arg(path.to_owned())
|
||||||
|
.arg("-x")
|
||||||
|
.arg("__MACOSX/*")
|
||||||
|
.spawn()
|
||||||
|
.expect("Couldn't launch unzip")
|
||||||
|
.wait()
|
||||||
|
.expect("failed to wait on unzip");
|
||||||
|
|
||||||
|
assert!(status.success());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(any(target_os = "macos", target_os = "ios"))]
|
#[cfg(any(target_os = "macos", target_os = "ios"))]
|
||||||
|
@ -118,13 +193,17 @@ fn main() {
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
// The 'external' feature was not enabled. Molten will be built automaticaly.
|
// The 'external' feature was not enabled. Molten will be built automaticaly.
|
||||||
if !is_external_enabled() {
|
let external_enabled = is_feature_enabled("EXTERNAL");
|
||||||
let target_dir = Path::new(&std::env::var("OUT_DIR").unwrap()).join(format!(
|
let pre_built_enabled = is_feature_enabled("PRE_BUILT");
|
||||||
"MoltenVK-{}/Package/Latest/MoltenVK/MoltenVK.xcframework/{}-{}",
|
|
||||||
crate::mac::TAG,
|
assert!(
|
||||||
std::env::var("CARGO_CFG_TARGET_OS").unwrap(),
|
!(external_enabled && pre_built_enabled),
|
||||||
std::env::var("CARGO_CFG_TARGET_ARCH").unwrap()
|
"external and prebuild cannot be active at the same time"
|
||||||
));
|
);
|
||||||
|
|
||||||
|
if !external_enabled && !pre_built_enabled {
|
||||||
|
let target_dir = Path::new(&std::env::var("OUT_DIR").unwrap())
|
||||||
|
.join(format!("MoltenVK-{}", crate::mac::VERSION,));
|
||||||
let _target_name = build_molten(&target_dir);
|
let _target_name = build_molten(&target_dir);
|
||||||
|
|
||||||
let project_dir = {
|
let project_dir = {
|
||||||
|
@ -132,8 +211,36 @@ fn main() {
|
||||||
std::env::var("CARGO_MANIFEST_DIR").expect("unable to find env:CARGO_MANIFEST_DIR"),
|
std::env::var("CARGO_MANIFEST_DIR").expect("unable to find env:CARGO_MANIFEST_DIR"),
|
||||||
);
|
);
|
||||||
pb.push(target_dir);
|
pb.push(target_dir);
|
||||||
|
pb.push(format!(
|
||||||
|
"Package/Latest/MoltenVK/MoltenVK.xcframework/{}-{}",
|
||||||
|
std::env::var("CARGO_CFG_TARGET_OS").unwrap(),
|
||||||
|
std::env::var("CARGO_CFG_TARGET_ARCH").unwrap()
|
||||||
|
));
|
||||||
|
|
||||||
pb
|
pb
|
||||||
};
|
};
|
||||||
|
|
||||||
|
println!("cargo:rustc-link-search=native={}", project_dir.display());
|
||||||
|
} else if pre_built_enabled {
|
||||||
|
let target_dir = Path::new(&std::env::var("OUT_DIR").unwrap())
|
||||||
|
.join(format!("Prebuilt-MoltenVK-{}", crate::mac::VERSION));
|
||||||
|
|
||||||
|
download_prebuilt_molten(&target_dir);
|
||||||
|
|
||||||
|
let project_dir = {
|
||||||
|
let mut pb = PathBuf::from(
|
||||||
|
std::env::var("CARGO_MANIFEST_DIR").expect("unable to find env:CARGO_MANIFEST_DIR"),
|
||||||
|
);
|
||||||
|
pb.push(target_dir);
|
||||||
|
pb.push(format!(
|
||||||
|
"{}-{}",
|
||||||
|
std::env::var("CARGO_CFG_TARGET_OS").unwrap(),
|
||||||
|
std::env::var("CARGO_CFG_TARGET_ARCH").unwrap()
|
||||||
|
));
|
||||||
|
|
||||||
|
pb
|
||||||
|
};
|
||||||
|
|
||||||
println!("cargo:rustc-link-search=native={}", project_dir.display());
|
println!("cargo:rustc-link-search=native={}", project_dir.display());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue