X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2F20-return.t;h=99d9954562118d840300e81324bf56368d31b21a;hb=790ba71f0305951a6d7bb04ca02a1dad7563f439;hp=48d3a54a1cbdbe9a649c5cc2186cbbc0b1baf05f;hpb=3271ef4bff5871bc6aa2d90537f97f177cbacc2a;p=perl%2Fmodules%2FSub-Nary.git
diff --git a/t/20-return.t b/t/20-return.t
index 48d3a54..99d9954 100644
--- a/t/20-return.t
+++ b/t/20-return.t
@@ -3,7 +3,7 @@
use strict;
use warnings;
-use Test::More tests => 72;
+use Test::More tests => 69;
use Sub::Nary;
@@ -11,8 +11,6 @@ my $sn = Sub::Nary->new();
my ($x, $y, @a, %h);
-my $exp_2 = { 1 => 0.5, 2 => 0.5 };
-
my @tests = (
[ sub { return }, 0 ],
[ sub { return () }, 0 ],
@@ -25,6 +23,11 @@ my @tests = (
[ sub { do { 1; return 2, 3 } }, 2 ],
[ sub { do { 1; return 2, 3; 4 } }, 2 ],
[ sub { do { 1; return 2, return 3 } }, 1 ],
+ [ sub { do { return if $x; 2, 3 }, 4 }, { 0 => 0.5, 3 => 0.5 } ],
+ [ sub { do { do { return if $x }, 3 }, 4 }, { 0 => 0.5, 3 => 0.5 } ],
+ [ sub { do { return if $x; 2, 3 }, do { return 1 if $y; 4, 5, 6 } },
+ { 0 => 0.5, 1 => 0.25, 5 => 0.25 } ],
+ [ sub { my $x = do { return 2, 3; 4 } }, 2 ],
[ sub { return $x }, 1 ],
[ sub { return $x, $y }, 2 ],
@@ -39,7 +42,7 @@ my @tests = (
[ sub { return %h }, 'list' ],
[ sub { return $h{a} }, 1 ],
- [ sub { return @h{qw/a b/} }, 2 ],
+ [ sub { return @h{qw} }, 2 ],
[ sub { return @h{@a[1 .. 3]} }, 3 ],
[ sub { return @h{@a[$y .. 3]} }, 'list' ],
[ sub { return keys %h }, 'list' ],
@@ -60,21 +63,28 @@ my @tests = (
[ sub { for (1, 2, 3) { return } }, 0 ],
[ sub { for (1, 2, 3) { } return 1, 2; }, 2 ],
+ [ sub { for (do { return 1, 2, 3 }) { } return 1, 2; }, 3 ],
+ [ sub { for (do { return 2, 3 if $x }) { } }, { 2 => 0.5, 0 => 0.5 } ],
+ [ sub { for (1, 2, 3) { return 1, 2 if $x } }, 'list' ],
[ sub { for ($x, 1, $y) { return 1, 2 } }, 2 ],
[ sub { for (@a) { return 1, do { $x } } }, 2 ],
[ sub { for (keys %h) { return do { 1 }, do { return @a[0, 2] } } }, 2 ],
- [ sub { for my $i (1 .. 4) { return @h{qw/a b/} } }, 2 ],
+ [ sub { for my $i (1 .. 4) { return @h{qw} } }, 2 ],
[ sub { for (my $i; $i < 10; ++$i) { return 1, @a[do{return 2, 3}] } }, 2 ],
[ sub { return 1, 2 for 1 .. 4 }, 2 ],
- [ sub { while (1) { return } }, 0 ],
- [ sub { while (1) { } return 1, 2 }, 2 ],
- [ sub { while (1) { return 1, 2 } }, 2 ],
- [ sub { while (1) { last; return 1, 2 } }, 2 ],
- [ sub { return 1, 2 while 1 }, 2 ],
+ [ sub { while (1) { return } }, 0 ],
+ [ sub { while (1) { } return 1, 2 }, 2 ],
+ [ sub { while (1) { return 1, 2 } }, 2 ],
+ [ sub { while (1) { return 1, 2 if $x } }, 'list' ],
+ [ sub { while (1) { last; return 1, 2 } }, 2 ],
+ [ sub { return 1, 2 while 1 }, 2 ],
+ [ sub { while (do { return 2, 3 }) { } }, 2 ],
+ [ sub { while (do { return 2, 3 if $x }) { } }, 'list' ],
[ sub { eval { return } }, 0 ],
[ sub { eval { return 1, 2 } }, 2 ],
+ [ sub { eval { return 1, 2; 3, 4, 5 } }, 2 ],
[ sub { eval { }; return $x, 2 }, 2 ],
[ sub { return eval { 1, $x }; }, 2 ],
[ sub { return 1, eval { $x, eval { $h{foo} } } }, 3 ],
@@ -82,26 +92,6 @@ my @tests = (
[ sub { return eval { do { eval { @a } } } }, 'list' ],
[ sub { eval 'return 1, 2' }, 'list' ],
-
- [ sub { grep { return 2, 4 } 5 .. 10 }, 2 ],
- [ sub { grep { $_ > 1 } do { return 2, 4; 5 .. 10 } }, 2 ],
- [ sub { grep { return 2, 4 } () }, 0 ],
- [ sub { grep { return $_ ? 2 : (3, 4) } 7 .. 8 }, $exp_2 ],
- [ sub { grep { $_ > 1 } do { return $x ? 7 : (8, 9) } }, $exp_2 ],
- [ sub { grep { return $_ ? 2 : (3, 4) } do { return 3 .. 5 if $x; } },
- { 3 => 0.5, 1 => 0.25, 2 => 0.25 } ],
- [ sub { grep { return $_ ? 2 : (3, 4) } do { return 3 .. 5 if $x; () } },
- { 3 => 0.5, 0 => 0.5 } ],
-
- [ sub { map { return 2, 4 } 5 .. 10 }, 2 ],
- [ sub { map { $_ + 1 } do { return 2, 4; 5 .. 10 } }, 2 ],
- [ sub { map { return 2, 4 } () }, 0 ],
- [ sub { map { return $_ ? 2 : (3, 4) } 7 .. 8 }, $exp_2 ],
- [ sub { map { $_ > 1 } do { return $x ? 7 : (8, 9) } }, $exp_2 ],
- [ sub { map { return $_ ? 2 : (3, 4) } do { return 3 .. 5 if $x; } },
- { 3 => 0.5, 1 => 0.25, 2 => 0.25 } ],
- [ sub { map { return $_ ? 2 : (3, 4) } do { return 3 .. 5 if $x; () } },
- { 3 => 0.5, 0 => 0.5 } ],
);
my $i = 1;