rhai/doc/src/rust/packages.md

39 lines
1.7 KiB
Markdown
Raw Normal View History

2020-06-20 12:06:17 +08:00
Packages
========
{{#include ../links.md}}
Standard built-in Rhai features are provided in various _packages_ that can be loaded via a call to `Engine::load_package`.
Packages reside under `rhai::packages::*` and the trait `rhai::packages::Package` must be loaded in order for
packages to be used.
2020-06-20 22:56:56 +08:00
Packages typically contain Rust functions that are callable within a Rhai script.
All functions registered in a package is loaded under the _global namespace_ (i.e. they're available without module qualifiers).
Once a package is created (e.g. via `new`), it can be _shared_ (via `get`) among multiple instances of [`Engine`],
even across threads (under [`sync`]). Therefore, a package only has to be created _once_.
2020-06-20 12:06:17 +08:00
```rust
use rhai::Engine;
use rhai::packages::Package // load the 'Package' trait to use packages
use rhai::packages::CorePackage; // the 'core' package contains basic functionalities (e.g. arithmetic)
let mut engine = Engine::new_raw(); // create a 'raw' Engine
let package = CorePackage::new(); // create a package - can be shared among multiple `Engine` instances
engine.load_package(package.get()); // load the package manually. 'get' returns a reference to the shared package
```
2020-06-20 22:56:56 +08:00
Difference Between a Package and a Module
----------------------------------------
2020-06-20 12:06:17 +08:00
Packages are actually implemented as [modules], so they share a lot of behavior and characteristics.
2020-06-20 22:56:56 +08:00
2020-06-20 12:06:17 +08:00
The main difference is that a package loads under the _global_ namespace, while a module loads under its own
namespace alias specified in an [`import`] statement (see also [modules]).
A package is _static_ (i.e. pre-loaded into an [`Engine`]), while a module is _dynamic_ (i.e. loaded with
the `import` statement).