2020-01-23 16:32:52 -05:00
|
|
|
# Deno Core Crate
|
|
|
|
|
|
|
|
[![crates](https://img.shields.io/crates/v/deno_core.svg)](https://crates.io/crates/deno_core)
|
|
|
|
[![docs](https://docs.rs/deno_core/badge.svg)](https://docs.rs/deno_core)
|
|
|
|
|
|
|
|
The main dependency of this crate is
|
|
|
|
[rusty_v8](https://github.com/denoland/rusty_v8), which provides the V8-Rust
|
|
|
|
bindings.
|
2019-04-04 09:35:52 -04:00
|
|
|
|
|
|
|
This Rust crate contains the essential V8 bindings for Deno's command-line
|
2020-09-06 21:44:29 +02:00
|
|
|
interface (Deno CLI). The main abstraction here is the JsRuntime which provides
|
2020-10-11 13:20:40 +02:00
|
|
|
a way to execute JavaScript.
|
|
|
|
|
|
|
|
The JsRuntime implements an event loop abstraction for the executed code that
|
|
|
|
keeps track of all pending tasks (async ops, dynamic module loads). It is user's
|
|
|
|
responsibility to drive that loop by using `JsRuntime::run_event_loop` method -
|
|
|
|
it must be executed in the context of Rust's future executor (eg. tokio, smol).
|
2019-05-20 14:19:16 -04:00
|
|
|
|
2022-03-20 16:08:35 +05:30
|
|
|
Rust functions can be registered in JavaScript using `deno_core::Extension`. Use
|
|
|
|
the `Deno.core.opSync()` and `Deno.core.opAsync()` functions to trigger the op
|
|
|
|
function callback. A conventional way to write ops is using the
|
|
|
|
[`deno_ops`](https://github.com/denoland/deno/blob/main/ops) crate.
|
2019-04-04 09:35:52 -04:00
|
|
|
|
|
|
|
Documentation for this crate is thin at the moment. Please see
|
2021-06-20 12:12:55 -03:00
|
|
|
[hello_world.rs](https://github.com/denoland/deno/blob/main/core/examples/hello_world.rs)
|
|
|
|
and
|
2021-04-24 16:45:40 +03:00
|
|
|
[http_bench_json_ops.rs](https://github.com/denoland/deno/blob/main/core/examples/http_bench_json_ops.rs)
|
2021-06-20 12:12:55 -03:00
|
|
|
as examples of usage.
|
2019-04-04 09:35:52 -04:00
|
|
|
|
2021-05-09 10:39:44 +09:00
|
|
|
TypeScript support and lots of other functionality are not available at this
|
2021-02-19 15:58:19 +01:00
|
|
|
layer. See the [CLI](https://github.com/denoland/deno/tree/main/cli) for that.
|