Refine docs.
This commit is contained in:
@@ -58,16 +58,16 @@ def_package!(rhai:MyPackage:"My own personal super package", module, {
|
||||
Create a Custom Package from a Plugin Module
|
||||
-------------------------------------------
|
||||
|
||||
By far the easiest way to create a custom module is to call `Module::merge_flatten` from within
|
||||
`rhai::def_package!` which simply merges in all the functions defined within a [plugin module].
|
||||
By far the easiest way to create a custom module is to call `rhai::plugins::combine_with_exported_module!`
|
||||
from within `rhai::def_package!` which simply merges in all the functions defined within a [plugin module].
|
||||
|
||||
In fact, this exactly is how Rhai's built-in packages, such as `BasicMathPackage`, are implemented.
|
||||
|
||||
`rhai::plugins::combine_with_exported_module!` adds all functions and constants from the
|
||||
[plugins][plugin module] definition into the package itself.
|
||||
Because of the specific requirements of a [package], all sub-modules are _flattened_
|
||||
(i.e. all functions defined within sub-modules are pulled up and registered at the top level instead)
|
||||
and so there will not be any sub-modules added to the package.
|
||||
|
||||
All sub-modules are _flattened_ (i.e. all functions and constants defined within sub-modules are registered
|
||||
at the top level) and so there will not be any sub-modules added to the package.
|
||||
Variables in the [plugin module] are ignored.
|
||||
|
||||
```rust
|
||||
// Import necessary types and traits.
|
||||
@@ -81,6 +81,8 @@ use rhai::plugin::*;
|
||||
// Define plugin module.
|
||||
#[export_module]
|
||||
mod my_module {
|
||||
pub const MY_NUMBER: i64 = 42;
|
||||
|
||||
pub fn greet(name: &str) -> String {
|
||||
format!("hello, {}!", name)
|
||||
}
|
||||
@@ -107,16 +109,17 @@ def_package!(rhai:MyPackage:"My own personal super package", module, {
|
||||
|
||||
// Merge all registered functions and constants from the plugin module into the custom package.
|
||||
//
|
||||
// Functions in the sub-module 'my_sub_module' are flattened and registered at the top level
|
||||
// instead of in a sub-module.
|
||||
// The sub-module 'my_sub_module' is flattened and its functions registered at the top level.
|
||||
//
|
||||
// The text string name in the middle parameter can be anything and is reserved for future use;
|
||||
// it is recommended to be an ID string that uniquely identifies the module.
|
||||
//
|
||||
// The constant variable, 'MY_NUMBER', is ignored.
|
||||
//
|
||||
// This call ends up registering three functions at the top level of the package:
|
||||
// 1) greet
|
||||
// 2) get_num
|
||||
// 3) get_sub_num (flattened from sub-module 'my_sub_module')
|
||||
// 3) get_sub_num (pulled up from 'my_sub_module')
|
||||
//
|
||||
combine_with_exported_module!(module, "my-functions", my_module));
|
||||
});
|
||||
|
Reference in New Issue
Block a user