rhai/examples/definitions/main.rs

49 lines
1.5 KiB
Rust
Raw Normal View History

use rhai::plugin::*;
use rhai::{Engine, EvalAltResult, Scope};
2022-07-25 19:01:06 +02:00
#[export_module]
pub mod general_kenobi {
/// Returns a string where "hello there" is repeated `n` times.
2022-07-25 19:01:06 +02:00
pub fn hello_there(n: i64) -> String {
use std::convert::TryInto;
"hello there ".repeat(n.try_into().unwrap())
}
}
fn main() -> Result<(), Box<EvalAltResult>> {
2022-07-25 19:01:06 +02:00
let mut engine = Engine::new();
let mut scope = Scope::new();
// This variable will also show up in the definitions, since it will be part of the scope.
2022-07-25 19:01:06 +02:00
scope.push("hello_there", "hello there");
2022-07-26 14:28:54 +02:00
#[cfg(not(feature = "no_module"))]
2022-07-25 19:01:06 +02:00
engine.register_static_module("general_kenobi", exported_module!(general_kenobi).into());
// Custom operators also show up in definitions.
2022-07-26 14:28:54 +02:00
#[cfg(not(feature = "no_custom_syntax"))]
{
engine.register_custom_operator("minus", 100).unwrap();
engine.register_fn("minus", |a: i64, b: i64| a - b);
}
2022-07-25 19:01:06 +02:00
engine.run_with_scope(
&mut scope,
"hello_there = general_kenobi::hello_there(4 minus 2);",
)?;
2022-07-25 19:01:06 +02:00
// Generate definitions for the contents of the engine and the scope.
2022-07-25 19:01:06 +02:00
engine
.definitions_with_scope(&scope)
.write_to_dir("examples/definitions/.rhai/definitions")
.unwrap();
// Alternatively we can write all of the above to a single file.
engine
.definitions_with_scope(&scope)
.write_to_file("examples/definitions/.rhai/all_in_one.d.rhai")
.unwrap();
Ok(())
2022-07-25 19:01:06 +02:00
}