Add more closure tests.
This commit is contained in:
parent
dbf5cd13c8
commit
564d3bc339
@ -1639,7 +1639,8 @@ fn parse_primary(
|
|||||||
// Function call
|
// Function call
|
||||||
Token::Identifier(s) if *next_token == Token::LeftParen || *next_token == Token::Bang => {
|
Token::Identifier(s) if *next_token == Token::LeftParen || *next_token == Token::Bang => {
|
||||||
// Once the identifier consumed we must enable next variables capturing
|
// Once the identifier consumed we must enable next variables capturing
|
||||||
#[cfg(not(feature = "no_closure"))] {
|
#[cfg(not(feature = "no_closure"))]
|
||||||
|
{
|
||||||
state.allow_capture = true;
|
state.allow_capture = true;
|
||||||
}
|
}
|
||||||
Expr::Variable(Box::new(((s, settings.pos), None, 0, None)))
|
Expr::Variable(Box::new(((s, settings.pos), None, 0, None)))
|
||||||
|
@ -89,6 +89,36 @@ fn test_closures() -> Result<(), Box<EvalAltResult>> {
|
|||||||
42
|
42
|
||||||
);
|
);
|
||||||
|
|
||||||
|
assert_eq!(
|
||||||
|
engine.eval::<INT>(
|
||||||
|
r#"
|
||||||
|
let a = 40;
|
||||||
|
let f = |x| {
|
||||||
|
let f = |x| {
|
||||||
|
let f = |x| plus_one(a) + x;
|
||||||
|
f.call(x)
|
||||||
|
};
|
||||||
|
f.call(x)
|
||||||
|
};
|
||||||
|
f.call(1)
|
||||||
|
"#
|
||||||
|
)?,
|
||||||
|
42
|
||||||
|
);
|
||||||
|
|
||||||
|
assert_eq!(
|
||||||
|
engine.eval::<INT>(
|
||||||
|
r#"
|
||||||
|
let a = 21;
|
||||||
|
let f = |x| a += x;
|
||||||
|
f.call(a);
|
||||||
|
a
|
||||||
|
"#
|
||||||
|
)?,
|
||||||
|
42
|
||||||
|
);
|
||||||
|
|
||||||
|
#[allow(deprecated)]
|
||||||
engine.register_raw_fn(
|
engine.register_raw_fn(
|
||||||
"custom_call",
|
"custom_call",
|
||||||
&[TypeId::of::<INT>(), TypeId::of::<FnPtr>()],
|
&[TypeId::of::<INT>(), TypeId::of::<FnPtr>()],
|
||||||
|
Loading…
Reference in New Issue
Block a user