Encapsulate functions resolution cache into State API.
This commit is contained in:
@@ -1527,15 +1527,16 @@ impl Engine {
|
||||
ast: &'a AST,
|
||||
level: usize,
|
||||
) -> Result<Dynamic, Box<EvalAltResult>> {
|
||||
let state = &mut State {
|
||||
source: ast.clone_source(),
|
||||
#[cfg(not(feature = "no_module"))]
|
||||
resolver: ast.resolver(),
|
||||
..Default::default()
|
||||
};
|
||||
let mut state: State = Default::default();
|
||||
state.source = ast.clone_source();
|
||||
#[cfg(not(feature = "no_module"))]
|
||||
{
|
||||
state.resolver = ast.resolver();
|
||||
}
|
||||
|
||||
let statements = ast.statements();
|
||||
let lib = &[ast.lib()];
|
||||
self.eval_global_statements(scope, mods, state, statements, lib, level)
|
||||
self.eval_global_statements(scope, mods, &mut state, statements, lib, level)
|
||||
}
|
||||
/// Evaluate a file, but throw away the result and only return error (if any).
|
||||
/// Useful for when you don't need the result, but still need to keep track of possible errors.
|
||||
@@ -1598,15 +1599,15 @@ impl Engine {
|
||||
ast: &AST,
|
||||
) -> Result<(), Box<EvalAltResult>> {
|
||||
let mods = &mut (&self.global_sub_modules).into();
|
||||
let state = &mut State {
|
||||
source: ast.clone_source(),
|
||||
#[cfg(not(feature = "no_module"))]
|
||||
resolver: ast.resolver(),
|
||||
..Default::default()
|
||||
};
|
||||
let mut state: State = Default::default();
|
||||
state.source = ast.clone_source();
|
||||
#[cfg(not(feature = "no_module"))]
|
||||
{
|
||||
state.resolver = ast.resolver();
|
||||
}
|
||||
let statements = ast.statements();
|
||||
let lib = &[ast.lib()];
|
||||
self.eval_global_statements(scope, mods, state, statements, lib, 0)?;
|
||||
self.eval_global_statements(scope, mods, &mut state, statements, lib, 0)?;
|
||||
Ok(())
|
||||
}
|
||||
/// Call a script function defined in an [`AST`] with multiple arguments.
|
||||
|
Reference in New Issue
Block a user