1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-09 23:58:23 -05:00

Minor tweaks (#2569)

1. Separate Snapshot and Script StartupData functions based on cfg "no-snapshot-init"
2. Replace deprecated Once::ONCE_INIT with Once::new (https://github.com/rust-lang/rust/pull/61757)
3. Elide lifetime
4. Fix typos
This commit is contained in:
Gurwinder Singh 2019-06-23 17:19:49 +05:30 committed by Ryan Dahl
parent b9fbd55214
commit 6fa6828e5f
2 changed files with 58 additions and 53 deletions

View file

@ -1,56 +1,61 @@
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
use deno::{Script, StartupData}; #[cfg(feature = "no-snapshot-init")]
use deno::Script;
use deno::StartupData;
#[cfg(feature = "no-snapshot-init")]
pub fn deno_isolate_init() -> StartupData<'static> { pub fn deno_isolate_init() -> StartupData<'static> {
if cfg!(feature = "no-snapshot-init") {
debug!("Deno isolate init without snapshots."); debug!("Deno isolate init without snapshots.");
#[cfg(not(feature = "check-only"))] #[cfg(not(feature = "check-only"))]
let source_bytes = let source =
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/cli/bundle/main.js")); include_str!(concat!(env!("GN_OUT_DIR"), "/gen/cli/bundle/main.js"));
#[cfg(feature = "check-only")] #[cfg(feature = "check-only")]
let source_bytes = b""; let source = "";
StartupData::Script(Script { StartupData::Script(Script {
filename: "gen/cli/bundle/main.js", filename: "gen/cli/bundle/main.js",
source: std::str::from_utf8(&source_bytes[..]).unwrap(), source,
}) })
} else { }
#[cfg(not(feature = "no-snapshot-init"))]
pub fn deno_isolate_init() -> StartupData<'static> {
debug!("Deno isolate init with snapshots."); debug!("Deno isolate init with snapshots.");
#[cfg(not(any(feature = "check-only", feature = "no-snapshot-init")))] #[cfg(not(feature = "check-only"))]
let data = let data =
include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/cli/snapshot_deno.bin")); include_bytes!(concat!(env!("GN_OUT_DIR"), "/gen/cli/snapshot_deno.bin"));
#[cfg(any(feature = "check-only", feature = "no-snapshot-init"))] #[cfg(feature = "check-only")]
let data = b""; let data = b"";
StartupData::Snapshot(data) StartupData::Snapshot(data)
} }
}
#[cfg(feature = "no-snapshot-init")]
pub fn compiler_isolate_init() -> StartupData<'static> { pub fn compiler_isolate_init() -> StartupData<'static> {
if cfg!(feature = "no-snapshot-init") {
debug!("Compiler isolate init without snapshots."); debug!("Compiler isolate init without snapshots.");
#[cfg(not(feature = "check-only"))] #[cfg(not(feature = "check-only"))]
let source_bytes = include_bytes!(concat!( let source =
env!("GN_OUT_DIR"), include_str!(concat!(env!("GN_OUT_DIR"), "/gen/cli/bundle/compiler.js"));
"/gen/cli/bundle/compiler.js"
));
#[cfg(feature = "check-only")] #[cfg(feature = "check-only")]
let source_bytes = b""; let source = "";
StartupData::Script(Script { StartupData::Script(Script {
filename: "gen/cli/bundle/compiler.js", filename: "gen/cli/bundle/compiler.js",
source: std::str::from_utf8(&source_bytes[..]).unwrap(), source,
}) })
} else { }
#[cfg(not(feature = "no-snapshot-init"))]
pub fn compiler_isolate_init() -> StartupData<'static> {
debug!("Deno isolate init with snapshots."); debug!("Deno isolate init with snapshots.");
#[cfg(not(any(feature = "check-only", feature = "no-snapshot-init")))] #[cfg(not(feature = "check-only"))]
let data = include_bytes!(concat!( let data = include_bytes!(concat!(
env!("GN_OUT_DIR"), env!("GN_OUT_DIR"),
"/gen/cli/snapshot_compiler.bin" "/gen/cli/snapshot_compiler.bin"
)); ));
#[cfg(any(feature = "check-only", feature = "no-snapshot-init"))] #[cfg(feature = "check-only")]
let data = b""; let data = b"";
StartupData::Snapshot(data) StartupData::Snapshot(data)
} }
}

View file

@ -25,7 +25,7 @@ use libc::c_void;
use std::ffi::CStr; use std::ffi::CStr;
use std::ffi::CString; use std::ffi::CString;
use std::ptr::null; use std::ptr::null;
use std::sync::{Arc, Mutex, Once, ONCE_INIT}; use std::sync::{Arc, Mutex, Once};
pub type Buf = Box<[u8]>; pub type Buf = Box<[u8]>;
@ -55,8 +55,8 @@ struct OwnedScript {
pub filename: String, pub filename: String,
} }
impl<'a> From<Script<'a>> for OwnedScript { impl From<Script<'_>> for OwnedScript {
fn from(s: Script<'a>) -> OwnedScript { fn from(s: Script) -> OwnedScript {
OwnedScript { OwnedScript {
source: s.source.to_string(), source: s.source.to_string(),
filename: s.filename.to_string(), filename: s.filename.to_string(),
@ -133,10 +133,10 @@ impl Drop for Isolate {
} }
} }
static DENO_INIT: Once = ONCE_INIT; static DENO_INIT: Once = Once::new();
impl Isolate { impl Isolate {
/// startup_data defines the snapshot or script used at startup to initalize /// startup_data defines the snapshot or script used at startup to initialize
/// the isolate. /// the isolate.
pub fn new(startup_data: StartupData, will_snapshot: bool) -> Self { pub fn new(startup_data: StartupData, will_snapshot: bool) -> Self {
DENO_INIT.call_once(|| { DENO_INIT.call_once(|| {
@ -157,7 +157,7 @@ impl Isolate {
let mut startup_script: Option<OwnedScript> = None; let mut startup_script: Option<OwnedScript> = None;
// Seperate into Option values for each startup type // Separate into Option values for each startup type
match startup_data { match startup_data {
StartupData::Script(d) => { StartupData::Script(d) => {
startup_script = Some(d.into()); startup_script = Some(d.into());