From 4244f890186e08ae8104d9764f573220bf4e702c Mon Sep 17 00:00:00 2001 From: Iban Eguia Moraza Date: Sat, 25 Mar 2023 22:44:10 +0100 Subject: [PATCH] Added an example usage to the main boa_engine documentation page, and a README for examples --- boa_engine/src/lib.rs | 46 ++++++++++++++++++++++++++++++++++++------ boa_examples/README.md | 8 ++++++++ 2 files changed, 48 insertions(+), 6 deletions(-) create mode 100644 boa_examples/README.md diff --git a/boa_engine/src/lib.rs b/boa_engine/src/lib.rs index 2cb02a5440f..a1c2602c5e9 100644 --- a/boa_engine/src/lib.rs +++ b/boa_engine/src/lib.rs @@ -1,18 +1,51 @@ //! Boa's **`boa_engine`** crate implements ECMAScript's standard library of builtin objects //! and an ECMAScript context, bytecompiler, and virtual machine for code execution. //! +//! # About Boa +//! +//! Boa is an open-source, experimental ECMAScript Engine written in Rust for lexing, parsing and +//! executing ECMAScript/JavaScript. Currently, Boa supports some of the [language][boa-conformance]. +//! More information can be viewed at [Boa's website][boa-web]. +//! +//! Try out the most recent release with Boa's live demo [playground][boa-playground]. +//! +//! # Example usage +//! +//! You can find multiple examples of the usage of Boa in the [`boa_examples`][examples] crate. In +//! order to use Boa in your project, you will need to add the `boa_engine` crate to your +//! `Cargo.toml` file. You will need to use a [`Source`] structure to handle the JavaScript code +//! to execute, and a [`Context`] structure to execute the code: +//! +//! ``` +//! use boa_engine::{Context, Source}; +//! +//! let js_code = "console.log('Hello World from a JS code string!')"; +//! +//! // Instantiate the execution context +//! let mut context = Context::default(); +//! +//! // Parse the source code +//! match context.eval_script(Source::from_bytes(js_code)) { +//! Ok(res) => { +//! println!( +//! "{}", +//! res.to_string(&mut context).unwrap().to_std_string_escaped() +//! ); +//! } +//! Err(e) => { +//! // Pretty print the error +//! eprintln!("Uncaught {e}"); +//! } +//! }; +//! ``` +//! //! # Crate Features +//! //! - **serde** - Enables serialization and deserialization of the AST (Abstract Syntax Tree). //! - **console** - Enables `boa`'s [WHATWG `console`][whatwg] object implementation. //! - **profiler** - Enables profiling with measureme (this is mostly internal). //! - **intl** - Enables `boa`'s [ECMA-402 Internationalization API][ecma-402] (`Intl` object) //! -//! # About Boa -//! Boa is an open-source, experimental ECMAScript Engine written in Rust for lexing, parsing and executing ECMAScript/JavaScript. Currently, Boa -//! supports some of the [language][boa-conformance]. More information can be viewed at [Boa's website][boa-web]. -//! -//! Try out the most recent release with Boa's live demo [playground][boa-playground]. -//! //! # Boa Crates //! - **`boa_ast`** - Boa's ECMAScript Abstract Syntax Tree. //! - **`boa_engine`** - Boa's implementation of ECMAScript builtin objects and execution. @@ -28,6 +61,7 @@ //! [boa-conformance]: https://boajs.dev/boa/test262/ //! [boa-web]: https://boajs.dev/ //! [boa-playground]: https://boajs.dev/boa/playground/ +//! [examples]: https://github.com/boa-dev/boa/tree/main/boa_examples #![doc( html_logo_url = "https://raw.githubusercontent.com/boa-dev/boa/main/assets/logo.svg", diff --git a/boa_examples/README.md b/boa_examples/README.md new file mode 100644 index 00000000000..c5c8dc5cbd1 --- /dev/null +++ b/boa_examples/README.md @@ -0,0 +1,8 @@ +# Examples of usage for `boa_engine` + +In this crate you can find examples of the usage of the Boa JavaScript engine. The simplest +example can be found in the [loadstring.rs](./src/bin/loadstring.rs) file. A similar example +that uses JavaScript stored in a file can be found in [loadfile.rs](./src/bin/loadfile.rs). + +You can also find examples of specific Rust APIs for arrays, maps, sets, typed arrays and much +more.