2020-05-15 15:40:54 +02:00
|
|
|
//! Module containing all built-in _packages_ available to Rhai, plus facilities to define custom packages.
|
2020-04-20 18:11:25 +02:00
|
|
|
|
2020-12-22 16:45:14 +01:00
|
|
|
use crate::{Module, Shared};
|
2020-04-20 18:11:25 +02:00
|
|
|
|
2020-05-23 12:59:28 +02:00
|
|
|
pub(crate) mod arithmetic;
|
2021-12-22 12:59:48 +01:00
|
|
|
pub(crate) mod array_basic;
|
2022-01-03 16:10:20 +01:00
|
|
|
mod bit_field;
|
2021-12-22 12:59:48 +01:00
|
|
|
pub(crate) mod blob_basic;
|
2022-01-25 07:32:42 +01:00
|
|
|
mod debugging;
|
2020-06-25 12:07:57 +02:00
|
|
|
mod fn_basic;
|
2022-04-09 07:11:32 +02:00
|
|
|
pub(crate) mod iter_basic;
|
2021-05-02 17:57:35 +02:00
|
|
|
mod lang_core;
|
2020-04-20 18:11:25 +02:00
|
|
|
mod logic;
|
|
|
|
mod map_basic;
|
|
|
|
mod math_basic;
|
|
|
|
mod pkg_core;
|
|
|
|
mod pkg_std;
|
|
|
|
mod string_basic;
|
|
|
|
mod string_more;
|
|
|
|
mod time_basic;
|
|
|
|
|
|
|
|
pub use arithmetic::ArithmeticPackage;
|
2020-04-21 17:25:12 +02:00
|
|
|
#[cfg(not(feature = "no_index"))]
|
2020-04-20 18:11:25 +02:00
|
|
|
pub use array_basic::BasicArrayPackage;
|
2022-01-03 16:10:20 +01:00
|
|
|
pub use bit_field::BitFieldPackage;
|
2021-11-23 07:58:54 +01:00
|
|
|
#[cfg(not(feature = "no_index"))]
|
|
|
|
pub use blob_basic::BasicBlobPackage;
|
2022-01-25 07:32:42 +01:00
|
|
|
#[cfg(feature = "debugging")]
|
|
|
|
pub use debugging::DebuggingPackage;
|
2020-06-25 12:07:57 +02:00
|
|
|
pub use fn_basic::BasicFnPackage;
|
2020-04-20 18:11:25 +02:00
|
|
|
pub use iter_basic::BasicIteratorPackage;
|
2021-12-20 04:42:39 +01:00
|
|
|
pub use lang_core::LanguageCorePackage;
|
2020-04-20 18:11:25 +02:00
|
|
|
pub use logic::LogicPackage;
|
2020-04-21 17:25:12 +02:00
|
|
|
#[cfg(not(feature = "no_object"))]
|
2020-04-20 18:11:25 +02:00
|
|
|
pub use map_basic::BasicMapPackage;
|
|
|
|
pub use math_basic::BasicMathPackage;
|
|
|
|
pub use pkg_core::CorePackage;
|
|
|
|
pub use pkg_std::StandardPackage;
|
|
|
|
pub use string_basic::BasicStringPackage;
|
|
|
|
pub use string_more::MoreStringPackage;
|
2020-04-24 06:39:24 +02:00
|
|
|
#[cfg(not(feature = "no_std"))]
|
2020-04-20 18:11:25 +02:00
|
|
|
pub use time_basic::BasicTimePackage;
|
|
|
|
|
2020-04-21 17:01:10 +02:00
|
|
|
/// Trait that all packages must implement.
|
|
|
|
pub trait Package {
|
2021-12-09 05:49:12 +01:00
|
|
|
/// Initialize the package.
|
|
|
|
/// Functions should be registered into `module` here.
|
|
|
|
fn init(module: &mut Module);
|
2020-04-20 18:11:25 +02:00
|
|
|
|
2021-12-09 05:49:12 +01:00
|
|
|
/// Get a reference to a shared module from this package.
|
2021-06-12 16:47:43 +02:00
|
|
|
#[must_use]
|
2020-12-22 16:45:14 +01:00
|
|
|
fn as_shared_module(&self) -> Shared<Module>;
|
2020-05-07 09:25:50 +02:00
|
|
|
}
|
2020-05-13 13:21:42 +02:00
|
|
|
|
2021-01-11 16:09:33 +01:00
|
|
|
/// Macro that makes it easy to define a _package_ (which is basically a shared [module][Module])
|
2020-05-13 13:21:42 +02:00
|
|
|
/// and register functions into it.
|
|
|
|
///
|
2021-03-15 05:39:06 +01:00
|
|
|
/// Functions can be added to the package using [`Module::set_native_fn`].
|
2020-05-13 13:21:42 +02:00
|
|
|
///
|
2020-10-27 04:30:38 +01:00
|
|
|
/// # Example
|
2020-05-13 13:21:42 +02:00
|
|
|
///
|
2021-01-11 16:09:33 +01:00
|
|
|
/// Define a package named `MyPackage` with a single function named `my_add`:
|
|
|
|
///
|
2020-05-13 13:21:42 +02:00
|
|
|
/// ```
|
|
|
|
/// use rhai::{Dynamic, EvalAltResult};
|
|
|
|
/// use rhai::def_package;
|
|
|
|
///
|
|
|
|
/// fn add(x: i64, y: i64) -> Result<i64, Box<EvalAltResult>> { Ok(x + y) }
|
|
|
|
///
|
2022-02-10 05:33:48 +01:00
|
|
|
/// def_package! {
|
|
|
|
/// /// My super-duper package.
|
|
|
|
/// pub MyPackage(module) {
|
|
|
|
/// // Load a binary function with all value parameters.
|
|
|
|
/// module.set_native_fn("my_add", add);
|
|
|
|
/// }
|
|
|
|
/// }
|
2020-05-13 13:21:42 +02:00
|
|
|
/// ```
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! def_package {
|
2022-02-10 05:33:48 +01:00
|
|
|
($($(#[$outer:meta])* $mod:vis $package:ident($lib:ident) $block:block)+) => { $(
|
|
|
|
$(#[$outer])*
|
|
|
|
$mod struct $package($crate::Shared<$crate::Module>);
|
|
|
|
|
|
|
|
impl $crate::packages::Package for $package {
|
|
|
|
fn as_shared_module(&self) -> $crate::Shared<$crate::Module> {
|
|
|
|
self.0.clone()
|
|
|
|
}
|
|
|
|
fn init($lib: &mut $crate::Module) {
|
|
|
|
$block
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for $package {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self::new()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $package {
|
|
|
|
pub fn new() -> Self {
|
|
|
|
let mut module = $crate::Module::new();
|
|
|
|
<Self as $crate::packages::Package>::init(&mut module);
|
|
|
|
module.build_index();
|
|
|
|
Self(module.into())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)* };
|
2021-12-22 05:41:55 +01:00
|
|
|
($($(#[$outer:meta])* $root:ident :: $package:ident => | $lib:ident | $block:block)+) => { $(
|
2021-12-20 04:42:39 +01:00
|
|
|
$(#[$outer])*
|
2022-02-10 05:33:48 +01:00
|
|
|
/// # Deprecated
|
|
|
|
///
|
|
|
|
/// This old syntax of `def_package!` is deprecated. Use the new syntax instead.
|
|
|
|
///
|
|
|
|
/// This syntax will be removed in the next major version.
|
|
|
|
#[deprecated(since = "1.5.0", note = "this is an old syntax of `def_package!` and is deprecated; use the new syntax of `def_package!` instead")]
|
2021-12-20 04:42:39 +01:00
|
|
|
pub struct $package($root::Shared<$root::Module>);
|
|
|
|
|
|
|
|
impl $root::packages::Package for $package {
|
|
|
|
fn as_shared_module(&self) -> $root::Shared<$root::Module> {
|
|
|
|
self.0.clone()
|
|
|
|
}
|
|
|
|
fn init($lib: &mut $root::Module) {
|
|
|
|
$block
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for $package {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self::new()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl $package {
|
|
|
|
pub fn new() -> Self {
|
|
|
|
let mut module = $root::Module::new();
|
|
|
|
<Self as $root::packages::Package>::init(&mut module);
|
|
|
|
module.build_index();
|
|
|
|
Self(module.into())
|
|
|
|
}
|
|
|
|
}
|
2021-12-22 05:41:55 +01:00
|
|
|
)* };
|
2020-05-13 13:21:42 +02:00
|
|
|
($root:ident : $package:ident : $comment:expr , $lib:ident , $block:stmt) => {
|
|
|
|
#[doc=$comment]
|
2021-12-20 04:42:39 +01:00
|
|
|
///
|
|
|
|
/// # Deprecated
|
|
|
|
///
|
|
|
|
/// This old syntax of `def_package!` is deprecated. Use the new syntax instead.
|
|
|
|
///
|
|
|
|
/// This syntax will be removed in the next major version.
|
2022-02-10 05:33:48 +01:00
|
|
|
#[deprecated(since = "1.4.0", note = "this is an old syntax of `def_package!` and is deprecated; use the new syntax of `def_package!` instead")]
|
2020-12-22 15:36:30 +01:00
|
|
|
pub struct $package($root::Shared<$root::Module>);
|
2020-05-13 13:21:42 +02:00
|
|
|
|
|
|
|
impl $root::packages::Package for $package {
|
2020-12-22 16:45:14 +01:00
|
|
|
fn as_shared_module(&self) -> $root::Shared<$root::Module> {
|
2021-12-20 04:42:39 +01:00
|
|
|
#[allow(deprecated)]
|
2020-05-13 13:21:42 +02:00
|
|
|
self.0.clone()
|
|
|
|
}
|
|
|
|
fn init($lib: &mut $root::Module) {
|
|
|
|
$block
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-24 08:11:16 +02:00
|
|
|
impl Default for $package {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self::new()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-13 13:21:42 +02:00
|
|
|
impl $package {
|
|
|
|
pub fn new() -> Self {
|
2021-03-23 05:13:53 +01:00
|
|
|
let mut module = $root::Module::new();
|
2020-05-13 13:21:42 +02:00
|
|
|
<Self as $root::packages::Package>::init(&mut module);
|
2020-11-21 15:18:32 +01:00
|
|
|
module.build_index();
|
2020-05-13 13:21:42 +02:00
|
|
|
Self(module.into())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|