#!./perl BEGIN { chdir 't' if -d 't'; @INC = '../lib'; } print "1..73\n"; # # @foo, @bar, and @ary are also used from tie-stdarray after tie-ing them # @ary = (1,2,3,4,5); if (join('',@ary) eq '12345') {print "ok 1\n";} else {print "not ok 1\n";} $tmp = $ary[$#ary]; --$#ary; if ($tmp == 5) {print "ok 2\n";} else {print "not ok 2\n";} if ($#ary == 3) {print "ok 3\n";} else {print "not ok 3\n";} if (join('',@ary) eq '1234') {print "ok 4\n";} else {print "not ok 4\n";} $[ = 1; @ary = (1,2,3,4,5); if (join('',@ary) eq '12345') {print "ok 5\n";} else {print "not ok 5\n";} $tmp = $ary[$#ary]; --$#ary; if ($tmp == 5) {print "ok 6\n";} else {print "not ok 6\n";} if ($#ary == 4) {print "ok 7\n";} else {print "not ok 7\n";} if (join('',@ary) eq '1234') {print "ok 8\n";} else {print "not ok 8\n";} if ($ary[5] eq '') {print "ok 9\n";} else {print "not ok 9\n";} $#ary += 1; # see if element 5 gone for good if ($#ary == 5) {print "ok 10\n";} else {print "not ok 10\n";} if (defined $ary[5]) {print "not ok 11\n";} else {print "ok 11\n";} $[ = 0; @foo = (); $r = join(',', $#foo, @foo); if ($r eq "-1") {print "ok 12\n";} else {print "not ok 12 $r\n";} $foo[0] = '0'; $r = join(',', $#foo, @foo); if ($r eq "0,0") {print "ok 13\n";} else {print "not ok 13 $r\n";} $foo[2] = '2'; $r = join(',', $#foo, @foo); if ($r eq "2,0,,2") {print "ok 14\n";} else {print "not ok 14 $r\n";} @bar = (); $bar[0] = '0'; $bar[1] = '1'; $r = join(',', $#bar, @bar); if ($r eq "1,0,1") {print "ok 15\n";} else {print "not ok 15 $r\n";} @bar = (); $r = join(',', $#bar, @bar); if ($r eq "-1") {print "ok 16\n";} else {print "not ok 16 $r\n";} $bar[0] = '0'; $r = join(',', $#bar, @bar); if ($r eq "0,0") {print "ok 17\n";} else {print "not ok 17 $r\n";} $bar[2] = '2'; $r = join(',', $#bar, @bar); if ($r eq "2,0,,2") {print "ok 18\n";} else {print "not ok 18 $r\n";} reset 'b'; @bar = (); $bar[0] = '0'; $r = join(',', $#bar, @bar); if ($r eq "0,0") {print "ok 19\n";} else {print "not ok 19 $r\n";} $bar[2] = '2'; $r = join(',', $#bar, @bar); if ($r eq "2,0,,2") {print "ok 20\n";} else {print "not ok 20 $r\n";} $foo = 'now is the time'; if (($F1,$F2,$Etc) = ($foo =~ /^(\S+)\s+(\S+)\s*(.*)/)) { if ($F1 eq 'now' && $F2 eq 'is' && $Etc eq 'the time') { print "ok 21\n"; } else { print "not ok 21\n"; } } else { print "not ok 21\n"; } $foo = 'lskjdf'; if ($cnt = (($F1,$F2,$Etc) = ($foo =~ /^(\S+)\s+(\S+)\s*(.*)/))) { print "not ok 22 $cnt $F1:$F2:$Etc\n"; } else { print "ok 22\n"; } %foo = ('blurfl','dyick','foo','bar','etc.','etc.'); %bar = %foo; print $bar{'foo'} eq 'bar' ? "ok 23\n" : "not ok 23\n"; %bar = (); print $bar{'foo'} eq '' ? "ok 24\n" : "not ok 24\n"; (%bar,$a,$b) = (%foo,'how','now'); print $bar{'foo'} eq 'bar' ? "ok 25\n" : "not ok 25\n"; print $bar{'how'} eq 'now' ? "ok 26\n" : "not ok 26\n"; @bar{keys %foo} = values %foo; print $bar{'foo'} eq 'bar' ? "ok 27\n" : "not ok 27\n"; print $bar{'how'} eq 'now' ? "ok 28\n" : "not ok 28\n"; @foo = grep(/e/,split(' ','now is the time for all good men to come to')); print join(' ',@foo) eq 'the time men come' ? "ok 29\n" : "not ok 29\n"; @foo = grep(!/e/,split(' ','now is the time for all good men to come to')); print join(' ',@foo) eq 'now is for all good to to' ? "ok 30\n" : "not ok 30\n"; $foo = join('',('a','b','c','d','e','f')[0..5]); print $foo eq 'abcdef' ? "ok 31\n" : "not ok 31\n"; $foo = join('',('a','b','c','d','e','f')[0..1]); print $foo eq 'ab' ? "ok 32\n" : "not ok 32\n"; $foo = join('',('a','b','c','d','e','f')[6]); print $foo eq '' ? "ok 33\n" : "not ok 33\n"; @foo = ('a','b','c','d','e','f')[0,2,4]; @bar = ('a','b','c','d','e','f')[1,3,5]; $foo = join('',(@foo,@bar)[0..5]); print $foo eq 'acebdf' ? "ok 34\n" : "not ok 34\n"; $foo = ('a','b','c','d','e','f')[0,2,4]; print $foo eq 'e' ? "ok 35\n" : "not ok 35\n"; $foo = ('a','b','c','d','e','f')[1]; print $foo eq 'b' ? "ok 36\n" : "not ok 36\n"; @foo = ( 'foo', 'bar', 'burbl'); push(foo, 'blah'); print $#foo == 3 ? "ok 37\n" : "not ok 37\n"; # various AASSIGN_COMMON checks (see newASSIGNOP() in op.c) $test = 37; sub t { ++$test; print "not " unless $_[0]; print "ok $test\n"; } @foo = @foo; t("@foo" eq "foo bar burbl blah"); # 38 (undef,@foo) = @foo; t("@foo" eq "bar burbl blah"); # 39 @foo = ('XXX',@foo, 'YYY'); t("@foo" eq "XXX bar burbl blah YYY"); # 40 @foo = @foo = qw(foo b\a\r bu\\rbl blah); t("@foo" eq 'foo b\a\r bu\\rbl blah'); # 41 @bar = @foo = qw(foo bar); # 42 t("@foo" eq "foo bar"); t("@bar" eq "foo bar"); # 43 # try the same with local # XXX tie-stdarray fails the tests involving local, so we use # different variable names to escape the 'tie' @bee = ( 'foo', 'bar', 'burbl', 'blah'); { local @bee = @bee; t("@bee" eq "foo bar burbl blah"); # 44 { local (undef,@bee) = @bee; t("@bee" eq "bar burbl blah"); # 45 { local @bee = ('XXX',@bee,'YYY'); t("@bee" eq "XXX bar burbl blah YYY"); # 46 { local @bee = local(@bee) = qw(foo bar burbl blah); t("@bee" eq "foo bar burbl blah"); # 47 { local (@bim) = local(@bee) = qw(foo bar); t("@bee" eq "foo bar"); # 48 t("@bim" eq "foo bar"); # 49 } t("@bee" eq "foo bar burbl blah"); # 50 } t("@bee" eq "XXX bar burbl blah YYY"); # 51 } t("@bee" eq "bar burbl blah"); # 52 } t("@bee" eq "foo bar burbl blah"); # 53 } # try the same with my { my @bee = @bee; t("@bee" eq "foo bar burbl blah"); # 54 { my (undef,@bee) = @bee; t("@bee" eq "bar burbl blah"); # 55 { my @bee = ('XXX',@bee,'YYY'); t("@bee" eq "XXX bar burbl blah YYY"); # 56 { my @bee = my @bee = qw(foo bar burbl blah); t("@bee" eq "foo bar burbl blah"); # 57 { my (@bim) = my(@bee) = qw(foo bar); t("@bee" eq "foo bar"); # 58 t("@bim" eq "foo bar"); # 59 } t("@bee" eq "foo bar burbl blah"); # 60 } t("@bee" eq "XXX bar burbl blah YYY"); # 61 } t("@bee" eq "bar burbl blah"); # 62 } t("@bee" eq "foo bar burbl blah"); # 63 } # make sure reification behaves my $t = 63; sub reify { $_[1] = ++$t; print "@_\n"; } reify('ok'); reify('ok'); # qw() is no more a runtime split, it's compiletime. print "not " unless qw(foo bar snorfle)[2] eq 'snorfle'; print "ok 66\n"; @ary = (12,23,34,45,56); print "not " unless shift(@ary) == 12; print "ok 67\n"; print "not " unless pop(@ary) == 56; print "ok 68\n"; print "not " unless push(@ary,56) == 4; print "ok 69\n"; print "not " unless unshift(@ary,12) == 5; print "ok 70\n"; sub foo { "a" } @foo=(foo())[0,0]; $foo[1] eq "a" or print "not "; print "ok 71\n"; # $[ should have the same effect regardless of whether the aelem # op is optimized to aelemfast. sub tary { local $[ = 10; my $five = 5; print "not " unless $tary[5] == $tary[$five]; print "ok 72\n"; } @tary = (0..50); tary(); require './test.pl'; # bugid #15439 - clearing an array calls destructors which may try # to modify the array - caused 'Attempt to free unreferenced scalar' my $got = runperl ( prog => q{ sub X::DESTROY { @a = () } @a = (bless {}, 'X'); @a = (); }, stderr => 1 ); $got =~ s/\n/ /g; print "# $got\nnot " unless $got eq ''; print "ok 73\n";