]> git.vpit.fr Git - perl/modules/Sub-Nary.git/commitdiff
Get the good count in aassign. Fixes successive arrays assignments and goatse operato...
authorVincent Pit <vince@profvince.com>
Tue, 5 Aug 2008 14:02:08 +0000 (16:02 +0200)
committerVincent Pit <vince@profvince.com>
Tue, 5 Aug 2008 14:02:08 +0000 (16:02 +0200)
lib/Sub/Nary.pm
t/20-return.t
t/21-list.t

index 707a2e627ee25228b9bc20432c6237014c661d3e..a6b97e0f401d0ab56a0b47281c7cc817ce22eff7 100644 (file)
@@ -441,7 +441,17 @@ sub pp_rv2av {
  return (name($op) eq 'const') ? $self->expect_any($op) : 'list';
 }
 
-sub pp_aassign { $_[0]->expect_any($_[1]->first) }
+sub pp_aassign {
+ my ($self, $op) = @_;
+
+ $op = $op->first;
+
+ # Can't assign to return
+ my ($p, $r) = $self->expect_list($op->sibling);
+ return $p => 0 if not exists $p->{list};
+
+ $self->expect_any($op);
+}
 
 sub pp_leaveloop { $_[0]->expect_return($_[1]->first->sibling) }
 
index 191a386dd9ca0332542df8e0c68ab899381e2c8a..fc63f95ef4b1b7ec273e18447776c9a871675a06 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More tests => 56;
+use Test::More tests => 58;
 
 use Sub::Nary;
 
@@ -31,6 +31,7 @@ my @tests = (
  [ sub { return $a[0] },             1 ],
  [ sub { return @a[1, 2] },          2 ],
  [ sub { return @a[2 .. 4] },        3 ],
+ [ sub { return @a[1, 4 .. 7, 2] },  6 ],
  [ sub { return @a[do{ 1 .. 5 }] },  5 ],
  [ sub { return @a[do{ 1 .. $x }] }, 'list' ],
 
@@ -46,13 +47,14 @@ my @tests = (
  [ sub { return $x, @a },           'list' ],
  [ sub { return %h, $y },           'list' ],
 
- [ sub { return 1 .. 3 },                  3 ],
+ [ sub { return 2 .. 4 },                  3 ],
  [ sub { return $x .. 3 },                 'list' ],
  [ sub { return 1 .. $x },                 'list' ],
  [ sub { return '2foo' .. 4 },             3 ],
  [ sub { my @a = (7, 8); return @a .. 4 }, 'list' ],
  [ sub { return do { return 1, 2 } .. 3 }, 2 ],
  [ sub { return 1 .. do { return 2, 3 } }, 2 ],
+ [ sub { my @a = return 6, $x },           2 ],
 
  [ sub { for (1, 2, 3) { return } },                                     0 ],
  [ sub { for (1, 2, 3) { } return 1, 2; },                               2 ],
index 3acf6593eeb4a83aca744724fdbf8963d65bb5a3..4dc492a811480b81dfa01965b9d46b23d8591047 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More tests => 40;
+use Test::More tests => 44;
 
 use Sub::Nary;
 
@@ -25,10 +25,11 @@ my @tests = (
  [ sub { $x },     1 ],
  [ sub { $x, $y }, 2 ],
 
- [ sub { @a },         'list' ],
- [ sub { $a[0] },      1 ],
- [ sub { @a[1, 2] },   2 ],
- [ sub { @a[2 .. 4] }, 3 ],
+ [ sub { @a },               'list' ],
+ [ sub { $a[0] },            1 ],
+ [ sub { @a[1, 2] },         2 ],
+ [ sub { @a[2 .. 4] },       3 ],
+ [ sub { @a[1, 4 .. 7, 2] }, 6 ],
 
  [ sub { %h },          'list' ],
  [ sub { $h{a} },       1 ],
@@ -40,12 +41,15 @@ my @tests = (
  [ sub { $x, @a },           'list' ],
  [ sub { %h, $y },           'list' ],
 
- [ sub { 1 .. 3 },                  3 ],
- [ sub { $x .. 3 },                 'list' ],
- [ sub { 1 .. $x },                 'list' ],
- [ sub { '2foo' .. 4 },             3 ],
- [ sub { my @a = (7, 8); @a .. 4 }, 'list' ],
- [ sub { my @a = (1 .. 4) },        4 ],
+ [ sub { 2 .. 4 },                      3 ],
+ [ sub { $x .. 3 },                     'list' ],
+ [ sub { 1 .. $x },                      'list' ],
+ [ sub { '2foo' .. 4 },                  3 ],
+ [ sub { my @a = (7, 8); @a .. 4 },      'list' ],
+ [ sub { my @a = (2 .. 5) },             4 ],
+ [ sub { my @b; my @a = @b = (2 .. 5) }, 4 ],
+ [ sub { my @a =()= (2 .. 5) },          0 ],
+ [ sub { my $x =()= (2 .. 5) },          1 ],
 
  [ sub { "banana" =~ /(a)/g }, 'list' ],