mirror of
https://github.com/roc-lang/roc.git
synced 2025-08-02 19:32:17 +00:00
Centralize host tempfile builder logic
This commit is contained in:
parent
0b73ea69af
commit
a8b6fa051a
7 changed files with 95 additions and 117 deletions
|
@ -341,14 +341,18 @@ pub fn build_file<'a>(
|
||||||
app_o_file.to_str().unwrap(),
|
app_o_file.to_str().unwrap(),
|
||||||
];
|
];
|
||||||
|
|
||||||
let builtins_host_tempfile = tempfile::Builder::new()
|
let builtins_host_tempfile = {
|
||||||
.prefix("host_bitcode")
|
#[cfg(unix)]
|
||||||
.suffix(".o")
|
{
|
||||||
.rand_bytes(5)
|
bitcode::host_unix_tempfile()
|
||||||
.tempfile()
|
}
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_tempfile.path(), bitcode::HOST_UNIX)
|
#[cfg(windows)]
|
||||||
.expect("failed to write host builtins object to tempfile");
|
{
|
||||||
|
bitcode::host_windows_tempfile()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.expect("failed to write host builtins object to tempfile");
|
||||||
|
|
||||||
if matches!(code_gen_options.backend, program::CodeGenBackend::Assembly) {
|
if matches!(code_gen_options.backend, program::CodeGenBackend::Assembly) {
|
||||||
inputs.push(builtins_host_tempfile.path().to_str().unwrap());
|
inputs.push(builtins_host_tempfile.path().to_str().unwrap());
|
||||||
|
|
|
@ -107,6 +107,7 @@ pub fn build_zig_host_native(
|
||||||
target: &str,
|
target: &str,
|
||||||
opt_level: OptLevel,
|
opt_level: OptLevel,
|
||||||
shared_lib_path: Option<&Path>,
|
shared_lib_path: Option<&Path>,
|
||||||
|
builtins_host_path: &Path,
|
||||||
) -> Command {
|
) -> Command {
|
||||||
let mut zig_cmd = zig();
|
let mut zig_cmd = zig();
|
||||||
zig_cmd
|
zig_cmd
|
||||||
|
@ -118,49 +119,12 @@ pub fn build_zig_host_native(
|
||||||
// with LLVM, the builtins are already part of the roc app,
|
// with LLVM, the builtins are already part of the roc app,
|
||||||
// but with the dev backend, they are missing. To minimize work,
|
// but with the dev backend, they are missing. To minimize work,
|
||||||
// we link them as part of the host executable
|
// we link them as part of the host executable
|
||||||
let (builtins_bytes, builtins_ext) = if target.contains("windows") {
|
|
||||||
#[cfg(windows)]
|
|
||||||
{
|
|
||||||
(bitcode::HOST_WINDOWS, ".obj")
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(windows))]
|
|
||||||
{
|
|
||||||
panic!(
|
|
||||||
"Building shared libraries for other operating systemes is not supported yet!"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
#[cfg(unix)]
|
|
||||||
{
|
|
||||||
(bitcode::HOST_UNIX, ".o")
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(unix))]
|
|
||||||
{
|
|
||||||
panic!(
|
|
||||||
"Building shared libraries for other operating systemes is not supported yet!"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// TODO in the future when we have numbered releases, this
|
|
||||||
// can go in ~/.cache/roc instead of writing it to a tempdir every time.
|
|
||||||
let builtins_host_file = tempfile::Builder::new()
|
|
||||||
.prefix("host_bitcode")
|
|
||||||
.suffix(builtins_ext)
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_file.path(), builtins_bytes)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
zig_cmd.args([
|
zig_cmd.args([
|
||||||
"build-exe",
|
"build-exe",
|
||||||
"-fPIE",
|
"-fPIE",
|
||||||
"-rdynamic", // make sure roc_alloc and friends are exposed
|
"-rdynamic", // make sure roc_alloc and friends are exposed
|
||||||
shared_lib_path.to_str().unwrap(),
|
shared_lib_path.to_str().unwrap(),
|
||||||
builtins_host_file.path().to_str().unwrap(),
|
builtins_host_path,
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
zig_cmd.args(["build-obj", "-fPIC"]);
|
zig_cmd.args(["build-obj", "-fPIC"]);
|
||||||
|
@ -216,6 +180,7 @@ pub fn build_zig_host_native(
|
||||||
target: &str,
|
target: &str,
|
||||||
opt_level: OptLevel,
|
opt_level: OptLevel,
|
||||||
shared_lib_path: Option<&Path>,
|
shared_lib_path: Option<&Path>,
|
||||||
|
builtins_host_path: &Path,
|
||||||
) -> Command {
|
) -> Command {
|
||||||
// to prevent `clang failed with stderr: zig: error: unable to make temporary file: No such file or directory`
|
// to prevent `clang failed with stderr: zig: error: unable to make temporary file: No such file or directory`
|
||||||
let env_userprofile = env::var("USERPROFILE").unwrap_or_else(|_| "".to_string());
|
let env_userprofile = env::var("USERPROFILE").unwrap_or_else(|_| "".to_string());
|
||||||
|
@ -232,7 +197,7 @@ pub fn build_zig_host_native(
|
||||||
"build-exe",
|
"build-exe",
|
||||||
// "-fPIE", PIE seems to fail on windows
|
// "-fPIE", PIE seems to fail on windows
|
||||||
shared_lib_path.to_str().unwrap(),
|
shared_lib_path.to_str().unwrap(),
|
||||||
&bitcode::get_builtins_windows_obj_path(),
|
builtins_host_path,
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
zig_cmd.args(&["build-obj"]);
|
zig_cmd.args(&["build-obj"]);
|
||||||
|
@ -275,6 +240,7 @@ pub fn build_zig_host_native(
|
||||||
_target: &str,
|
_target: &str,
|
||||||
opt_level: OptLevel,
|
opt_level: OptLevel,
|
||||||
shared_lib_path: Option<&Path>,
|
shared_lib_path: Option<&Path>,
|
||||||
|
builtins_host_path: &Path,
|
||||||
// For compatibility with the non-macOS def above. Keep these in sync.
|
// For compatibility with the non-macOS def above. Keep these in sync.
|
||||||
) -> Command {
|
) -> Command {
|
||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
|
@ -323,35 +289,11 @@ pub fn build_zig_host_native(
|
||||||
.env("PATH", &env_path)
|
.env("PATH", &env_path)
|
||||||
.env("HOME", &env_home);
|
.env("HOME", &env_home);
|
||||||
if let Some(shared_lib_path) = shared_lib_path {
|
if let Some(shared_lib_path) = shared_lib_path {
|
||||||
let native_bitcode;
|
|
||||||
let builtins_ext;
|
|
||||||
|
|
||||||
#[cfg(windows)]
|
|
||||||
{
|
|
||||||
native_bitcode = bitcode::HOST_WINDOWS;
|
|
||||||
builtins_ext = ".obj";
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(unix)]
|
|
||||||
{
|
|
||||||
native_bitcode = bitcode::HOST_UNIX;
|
|
||||||
builtins_ext = ".o";
|
|
||||||
}
|
|
||||||
|
|
||||||
let builtins_host_file = tempfile::Builder::new()
|
|
||||||
.prefix("host_bitcode")
|
|
||||||
.suffix(builtins_ext)
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_file.path(), native_bitcode)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
zig_cmd.args(&[
|
zig_cmd.args(&[
|
||||||
"build-exe",
|
"build-exe",
|
||||||
"-fPIE",
|
"-fPIE",
|
||||||
shared_lib_path.to_str().unwrap(),
|
shared_lib_path.to_str().unwrap(),
|
||||||
builtins_host_file.path().to_str().unwrap(),
|
builtins_host_path.to_str().unwrap(),
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
zig_cmd.args(&["build-obj"]);
|
zig_cmd.args(&["build-obj"]);
|
||||||
|
@ -455,6 +397,7 @@ pub fn build_c_host_native(
|
||||||
sources: &[&str],
|
sources: &[&str],
|
||||||
opt_level: OptLevel,
|
opt_level: OptLevel,
|
||||||
shared_lib_path: Option<&Path>,
|
shared_lib_path: Option<&Path>,
|
||||||
|
builtins_host_path: &Path,
|
||||||
) -> Command {
|
) -> Command {
|
||||||
let mut clang_cmd = clang();
|
let mut clang_cmd = clang();
|
||||||
clang_cmd
|
clang_cmd
|
||||||
|
@ -481,18 +424,10 @@ pub fn build_c_host_native(
|
||||||
get_target_str(target),
|
get_target_str(target),
|
||||||
opt_level,
|
opt_level,
|
||||||
Some(shared_lib_path),
|
Some(shared_lib_path),
|
||||||
|
builtins_host_path,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
let builtins_host_file = tempfile::Builder::new()
|
|
||||||
.prefix("host_bitcode")
|
|
||||||
.suffix(".o")
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_file.path(), bitcode::HOST_UNIX)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
clang_cmd.args([
|
clang_cmd.args([
|
||||||
shared_lib_path.to_str().unwrap(),
|
shared_lib_path.to_str().unwrap(),
|
||||||
// This line is commented out because
|
// This line is commented out because
|
||||||
|
@ -500,7 +435,7 @@ pub fn build_c_host_native(
|
||||||
// linking the built-ins led to a surgical linker bug for
|
// linking the built-ins led to a surgical linker bug for
|
||||||
// optimized builds. Disabling until it is needed for dev
|
// optimized builds. Disabling until it is needed for dev
|
||||||
// builds.
|
// builds.
|
||||||
// builtins_host_file.path().to_str().unwrap(),
|
// builtins_host_path,
|
||||||
"-fPIE",
|
"-fPIE",
|
||||||
"-pie",
|
"-pie",
|
||||||
"-lm",
|
"-lm",
|
||||||
|
@ -618,6 +553,19 @@ pub fn rebuild_host(
|
||||||
let env_home = env::var("HOME").unwrap_or_else(|_| "".to_string());
|
let env_home = env::var("HOME").unwrap_or_else(|_| "".to_string());
|
||||||
let env_cpath = env::var("CPATH").unwrap_or_else(|_| "".to_string());
|
let env_cpath = env::var("CPATH").unwrap_or_else(|_| "".to_string());
|
||||||
|
|
||||||
|
let builtins_host_tempfile = {
|
||||||
|
#[cfg(windows)]
|
||||||
|
{
|
||||||
|
bitcode::host_windows_tempfile()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(unix)]
|
||||||
|
{
|
||||||
|
bitcode::host_unix_tempfile()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.expect("failed to write host builtins object to tempfile");
|
||||||
|
|
||||||
if zig_host_src.exists() {
|
if zig_host_src.exists() {
|
||||||
// Compile host.zig
|
// Compile host.zig
|
||||||
|
|
||||||
|
@ -655,6 +603,7 @@ pub fn rebuild_host(
|
||||||
get_target_str(target),
|
get_target_str(target),
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
),
|
),
|
||||||
Architecture::X86_32(_) => build_zig_host_native(
|
Architecture::X86_32(_) => build_zig_host_native(
|
||||||
&env_path,
|
&env_path,
|
||||||
|
@ -665,8 +614,8 @@ pub fn rebuild_host(
|
||||||
"i386-linux-musl",
|
"i386-linux-musl",
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
),
|
),
|
||||||
|
|
||||||
Architecture::Aarch64(_) => build_zig_host_native(
|
Architecture::Aarch64(_) => build_zig_host_native(
|
||||||
&env_path,
|
&env_path,
|
||||||
&env_home,
|
&env_home,
|
||||||
|
@ -676,11 +625,12 @@ pub fn rebuild_host(
|
||||||
target_zig_str(target),
|
target_zig_str(target),
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
),
|
),
|
||||||
_ => internal_error!("Unsupported architecture {:?}", target.architecture),
|
_ => internal_error!("Unsupported architecture {:?}", target.architecture),
|
||||||
};
|
};
|
||||||
|
|
||||||
run_build_command(zig_cmd, "host.zig", 0)
|
run_build_command(zig_cmd, "host.zig", 0);
|
||||||
} else if cargo_host_src.exists() {
|
} else if cargo_host_src.exists() {
|
||||||
// Compile and link Cargo.toml, if it exists
|
// Compile and link Cargo.toml, if it exists
|
||||||
let cargo_dir = host_input_path.parent().unwrap();
|
let cargo_dir = host_input_path.parent().unwrap();
|
||||||
|
@ -743,6 +693,7 @@ pub fn rebuild_host(
|
||||||
&[c_host_src.to_str().unwrap()],
|
&[c_host_src.to_str().unwrap()],
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
);
|
);
|
||||||
|
|
||||||
run_build_command(clang_cmd, "host.c", 0);
|
run_build_command(clang_cmd, "host.c", 0);
|
||||||
|
@ -797,6 +748,7 @@ pub fn rebuild_host(
|
||||||
],
|
],
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
);
|
);
|
||||||
run_build_command(clang_cmd, "host.c", 0);
|
run_build_command(clang_cmd, "host.c", 0);
|
||||||
} else {
|
} else {
|
||||||
|
@ -809,6 +761,7 @@ pub fn rebuild_host(
|
||||||
&[c_host_src.to_str().unwrap()],
|
&[c_host_src.to_str().unwrap()],
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
);
|
);
|
||||||
|
|
||||||
run_build_command(clang_cmd, "host.c", 0);
|
run_build_command(clang_cmd, "host.c", 0);
|
||||||
|
@ -844,6 +797,7 @@ pub fn rebuild_host(
|
||||||
&[c_host_src.to_str().unwrap()],
|
&[c_host_src.to_str().unwrap()],
|
||||||
opt_level,
|
opt_level,
|
||||||
shared_lib_path,
|
shared_lib_path,
|
||||||
|
builtins_host_tempfile.path(),
|
||||||
);
|
);
|
||||||
|
|
||||||
run_build_command(clang_cmd, "host.c", 0);
|
run_build_command(clang_cmd, "host.c", 0);
|
||||||
|
@ -865,6 +819,10 @@ pub fn rebuild_host(
|
||||||
run_build_command(swiftc_cmd, "host.swift", 0);
|
run_build_command(swiftc_cmd, "host.swift", 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Extend the lifetime of the tempfile so it doesn't get dropped
|
||||||
|
// (and thus deleted) before the build process is done using it!
|
||||||
|
let _ = builtins_host_tempfile;
|
||||||
|
|
||||||
host_dest
|
host_dest
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1417,14 +1375,8 @@ pub fn preprocess_host_wasm32(host_input_path: &Path, preprocessed_host_path: &P
|
||||||
(but seems to be an unofficial API)
|
(but seems to be an unofficial API)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
let builtins_host_tempfile = tempfile::Builder::new()
|
let builtins_host_tempfile =
|
||||||
.prefix("host_bitcode")
|
bitcode::host_wasm_tempfile().expect("failed to write host builtins object to tempfile");
|
||||||
.suffix(".wasm")
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_tempfile.path(), bitcode::HOST_WASM)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
let mut zig_cmd = zig();
|
let mut zig_cmd = zig();
|
||||||
let args = &[
|
let args = &[
|
||||||
|
|
|
@ -12,6 +12,7 @@ roc_region = { path = "../region" }
|
||||||
roc_module = { path = "../module" }
|
roc_module = { path = "../module" }
|
||||||
roc_target = { path = "../roc_target" }
|
roc_target = { path = "../roc_target" }
|
||||||
roc_utils = { path = "../../utils" }
|
roc_utils = { path = "../../utils" }
|
||||||
|
tempfile.workspace = true
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
# dunce can be removed once ziglang/zig#5109 is fixed
|
# dunce can be removed once ziglang/zig#5109 is fixed
|
||||||
|
@ -19,4 +20,4 @@ dunce = "1.0.3"
|
||||||
roc_utils = { path = "../../utils" }
|
roc_utils = { path = "../../utils" }
|
||||||
|
|
||||||
[target.'cfg(target_os = "macos")'.build-dependencies]
|
[target.'cfg(target_os = "macos")'.build-dependencies]
|
||||||
tempfile = "3.2.0"
|
tempfile.workspace = true
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
use roc_module::symbol::Symbol;
|
use roc_module::symbol::Symbol;
|
||||||
use roc_target::TargetInfo;
|
use roc_target::TargetInfo;
|
||||||
use std::ops::Index;
|
use std::ops::Index;
|
||||||
|
use tempfile::NamedTempFile;
|
||||||
|
|
||||||
pub const HOST_WASM: &[u8] = include_bytes!(concat!(env!("OUT_DIR"), "/bitcode/builtins-wasm32.o"));
|
pub const HOST_WASM: &[u8] = include_bytes!(concat!(env!("OUT_DIR"), "/bitcode/builtins-wasm32.o"));
|
||||||
// TODO: in the future, we should use Zig's cross-compilation to generate and store these
|
// TODO: in the future, we should use Zig's cross-compilation to generate and store these
|
||||||
|
@ -13,6 +14,44 @@ pub const HOST_WINDOWS: &[u8] = include_bytes!(concat!(
|
||||||
"/bitcode/builtins-windows-x86_64.obj"
|
"/bitcode/builtins-windows-x86_64.obj"
|
||||||
));
|
));
|
||||||
|
|
||||||
|
pub fn host_wasm_tempfile() -> std::io::Result<NamedTempFile> {
|
||||||
|
let tempfile = tempfile::Builder::new()
|
||||||
|
.prefix("host_bitcode")
|
||||||
|
.suffix(".wasm")
|
||||||
|
.rand_bytes(8)
|
||||||
|
.tempfile()?;
|
||||||
|
|
||||||
|
std::fs::write(tempfile.path(), HOST_WASM)?;
|
||||||
|
|
||||||
|
Ok(tempfile)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(unix)]
|
||||||
|
pub fn host_unix_tempfile() -> std::io::Result<NamedTempFile> {
|
||||||
|
let tempfile = tempfile::Builder::new()
|
||||||
|
.prefix("host_bitcode")
|
||||||
|
.suffix(".o")
|
||||||
|
.rand_bytes(8)
|
||||||
|
.tempfile()?;
|
||||||
|
|
||||||
|
std::fs::write(tempfile.path(), HOST_UNIX)?;
|
||||||
|
|
||||||
|
Ok(tempfile)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(windows)]
|
||||||
|
pub fn host_windows_tempfile() -> std::io::Result<NamedTempFile> {
|
||||||
|
let tempfile = tempfile::Builder::new()
|
||||||
|
.prefix("host_bitcode")
|
||||||
|
.suffix(".obj")
|
||||||
|
.rand_bytes(8)
|
||||||
|
.tempfile()?;
|
||||||
|
|
||||||
|
std::fs::write(tempfile.path(), HOST_WINDOWS)?;
|
||||||
|
|
||||||
|
Ok(tempfile)
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Default, Copy, Clone)]
|
#[derive(Debug, Default, Copy, Clone)]
|
||||||
pub struct IntrinsicName {
|
pub struct IntrinsicName {
|
||||||
pub options: [&'static str; 14],
|
pub options: [&'static str; 14],
|
||||||
|
|
|
@ -100,14 +100,8 @@ fn build_wasm_test_host() {
|
||||||
let mut outfile = PathBuf::from(&out_dir).join(PLATFORM_FILENAME);
|
let mut outfile = PathBuf::from(&out_dir).join(PLATFORM_FILENAME);
|
||||||
outfile.set_extension("wasm");
|
outfile.set_extension("wasm");
|
||||||
|
|
||||||
let builtins_host_tempfile = tempfile::Builder::new()
|
let builtins_host_tempfile =
|
||||||
.prefix("host_bitcode")
|
bitcode::host_wasm_tempfile().expect("failed to write host builtins object to tempfile");
|
||||||
.suffix(".wasm")
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_tempfile.path(), bitcode::HOST_WASM)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
run_zig(&[
|
run_zig(&[
|
||||||
"wasm-ld",
|
"wasm-ld",
|
||||||
|
|
|
@ -193,14 +193,8 @@ pub fn helper(
|
||||||
.expect("failed to build output object");
|
.expect("failed to build output object");
|
||||||
std::fs::write(&app_o_file, module_out).expect("failed to write object to file");
|
std::fs::write(&app_o_file, module_out).expect("failed to write object to file");
|
||||||
|
|
||||||
let builtins_host_tempfile = tempfile::Builder::new()
|
let builtins_host_tempfile =
|
||||||
.prefix("host_bitcode")
|
bitcode::host_unix_tempfile().expect("failed to write host builtins object to tempfile");
|
||||||
.suffix(".o")
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_tempfile.path(), bitcode::HOST_UNIX)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
let (mut child, dylib_path) = link(
|
let (mut child, dylib_path) = link(
|
||||||
&target,
|
&target,
|
||||||
|
|
|
@ -23,14 +23,8 @@ fn main() {
|
||||||
pre_linked_binary_path.extend(["pre_linked_binary"]);
|
pre_linked_binary_path.extend(["pre_linked_binary"]);
|
||||||
pre_linked_binary_path.set_extension("o");
|
pre_linked_binary_path.set_extension("o");
|
||||||
|
|
||||||
let builtins_host_tempfile = tempfile::Builder::new()
|
let builtins_host_tempfile =
|
||||||
.prefix("host_bitcode")
|
bitcode::host_wasm_tempfile().expect("failed to write host builtins object to tempfile");
|
||||||
.suffix(".wasm")
|
|
||||||
.rand_bytes(5)
|
|
||||||
.tempfile()
|
|
||||||
.unwrap();
|
|
||||||
std::fs::write(builtins_host_tempfile.path(), bitcode::HOST_WASM)
|
|
||||||
.expect("failed to write host builtins object to tempfile");
|
|
||||||
|
|
||||||
let output = Command::new(&zig_executable())
|
let output = Command::new(&zig_executable())
|
||||||
.args([
|
.args([
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue