mirror of
https://github.com/denoland/deno.git
synced 2025-01-08 23:28:18 -05:00
parent
ee29ed79a7
commit
da004fb6c8
2 changed files with 59 additions and 63 deletions
14
build.rs
14
build.rs
|
@ -76,11 +76,15 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable snapshots for x64 builds
|
// If target_arch != host_arch disable snapshots since we are cross compiling.
|
||||||
if env::var("CARGO_CFG_TARGET_ARCH").unwrap() == "x86_64" {
|
if env::var("CARGO_CFG_TARGET_ARCH").unwrap().as_str() != env::var("HOST")
|
||||||
// Not related to v8_use_snapshot
|
.unwrap()
|
||||||
// This only enables using pregenerated snapshots for isolate init
|
.as_str()
|
||||||
println!("cargo:rustc-cfg=feature=\"use-snapshot-init\"");
|
.split("-")
|
||||||
|
.collect::<Vec<&str>>()[0]
|
||||||
|
{
|
||||||
|
// no-snapshot-init is not related to v8_use_snapshots
|
||||||
|
println!("cargo:rustc-cfg=feature=\"no-snapshot-init\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
if !gn_out_path.join("build.ninja").exists() {
|
if !gn_out_path.join("build.ninja").exists() {
|
||||||
|
|
|
@ -12,75 +12,67 @@ pub struct IsolateInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn deno_isolate_init() -> IsolateInit {
|
pub fn deno_isolate_init() -> IsolateInit {
|
||||||
if cfg!(not(feature = "check-only")) {
|
if cfg!(feature = "no-snapshot-init") {
|
||||||
if cfg!(feature = "use-snapshot-init") {
|
debug!("Deno isolate init without snapshots.");
|
||||||
let data =
|
#[cfg(not(feature = "check-only"))]
|
||||||
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/snapshot_deno.bin"));
|
let source_bytes =
|
||||||
|
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/bundle/main.js"));
|
||||||
|
#[cfg(feature = "check-only")]
|
||||||
|
let source_bytes = vec![];
|
||||||
|
|
||||||
unsafe {
|
|
||||||
IsolateInit {
|
|
||||||
snapshot: Some(deno_buf::from_raw_parts(data.as_ptr(), data.len())),
|
|
||||||
init_script: None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
#[cfg(not(feature = "check-only"))]
|
|
||||||
let source_bytes =
|
|
||||||
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/bundle/main.js"));
|
|
||||||
|
|
||||||
#[cfg(feature = "check-only")]
|
|
||||||
let source_bytes = vec![];
|
|
||||||
|
|
||||||
IsolateInit {
|
|
||||||
snapshot: None,
|
|
||||||
init_script: Some(IsolateInitScript {
|
|
||||||
filename: "gen/bundle/main.js".to_string(),
|
|
||||||
source: std::str::from_utf8(source_bytes).unwrap().to_string(),
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
IsolateInit {
|
IsolateInit {
|
||||||
snapshot: None,
|
snapshot: None,
|
||||||
init_script: None,
|
init_script: Some(IsolateInitScript {
|
||||||
|
filename: "gen/bundle/main.js".to_string(),
|
||||||
|
source: std::str::from_utf8(source_bytes).unwrap().to_string(),
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
debug!("Deno isolate init with snapshots.");
|
||||||
|
#[cfg(not(feature = "check-only"))]
|
||||||
|
let data =
|
||||||
|
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/snapshot_deno.bin"));
|
||||||
|
#[cfg(feature = "check-only")]
|
||||||
|
let data = vec![];
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
IsolateInit {
|
||||||
|
snapshot: Some(deno_buf::from_raw_parts(data.as_ptr(), data.len())),
|
||||||
|
init_script: None,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn compiler_isolate_init() -> IsolateInit {
|
pub fn compiler_isolate_init() -> IsolateInit {
|
||||||
if cfg!(not(feature = "check-only")) {
|
if cfg!(feature = "no-snapshot-init") {
|
||||||
if cfg!(feature = "use-snapshot-init") {
|
debug!("Deno isolate init without snapshots.");
|
||||||
let data = include_bytes!(concat!(
|
#[cfg(not(feature = "check-only"))]
|
||||||
env!("GN_OUT_DIR"),
|
let source_bytes =
|
||||||
"/gen/snapshot_compiler.bin"
|
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/bundle/compiler.js"));
|
||||||
));
|
#[cfg(feature = "check-only")]
|
||||||
|
let source_bytes = vec![];
|
||||||
|
|
||||||
unsafe {
|
|
||||||
IsolateInit {
|
|
||||||
snapshot: Some(deno_buf::from_raw_parts(data.as_ptr(), data.len())),
|
|
||||||
init_script: None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
#[cfg(not(feature = "check-only"))]
|
|
||||||
let source_bytes =
|
|
||||||
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/bundle/compiler.js"));
|
|
||||||
|
|
||||||
#[cfg(feature = "check-only")]
|
|
||||||
let source_bytes = vec![];
|
|
||||||
|
|
||||||
IsolateInit {
|
|
||||||
snapshot: None,
|
|
||||||
init_script: Some(IsolateInitScript {
|
|
||||||
filename: "gen/bundle/compiler.js".to_string(),
|
|
||||||
source: std::str::from_utf8(source_bytes).unwrap().to_string(),
|
|
||||||
}),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
IsolateInit {
|
IsolateInit {
|
||||||
snapshot: None,
|
snapshot: None,
|
||||||
init_script: None,
|
init_script: Some(IsolateInitScript {
|
||||||
|
filename: "gen/bundle/compiler.js".to_string(),
|
||||||
|
source: std::str::from_utf8(source_bytes).unwrap().to_string(),
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
debug!("Deno isolate init with snapshots.");
|
||||||
|
#[cfg(not(feature = "check-only"))]
|
||||||
|
let data =
|
||||||
|
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/snapshot_compiler.bin"));
|
||||||
|
#[cfg(feature = "check-only")]
|
||||||
|
let data = vec![];
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
IsolateInit {
|
||||||
|
snapshot: Some(deno_buf::from_raw_parts(data.as_ptr(), data.len())),
|
||||||
|
init_script: None,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue