2017-10-28 22:33:00 +02:00
|
|
|
//! # Rhai - embedded scripting for Rust
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2020-10-10 07:41:55 +02:00
|
|
|
//! Rhai is a tiny, simple and fast embedded scripting language for Rust
|
2017-10-28 22:33:00 +02:00
|
|
|
//! that gives you a safe and easy way to add scripting to your applications.
|
2020-06-22 16:02:49 +02:00
|
|
|
//! It provides a familiar syntax based on JavaScript and Rust and a simple Rust interface.
|
2020-04-09 04:38:33 +02:00
|
|
|
//! Here is a quick example.
|
|
|
|
//!
|
|
|
|
//! First, the contents of `my_script.rhai`:
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2020-03-19 06:52:10 +01:00
|
|
|
//! ```,ignore
|
2020-04-09 04:38:33 +02:00
|
|
|
//! // Brute force factorial function
|
2017-10-28 22:33:00 +02:00
|
|
|
//! fn factorial(x) {
|
|
|
|
//! if x == 1 { return 1; }
|
2020-03-24 09:57:35 +01:00
|
|
|
//! x * factorial(x - 1)
|
2017-10-28 22:33:00 +02:00
|
|
|
//! }
|
|
|
|
//!
|
2020-04-09 04:38:33 +02:00
|
|
|
//! // Calling an external function 'compute'
|
|
|
|
//! compute(factorial(10))
|
2017-10-28 22:33:00 +02:00
|
|
|
//! ```
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2017-10-28 22:33:00 +02:00
|
|
|
//! And the Rust part:
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2020-03-19 06:52:10 +01:00
|
|
|
//! ```,no_run
|
2020-03-09 14:09:53 +01:00
|
|
|
//! use rhai::{Engine, EvalAltResult, RegisterFn};
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2020-04-21 17:25:12 +02:00
|
|
|
//! fn main() -> Result<(), Box<EvalAltResult>>
|
2020-03-09 14:09:53 +01:00
|
|
|
//! {
|
2020-04-09 04:38:33 +02:00
|
|
|
//! // Define external function
|
2020-03-09 14:09:53 +01:00
|
|
|
//! fn compute_something(x: i64) -> bool {
|
2020-03-24 09:57:35 +01:00
|
|
|
//! (x % 40) == 0
|
2020-03-09 14:09:53 +01:00
|
|
|
//! }
|
|
|
|
//!
|
2020-04-09 04:38:33 +02:00
|
|
|
//! // Create scripting engine
|
2020-03-09 14:09:53 +01:00
|
|
|
//! let mut engine = Engine::new();
|
|
|
|
//!
|
2020-04-09 04:38:33 +02:00
|
|
|
//! // Register external function as 'compute'
|
|
|
|
//! engine.register_fn("compute", compute_something);
|
2017-12-20 12:16:14 +01:00
|
|
|
//!
|
2020-04-07 07:23:06 +02:00
|
|
|
//! # #[cfg(not(feature = "no_std"))]
|
2020-06-17 03:54:17 +02:00
|
|
|
//! # #[cfg(not(target_arch = "wasm32"))]
|
2020-04-09 04:38:33 +02:00
|
|
|
//! assert_eq!(
|
2020-04-09 12:45:49 +02:00
|
|
|
//! // Evaluate the script, expects a 'bool' return
|
2020-04-09 04:38:33 +02:00
|
|
|
//! engine.eval_file::<bool>("my_script.rhai".into())?,
|
|
|
|
//! true
|
|
|
|
//! );
|
2020-03-09 14:09:53 +01:00
|
|
|
//!
|
|
|
|
//! Ok(())
|
|
|
|
//! }
|
2017-10-28 22:33:00 +02:00
|
|
|
//! ```
|
|
|
|
//!
|
2020-07-29 16:43:50 +02:00
|
|
|
//! # Documentation
|
2020-04-03 13:42:01 +02:00
|
|
|
//!
|
2020-06-23 04:43:24 +02:00
|
|
|
//! See [The Rhai Book](https://schungx.github.io/rhai) for details on the Rhai script engine and language.
|
2016-03-03 16:55:28 +01:00
|
|
|
|
2020-03-18 05:04:26 +01:00
|
|
|
#![cfg_attr(feature = "no_std", no_std)]
|
2017-10-02 23:44:45 +02:00
|
|
|
|
2020-03-18 05:04:26 +01:00
|
|
|
#[cfg(feature = "no_std")]
|
2020-03-17 19:26:11 +01:00
|
|
|
extern crate alloc;
|
|
|
|
|
2020-10-28 15:18:44 +01:00
|
|
|
mod ast;
|
|
|
|
mod dynamic;
|
2016-03-03 16:55:28 +01:00
|
|
|
mod engine;
|
2020-10-28 15:18:44 +01:00
|
|
|
mod engine_api;
|
|
|
|
mod engine_settings;
|
2020-07-23 12:40:42 +02:00
|
|
|
mod fn_args;
|
2020-04-08 17:01:48 +02:00
|
|
|
mod fn_call;
|
2020-04-09 04:38:33 +02:00
|
|
|
mod fn_func;
|
2020-06-18 12:39:28 +02:00
|
|
|
mod fn_native;
|
2016-03-03 16:55:28 +01:00
|
|
|
mod fn_register;
|
2020-05-05 06:24:13 +02:00
|
|
|
mod module;
|
2020-03-09 14:57:07 +01:00
|
|
|
mod optimize;
|
2020-04-20 18:11:25 +02:00
|
|
|
pub mod packages;
|
2020-10-28 15:18:44 +01:00
|
|
|
mod parse_error;
|
2016-03-03 16:55:28 +01:00
|
|
|
mod parser;
|
2020-07-02 06:47:24 +02:00
|
|
|
pub mod plugin;
|
2020-03-04 15:00:01 +01:00
|
|
|
mod result;
|
2020-03-03 08:20:20 +01:00
|
|
|
mod scope;
|
2020-07-03 16:48:33 +02:00
|
|
|
#[cfg(feature = "serde")]
|
2020-10-10 07:41:55 +02:00
|
|
|
mod serde_impl;
|
2020-03-18 15:03:50 +01:00
|
|
|
mod stdlib;
|
2020-07-09 13:54:28 +02:00
|
|
|
mod syntax;
|
2020-04-15 16:21:23 +02:00
|
|
|
mod token;
|
2020-05-14 12:27:22 +02:00
|
|
|
mod r#unsafe;
|
2020-05-05 06:24:13 +02:00
|
|
|
mod utils;
|
2016-03-03 16:55:28 +01:00
|
|
|
|
2020-10-28 15:18:44 +01:00
|
|
|
pub use ast::AST;
|
|
|
|
pub use dynamic::Dynamic;
|
2020-10-11 15:58:11 +02:00
|
|
|
pub use engine::{Engine, EvalContext};
|
2020-10-18 11:02:17 +02:00
|
|
|
pub use fn_native::{FnPtr, NativeCallContext};
|
2020-09-30 16:55:40 +02:00
|
|
|
pub use fn_register::{RegisterFn, RegisterResultFn};
|
2020-05-13 13:21:42 +02:00
|
|
|
pub use module::Module;
|
2020-10-28 15:18:44 +01:00
|
|
|
pub use parse_error::{ParseError, ParseErrorType};
|
|
|
|
pub use parser::{ImmutableString, INT};
|
2020-03-04 15:00:01 +01:00
|
|
|
pub use result::EvalAltResult;
|
2020-03-25 04:24:29 +01:00
|
|
|
pub use scope::Scope;
|
2020-10-11 15:58:11 +02:00
|
|
|
pub use syntax::Expression;
|
2020-04-15 16:21:23 +02:00
|
|
|
pub use token::Position;
|
2020-09-25 04:59:21 +02:00
|
|
|
|
|
|
|
#[cfg(feature = "internals")]
|
2020-10-28 15:18:44 +01:00
|
|
|
pub use utils::{calc_native_fn_hash, calc_script_fn_hash};
|
2020-03-10 10:10:33 +01:00
|
|
|
|
2020-09-25 04:59:21 +02:00
|
|
|
#[cfg(not(feature = "internals"))]
|
2020-10-28 15:18:44 +01:00
|
|
|
pub(crate) use utils::{calc_native_fn_hash, calc_script_fn_hash};
|
2020-09-25 04:59:21 +02:00
|
|
|
|
2020-08-01 18:52:26 +02:00
|
|
|
pub use rhai_codegen::*;
|
|
|
|
|
2020-06-30 12:34:58 +02:00
|
|
|
#[cfg(not(feature = "no_function"))]
|
|
|
|
pub use parser::FnAccess;
|
2020-08-07 01:36:15 +02:00
|
|
|
#[cfg(feature = "no_function")]
|
|
|
|
pub use parser::FnAccess;
|
2020-06-30 12:34:58 +02:00
|
|
|
|
2020-04-08 17:01:48 +02:00
|
|
|
#[cfg(not(feature = "no_function"))]
|
2020-04-09 04:38:33 +02:00
|
|
|
pub use fn_func::Func;
|
2020-04-08 17:01:48 +02:00
|
|
|
|
2020-03-10 10:10:33 +01:00
|
|
|
#[cfg(not(feature = "no_index"))]
|
|
|
|
pub use engine::Array;
|
2020-03-14 13:06:40 +01:00
|
|
|
|
2020-03-29 17:53:35 +02:00
|
|
|
#[cfg(not(feature = "no_object"))]
|
|
|
|
pub use engine::Map;
|
|
|
|
|
2020-03-14 13:06:40 +01:00
|
|
|
#[cfg(not(feature = "no_float"))]
|
|
|
|
pub use parser::FLOAT;
|
2020-03-15 15:39:58 +01:00
|
|
|
|
2020-05-05 09:00:10 +02:00
|
|
|
#[cfg(not(feature = "no_module"))]
|
2020-05-13 13:21:42 +02:00
|
|
|
pub use module::ModuleResolver;
|
2020-05-05 17:57:25 +02:00
|
|
|
|
2020-05-15 15:40:54 +02:00
|
|
|
/// Module containing all built-in _module resolvers_ available to Rhai.
|
2020-05-05 17:57:25 +02:00
|
|
|
#[cfg(not(feature = "no_module"))]
|
2020-10-10 07:41:55 +02:00
|
|
|
pub use crate::module::resolvers as module_resolvers;
|
2020-05-05 09:00:10 +02:00
|
|
|
|
2020-10-10 07:41:55 +02:00
|
|
|
/// _[SERDE]_ Serialization and deserialization support for [`serde`](https://crates.io/crates/serde).
|
2020-10-03 12:49:11 +02:00
|
|
|
/// Exported under the `serde` feature.
|
2020-07-03 11:19:55 +02:00
|
|
|
#[cfg(feature = "serde")]
|
2020-10-10 07:41:55 +02:00
|
|
|
pub mod serde {
|
|
|
|
pub use super::serde_impl::de::from_dynamic;
|
|
|
|
pub use super::serde_impl::ser::to_dynamic;
|
2020-07-03 11:19:55 +02:00
|
|
|
}
|
|
|
|
|
2020-03-15 15:39:58 +01:00
|
|
|
#[cfg(not(feature = "no_optimize"))]
|
|
|
|
pub use optimize::OptimizationLevel;
|
2020-06-23 04:43:24 +02:00
|
|
|
|
|
|
|
// Expose internal data structures.
|
|
|
|
|
2020-07-09 13:54:28 +02:00
|
|
|
#[cfg(feature = "internals")]
|
|
|
|
#[deprecated(note = "this type is volatile and may change")]
|
2020-10-28 15:18:44 +01:00
|
|
|
pub use parse_error::LexError;
|
2020-07-09 13:54:28 +02:00
|
|
|
|
2020-06-23 04:43:24 +02:00
|
|
|
#[cfg(feature = "internals")]
|
2020-06-25 05:07:46 +02:00
|
|
|
#[deprecated(note = "this type is volatile and may change")]
|
2020-06-26 13:44:50 +02:00
|
|
|
pub use token::{get_next_token, parse_string_literal, InputStream, Token, TokenizeState};
|
2020-06-23 04:43:24 +02:00
|
|
|
|
|
|
|
#[cfg(feature = "internals")]
|
2020-06-25 05:07:46 +02:00
|
|
|
#[deprecated(note = "this type is volatile and may change")]
|
2020-10-28 12:11:17 +01:00
|
|
|
pub use parser::{
|
|
|
|
BinaryExpr, CustomExpr, Expr, FloatWrapper, Ident, IdentX, ReturnType, ScriptFnDef, Stmt,
|
|
|
|
};
|
2020-07-09 13:54:28 +02:00
|
|
|
|
|
|
|
#[cfg(feature = "internals")]
|
|
|
|
#[deprecated(note = "this type is volatile and may change")]
|
2020-07-26 07:51:09 +02:00
|
|
|
pub use engine::{Imports, Limits, State as EvalState};
|
2020-07-22 07:08:51 +02:00
|
|
|
|
2020-06-23 04:43:24 +02:00
|
|
|
#[cfg(feature = "internals")]
|
2020-06-25 05:07:46 +02:00
|
|
|
#[deprecated(note = "this type is volatile and may change")]
|
2020-06-23 04:43:24 +02:00
|
|
|
pub use module::ModuleRef;
|
|
|
|
|
2020-10-10 07:41:55 +02:00
|
|
|
/// _[INTERNALS]_ Alias to [`smallvec::SmallVec<[T; 4]>`](https://crates.io/crates/smallvec),
|
|
|
|
/// which is a specialized `Vec` backed by a small, fixed-size array when there are <= 4 items stored.
|
|
|
|
/// Exported under the `internals` feature only.
|
|
|
|
#[cfg(not(feature = "internals"))]
|
|
|
|
type StaticVec<T> = smallvec::SmallVec<[T; 4]>;
|
|
|
|
|
|
|
|
/// _[INTERNALS]_ Alias to [`smallvec::SmallVec<[T; 4]>`](https://crates.io/crates/smallvec),
|
|
|
|
/// which is a specialized `Vec` backed by a small, fixed-size array when there are <= 4 items stored.
|
|
|
|
/// Exported under the `internals` feature only.
|
2020-06-23 04:43:24 +02:00
|
|
|
#[cfg(feature = "internals")]
|
2020-10-10 07:41:55 +02:00
|
|
|
pub type StaticVec<T> = smallvec::SmallVec<[T; 4]>;
|