Go to file
Stephen Chung b5879f9304
Merge pull request #307 from schungx/master
Better treatment of constants and doc-comments for functions.
2020-12-12 20:20:31 +08:00
.github/workflows Merge pull request #301 from schungx/master 2020-11-28 17:37:22 +08:00
benches Increase switch benchmark size. 2020-12-11 12:51:28 +08:00
codegen Fix tests. 2020-11-30 21:16:59 +08:00
doc Provide Position to debug. 2020-12-12 11:47:18 +08:00
examples Add ScriptFnMetadata. 2020-12-12 18:44:28 +08:00
no_std/no_std_test f32_float for no-std example. 2020-11-04 17:12:21 +08:00
scripts Fix recursive file import bug. 2020-11-08 23:00:03 +08:00
src Add doc-comment to function metadata. 2020-12-12 20:09:29 +08:00
tests Change AST to struct. 2020-12-12 15:57:55 +08:00
.gitignore Improve shared value treatment. 2020-08-08 16:24:10 +08:00
Cargo.toml Bump version. 2020-12-07 22:21:02 +08:00
LICENSE-APACHE.txt Remove appendix from LICENSE-APACHE.txt 2020-07-25 07:08:13 +02:00
LICENSE-MIT.txt Add LICENSE-MIT.txt (based on Syn) 2020-07-25 07:08:16 +02:00
README.md Docs revision. 2020-11-04 17:10:26 +08:00
RELEASES.md Add ScriptFnMetadata. 2020-12-12 18:44:28 +08:00

Rhai - Embedded Scripting for Rust

GitHub last commit Build Status license crates.io crates.io API Docs chat Reddit

Rhai is an embedded scripting language and evaluation engine for Rust that gives a safe and easy way to add scripting to any application.

Supported targets and builds

  • All common CPU targets for Windows, Linux and MacOS.
  • WebAssembly (WASM)
  • no-std
  • Minimum Rust version 1.45

Standard features

  • Easy-to-use language similar to JavaScript+Rust with dynamic typing.
  • Fairly low compile-time overhead.
  • Fairly efficient evaluation (1 million iterations in 0.3 sec on a single core, 2.3 GHz Linux VM).
  • Tight integration with native Rust functions and types, including getters/setters, methods and indexers.
  • Freely pass Rust variables/constants into a script via an external Scope - all clonable Rust types are supported; no need to implement any special trait.
  • Easily call a script-defined function from Rust.
  • Relatively little unsafe code (yes there are some for performance reasons).
  • Few dependencies (currently only smallvec).
  • Re-entrant scripting engine can be made Send + Sync (via the sync feature).
  • Scripts are optimized (useful for template-based machine-generated scripts) for repeated evaluations.
  • Easy custom API development via plugins system powered by procedural macros.
  • Function overloading and operator overloading.
  • Dynamic dispatch via function pointers with additional support for currying.
  • Closures (anonymous functions) that can capture shared values.
  • Some syntactic support for object-oriented programming (OOP).
  • Organize code base with dynamically-loadable modules.
  • Serialization/deserialization support via serde (requires the serde feature).
  • Support for minimal builds by excluding unneeded language features.

Protected against attacks

  • Sand-boxed - the scripting engine, if declared immutable, cannot mutate the containing environment unless explicitly permitted.
  • Rugged - protected against malicious attacks (such as stack-overflow, over-sized data, and runaway scripts etc.) that may come from untrusted third-party user-land scripts.
  • Track script evaluation progress and manually terminate a script run.

For those who actually want their own language

Documentation

See The Rhai Book for details on the Rhai scripting engine and language.

To build The Book, first install mdbook and mdbook-tera (for templating). Running mdbook build builds it.

Playground

An Online Playground is available with syntax-highlighting editor. Scripts can be evaluated directly from the editor.

License

Licensed under either of the following, at your choice:

Unless explicitly stated otherwise, any contribution intentionally submitted for inclusion in this crate, as defined in the Apache-2.0 license, shall be dual-licensed as above, without any additional terms or conditions.