mirror of
https://github.com/denoland/deno.git
synced 2024-12-27 17:49:08 -05:00
55362452a8
Currently the resolution for extension sources is different depending on whether `include_js_files_for_snapshotting` is enabled. If sources are embedded it uses `include_str!()` which is module-relative. If sources are read at runtime paths are joined to `CARGO_MANIFEST_DIR` and are package-relative. This makes them both package-relative. Fixes `cargo run -p deno_runtime --example extension_with_esm --features include_js_files_for_snapshotting`.
36 lines
1.1 KiB
Rust
36 lines
1.1 KiB
Rust
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
use std::path::Path;
|
|
use std::rc::Rc;
|
|
|
|
use deno_core::error::AnyError;
|
|
use deno_core::FsModuleLoader;
|
|
use deno_core::ModuleSpecifier;
|
|
use deno_runtime::permissions::PermissionsContainer;
|
|
use deno_runtime::worker::MainWorker;
|
|
use deno_runtime::worker::WorkerOptions;
|
|
|
|
deno_core::extension!(
|
|
hello_runtime,
|
|
esm_entry_point = "ext:hello_runtime/bootstrap.js",
|
|
esm = [dir "examples/extension_with_esm", "bootstrap.js"]
|
|
);
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), AnyError> {
|
|
let js_path = Path::new(env!("CARGO_MANIFEST_DIR"))
|
|
.join("examples/extension_with_esm/main.js");
|
|
let main_module = ModuleSpecifier::from_file_path(js_path).unwrap();
|
|
let mut worker = MainWorker::bootstrap_from_options(
|
|
main_module.clone(),
|
|
PermissionsContainer::allow_all(),
|
|
WorkerOptions {
|
|
module_loader: Rc::new(FsModuleLoader),
|
|
extensions: vec![hello_runtime::init_ops_and_esm()],
|
|
..Default::default()
|
|
},
|
|
);
|
|
worker.execute_main_module(&main_module).await?;
|
|
worker.run_event_loop(false).await?;
|
|
Ok(())
|
|
}
|