Go to file
2020-07-11 14:36:43 +08:00
.ci Split no_stdlib and no_std into two features. 2020-03-18 12:04:26 +08:00
.github/workflows Move benchmark.yml to correct location. 2020-07-04 15:43:48 +08:00
benches More benchmarks and examples. 2020-05-31 23:44:49 +08:00
doc Refine docs and add custom syntax. 2020-07-10 22:01:47 +08:00
examples Add doc to serde example. 2020-07-04 22:52:45 +08:00
scripts Fix scripts and tests. 2020-06-27 21:19:53 +08:00
src Refine docs and add custom syntax. 2020-07-10 22:01:47 +08:00
tests Refine docs and add custom syntax. 2020-07-10 22:01:47 +08:00
.gitignore Expose FnPtr and move name checking into 2020-07-06 21:30:35 +08:00
.travis.yml Added no_std support 2020-03-17 19:26:11 +01:00
Cargo.toml Refine docs and add custom syntax. 2020-07-10 22:01:47 +08:00
LICENSE.txt Add LICENSE. 2020-03-22 00:32:07 +08:00
README.md Merge branch 'master' of https://github.com/jonathandturner/rhai 2020-07-11 14:36:43 +08:00
RELEASES.md FIXED - method calls inside dot chain. 2020-07-09 22:21:07 +08:00
rhai_logo.png Refactor. 2020-06-29 23:55:28 +08:00

Rhai - Embedded Scripting for Rust

GitHub last commit Travis (.org) license crates.io crates.io API Docs

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

Features

  • Easy-to-use language similar to JavaScript+Rust with dynamic typing.
  • 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.
  • Easily call a script-defined function from Rust.
  • Fairly low compile-time overhead.
  • Fairly efficient evaluation (1 million iterations in 0.3 sec on a single core, 2.3 GHz Linux VM).
  • Relatively little unsafe code (yes there are some for performance reasons, and most unsafe code is limited to one single source file, all with names starting with "unsafe_").
  • Re-entrant scripting engine can be made Send + Sync (via the sync feature).
  • Sand-boxed - the scripting engine, if declared immutable, cannot mutate the containing environment unless explicitly permitted (e.g. via a RefCell).
  • 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.
  • Function overloading.
  • Operator overloading.
  • Support for use as a DSL - disabling keywords/operators, custom operators and extending the language with custom syntax.
  • Dynamic dispatch via function pointers.
  • Some support for object-oriented programming (OOP).
  • Organize code base with dynamically-loadable modules.
  • Serialization/deserialization support via serde (requires the serde feature).
  • Surgically disable keywords and operators to restrict the language.
  • Scripts are optimized (useful for template-based machine-generated scripts) for repeated evaluations.
  • Support for minimal builds by excluding unneeded language features.

Documentation

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

Playground

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