use v6;
use Test;
plan 14;
{
sub make_eval_closure {
my $a = 5;
return sub ($s) {
eval $s
};
};
is(make_eval_closure().('$a'), 5, 'eval runs code in the proper lexical scope');
}
is(eval('5'), 5, 'simple eval works and returns the value');
my $foo = 1234;
is(eval('$foo'), $foo, 'simple eval using variable defined outside');
ok(!eval('die; 1'), "eval can trap die");
ok(eval('my @a = (1); @a!<0>').notdef, "eval returns undefined on syntax error");
ok(!eval('use Poison; 1'), "eval can trap a fatal use statement");
dies_ok({eval {42}}, 'block eval is gone');
{
class EvalTester1 {
method e($s) { eval $s };
}
is EvalTester1.e('5'), 5, 'eval works inside class methods';
is EvalTester1.new.e('5'), 5, 'eval works inside instance methods';
}
{
my $x = 5;
class EvalTester2 {
method e($s) { eval "$s + \$x" };
}
is EvalTester2.e('1'), 6,
'eval works inside class methods, with outer lexicals';
is EvalTester2.new.e('1'), 6,
'eval works inside instance methods, with outer lexicals';
}
is eval("'møp'".encode('UTF-8')), 'møp', 'eval(Buf)';
{
is eval 88, 88, 'eval of non-string works';
my $number = 2;
is eval $number, $number, 'eval of non-string variable works';
}