Add plugins test.

This commit is contained in:
Stephen Chung 2020-08-02 18:53:25 +08:00
parent 675c4eb606
commit 5eed5fe6a3
5 changed files with 35 additions and 23 deletions

View File

@ -204,7 +204,11 @@ impl Engine {
}
// Run external function
let result = func.get_native_fn()(self, lib, args)?;
let result = if func.is_plugin_fn() {
func.get_plugin_fn().call(args, Position::none())?
} else {
func.get_native_fn()(self, lib, args)?
};
// Restore the original reference
restore_first_arg(old_this_ptr, args);

View File

@ -2,18 +2,11 @@
use crate::stdlib::{any::TypeId, boxed::Box};
pub use crate::any::{Dynamic, Variant};
pub use crate::fn_native::{CallableFunction, FnCallArgs, IteratorFn};
pub use crate::parser::{
FnAccess,
FnAccess::{Private, Public},
AST,
};
pub use crate::result::EvalAltResult;
pub use crate::scope::{Entry as ScopeEntry, EntryType as ScopeEntryType, Scope};
pub use crate::token::{Position, Token};
pub use crate::utils::StaticVec;
pub use crate::Engine;
use crate::any::Dynamic;
use crate::engine::Engine;
pub use crate::fn_native::CallableFunction;
use crate::result::EvalAltResult;
use crate::token::Position;
#[cfg(features = "sync")]
/// Represents an externally-written plugin for the Rhai interpreter.
@ -38,7 +31,8 @@ pub trait PluginFunction {
fn is_method_call(&self) -> bool;
fn is_varadic(&self) -> bool;
fn call(&self, args: &mut[&mut Dynamic], pos: Position) -> Result<Dynamic, Box<EvalAltResult>>;
fn call(&self, args: &mut [&mut Dynamic], pos: Position)
-> Result<Dynamic, Box<EvalAltResult>>;
fn clone_boxed(&self) -> Box<dyn PluginFunction>;

View File

@ -18,9 +18,9 @@ impl Engine {
///
/// When searching for functions, packages loaded later are preferred.
/// In other words, loaded packages are searched in reverse order.
pub fn load_package(&mut self, package: PackageLibrary) -> &mut Self {
pub fn load_package(&mut self, package: impl Into<PackageLibrary>) -> &mut Self {
// Push the package to the top - packages are searched in reverse order
self.packages.push(package);
self.packages.push(package.into());
self
}

View File

@ -16,7 +16,7 @@ fn test_fn_ptr_curry_call() -> Result<(), Box<EvalAltResult>> {
);
let mut engine = Engine::new();
engine.load_package(module.into());
engine.load_package(module);
#[cfg(not(feature = "no_object"))]
assert_eq!(

View File

@ -1,8 +1,12 @@
use rhai::{export_module, exported_module};
use rhai::{
export_fn, export_module, exported_module,
plugin::{CallableFunction, PluginFunction},
register_exported_fn,
};
use rhai::{Engine, EvalAltResult, INT};
#[export_module]
pub mod array_package {
mod special_array_package {
use rhai::{Array, INT};
pub fn len(array: &mut Array, mul: INT) -> INT {
@ -10,15 +14,25 @@ pub mod array_package {
}
}
#[export_fn]
fn make_greeting(n: INT) -> String {
format!("{} {}", n, if n > 1 { "kitties" } else { "kitty" }).into()
}
#[test]
fn test_plugins() -> Result<(), Box<EvalAltResult>> {
fn test_plugins_package() -> Result<(), Box<EvalAltResult>> {
let mut engine = Engine::new();
let m = exported_module!(array_package);
let mut m = exported_module!(special_array_package);
register_exported_fn!(m, "greet", make_greeting);
engine.load_package(m.into());
engine.load_package(m);
assert_eq!(engine.eval::<INT>("let a = [1, 2, 3]; a.len(2)")?, 6);
assert_eq!(engine.eval::<INT>("let a = [1, 2, 3]; len(a, 2)")?, 6);
assert_eq!(
engine.eval::<String>("let a = [1, 2, 3]; greet(len(a, 2))")?,
"6 kitties"
);
Ok(())
}