summaryrefslogtreecommitdiff
path: root/cli/build.rs
diff options
context:
space:
mode:
authorBartek IwaƄczuk <biwanczuk@gmail.com>2020-07-19 19:49:44 +0200
committerGitHub <noreply@github.com>2020-07-19 19:49:44 +0200
commitfa61956f03491101b6ef64423ea2f1f73af26a73 (patch)
treec3800702071ca78aa4dd71bdd0a59a9bbe460bdd /cli/build.rs
parent53adde866dd399aa2509d14508642fce37afb8f5 (diff)
Port internal TS code to JS (#6793)
Co-authored-by: Ryan Dahl <ry@tinyclouds.org>
Diffstat (limited to 'cli/build.rs')
-rw-r--r--cli/build.rs152
1 files changed, 82 insertions, 70 deletions
diff --git a/cli/build.rs b/cli/build.rs
index 695c4f86f..89958325b 100644
--- a/cli/build.rs
+++ b/cli/build.rs
@@ -1,9 +1,11 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
-use deno_core::include_crate_modules;
+
+use deno_core::js_check;
use deno_core::CoreIsolate;
use deno_core::StartupData;
use std::collections::HashMap;
use std::env;
+use std::path::Path;
use std::path::PathBuf;
#[cfg(target_os = "windows")]
@@ -11,101 +13,111 @@ extern crate winapi;
#[cfg(target_os = "windows")]
extern crate winres;
-fn main() {
- // Don't build V8 if "cargo doc" is being run. This is to support docs.rs.
- if env::var_os("RUSTDOCFLAGS").is_some() {
- return;
+fn create_snapshot(
+ mut isolate: CoreIsolate,
+ snapshot_path: &Path,
+ files: Vec<String>,
+) {
+ for file in files {
+ println!("cargo:rerun-if-changed={}", file);
+ js_check(isolate.execute(&file, &std::fs::read_to_string(&file).unwrap()));
}
- // To debug snapshot issues uncomment:
- // deno_typescript::trace_serializer();
-
- println!(
- "cargo:rustc-env=TS_VERSION={}",
- deno_typescript::ts_version()
- );
-
- println!(
- "cargo:rustc-env=TARGET={}",
- std::env::var("TARGET").unwrap()
- );
-
- let extern_crate_modules = include_crate_modules![deno_core];
-
- let c = PathBuf::from(env::var_os("CARGO_MANIFEST_DIR").unwrap());
- let o = PathBuf::from(env::var_os("OUT_DIR").unwrap());
-
- // Main snapshot
- let root_names = vec![c.join("js/main.ts")];
- let bundle_path = o.join("CLI_SNAPSHOT.js");
- let snapshot_path = o.join("CLI_SNAPSHOT.bin");
-
- let main_module_name = deno_typescript::compile_bundle(
- &bundle_path,
- root_names,
- Some(extern_crate_modules.clone()),
- )
- .expect("Bundle compilation failed");
- assert!(bundle_path.exists());
-
- let mut runtime_isolate = CoreIsolate::new(StartupData::None, true);
+ let snapshot = isolate.snapshot();
+ let snapshot_slice: &[u8] = &*snapshot;
+ println!("Snapshot size: {}", snapshot_slice.len());
+ std::fs::write(&snapshot_path, snapshot_slice).unwrap();
+ println!("Snapshot written to: {} ", snapshot_path.display());
+}
- deno_typescript::mksnapshot_bundle(
- &mut runtime_isolate,
- &snapshot_path,
- &bundle_path,
- &main_module_name,
- )
- .expect("Failed to create snapshot");
-
- // Compiler snapshot
- let root_names = vec![c.join("js/compiler.ts")];
- let bundle_path = o.join("COMPILER_SNAPSHOT.js");
- let snapshot_path = o.join("COMPILER_SNAPSHOT.bin");
-
- let main_module_name = deno_typescript::compile_bundle(
- &bundle_path,
- root_names,
- Some(extern_crate_modules),
- )
- .expect("Bundle compilation failed");
- assert!(bundle_path.exists());
+fn create_runtime_snapshot(snapshot_path: &Path, files: Vec<String>) {
+ let runtime_isolate = CoreIsolate::new(StartupData::None, true);
+ create_snapshot(runtime_isolate, snapshot_path, files);
+}
+fn create_compiler_snapshot(
+ snapshot_path: &Path,
+ files: Vec<String>,
+ cwd: &Path,
+) {
let mut runtime_isolate = CoreIsolate::new(StartupData::None, true);
-
let mut custom_libs: HashMap<String, PathBuf> = HashMap::new();
custom_libs.insert(
"lib.deno.window.d.ts".to_string(),
- c.join("js/lib.deno.window.d.ts"),
+ cwd.join("js2/lib.deno.window.d.ts"),
);
custom_libs.insert(
"lib.deno.worker.d.ts".to_string(),
- c.join("js/lib.deno.worker.d.ts"),
+ cwd.join("js2/lib.deno.worker.d.ts"),
);
custom_libs.insert(
"lib.deno.shared_globals.d.ts".to_string(),
- c.join("js/lib.deno.shared_globals.d.ts"),
+ cwd.join("js2/lib.deno.shared_globals.d.ts"),
);
custom_libs.insert(
"lib.deno.ns.d.ts".to_string(),
- c.join("js/lib.deno.ns.d.ts"),
+ cwd.join("js2/lib.deno.ns.d.ts"),
);
custom_libs.insert(
"lib.deno.unstable.d.ts".to_string(),
- c.join("js/lib.deno.unstable.d.ts"),
+ cwd.join("js2/lib.deno.unstable.d.ts"),
);
runtime_isolate.register_op(
"op_fetch_asset",
deno_typescript::op_fetch_asset(custom_libs),
);
- deno_typescript::mksnapshot_bundle_ts(
- &mut runtime_isolate,
- &snapshot_path,
- &bundle_path,
- &main_module_name,
- )
- .expect("Failed to create snapshot");
+ js_check(
+ runtime_isolate.execute("typescript.js", deno_typescript::TYPESCRIPT_CODE),
+ );
+
+ create_snapshot(runtime_isolate, snapshot_path, files);
+}
+
+fn main() {
+ // Don't build V8 if "cargo doc" is being run. This is to support docs.rs.
+ if env::var_os("RUSTDOCFLAGS").is_some() {
+ return;
+ }
+
+ // To debug snapshot issues uncomment:
+ // deno_typescript::trace_serializer();
+
+ println!(
+ "cargo:rustc-env=TS_VERSION={}",
+ deno_typescript::ts_version()
+ );
+
+ println!(
+ "cargo:rustc-env=TARGET={}",
+ std::env::var("TARGET").unwrap()
+ );
+
+ let c = PathBuf::from(env::var_os("CARGO_MANIFEST_DIR").unwrap());
+ let o = PathBuf::from(env::var_os("OUT_DIR").unwrap());
+
+ // Main snapshot
+ let runtime_snapshot_path = o.join("CLI_SNAPSHOT.bin");
+ let compiler_snapshot_path = o.join("COMPILER_SNAPSHOT.bin");
+
+ let mut js_files = std::fs::read_dir("js2/")
+ .unwrap()
+ .map(|dir_entry| {
+ let file = dir_entry.unwrap();
+ file.path().to_string_lossy().to_string()
+ })
+ .filter(|filename| filename.ends_with(".js"))
+ .collect::<Vec<String>>();
+
+ js_files.sort();
+
+ let runtime_files = js_files
+ .clone()
+ .into_iter()
+ .filter(|filepath| !filepath.ends_with("compiler.js"))
+ .collect::<Vec<String>>();
+ create_runtime_snapshot(&runtime_snapshot_path, runtime_files);
+ create_compiler_snapshot(&compiler_snapshot_path, js_files, &c);
set_binary_metadata();
}