📄 deparse.t
字号:
#!./perlBEGIN { if ($ENV{PERL_CORE}){ chdir('t') if -d 't'; if ($^O eq 'MacOS') { @INC = qw(: ::lib ::macos:lib); } else { @INC = '.'; push @INC, '../lib'; } } else { unshift @INC, 't'; } require Config; if (($Config::Config{'extensions'} !~ /\bB\b/) ){ print "1..0 # Skip -- Perl configured without B module\n"; exit 0; }}use warnings;use strict;BEGIN { # BEGIN block is acutally a subroutine :-) return unless $] > 5.009; require feature; feature->import(':5.10');}use Test::More tests => 54;use B::Deparse;my $deparse = B::Deparse->new();ok($deparse);# Tell B::Deparse about our ambient pragmas{ my ($hint_bits, $warning_bits, $hinthash); BEGIN { ($hint_bits, $warning_bits, $hinthash) = ($^H, ${^WARNING_BITS}, \%^H); } $deparse->ambient_pragmas ( hint_bits => $hint_bits, warning_bits => $warning_bits, '$[' => 0 + $[, '%^H' => $hinthash, );}$/ = "\n####\n";while (<DATA>) { chomp; # This code is pinched from the t/lib/common.pl for TODO. # It's not clear how to avoid duplication my ($skip, $skip_reason); s/^#\s*SKIP\s*(.*)\n//m and $skip_reason = $1; # If the SKIP reason starts ? then it's taken as a code snippet to evaluate # This provides the flexibility to have conditional SKIPs if ($skip_reason && $skip_reason =~ s/^\?//) { my $temp = eval $skip_reason; if ($@) { die "# In SKIP code reason:\n# $skip_reason\n$@"; } $skip_reason = $temp; } s/#\s*(.*)$//mg; my ($num, $testname) = $1 =~ m/(\d+)\s*(.*)/; if ($skip_reason) { # Like this to avoid needing a label SKIP: Test::More->builder->skip($skip_reason); next; } my ($input, $expected); if (/(.*)\n>>>>\n(.*)/s) { ($input, $expected) = ($1, $2); } else { ($input, $expected) = ($_, $_); } my $coderef = eval "sub {$input}"; if ($@) { diag("$num deparsed: $@"); ok(0, $testname); } else { my $deparsed = $deparse->coderef2text( $coderef ); my $regex = $expected; $regex =~ s/(\S+)/\Q$1/g; $regex =~ s/\s+/\\s+/g; $regex = '^\{\s*' . $regex . '\s*\}$'; like($deparsed, qr/$regex/, $testname); }}use constant 'c', 'stuff';is((eval "sub ".$deparse->coderef2text(\&c))->(), 'stuff');my $a = 0;is("{\n (-1) ** \$a;\n}", $deparse->coderef2text(sub{(-1) ** $a }));use constant cr => ['hello'];my $string = "sub " . $deparse->coderef2text(\&cr);my $val = (eval $string)->();ok( ref($val) eq 'ARRAY' && $val->[0] eq 'hello');my $Is_VMS = $^O eq 'VMS';my $Is_MacOS = $^O eq 'MacOS';my $path = join " ", map { qq["-I$_"] } @INC;$path .= " -MMac::err=unix" if $Is_MacOS;my $redir = $Is_MacOS ? "" : "2>&1";$a = `$^X $path "-MO=Deparse" -anlwi.bak -e 1 $redir`;$a =~ s/-e syntax OK\n//g;$a =~ s/.*possible typo.*\n//; # Remove warning line$a =~ s{\\340\\242}{\\s} if (ord("\\") == 224); # EBCDIC, cp 1047 or 037$a =~ s{\\274\\242}{\\s} if (ord("\\") == 188); # $^O eq 'posix-bc'$b = <<'EOF';BEGIN { $^I = ".bak"; }BEGIN { $^W = 1; }BEGIN { $/ = "\n"; $\ = "\n"; }LINE: while (defined($_ = <ARGV>)) { chomp $_; our(@F) = split(' ', $_, 0); '???';}EOF$b =~ s/(LINE:)/sub BEGIN { 'MacPerl'->bootstrap; 'OSA'->bootstrap; 'XL'->bootstrap;}$1/ if $Is_MacOS;is($a, $b);#Re: perlbug #35857, patch #24505#handle warnings::register-ed packages properly.package B::Deparse::Wrapper;use strict;use warnings;use warnings::register;sub getcode { my $deparser = B::Deparse->new(); return $deparser->coderef2text(shift);}package main;use strict;use warnings;sub test { my $val = shift; my $res = B::Deparse::Wrapper::getcode($val); like( $res, qr/use warnings/);}my ($q,$p);my $x=sub { ++$q,++$p };test($x);eval <<EOFCODE and test($x); package bar; use strict; use warnings; use warnings::register; package main; 1EOFCODE__DATA__# 21;##### 3{ no warnings; '???'; 2;}##### 4my $test;++$test and $test /= 2;>>>>my $test;$test /= 2 if ++$test;##### 5-((1, 2) x 2);##### 6{ my $test = sub : lvalue { my $x; } ;}##### 7{ my $test = sub : method { my $x; } ;}##### 8{ my $test = sub : locked method { my $x; } ;}##### 9{ 234;}continue { 123;}##### 10my $x;print $main::x;##### 11my @x;print $main::x[1];##### 12my %x;$x{warn()};##### 13my $foo;$_ .= <ARGV> . <$foo>;##### 14my $foo = "Ab\x{100}\200\x{200}\377Cd\000Ef\x{1000}\cA\x{2000}\cZ";##### 15s/x/'y';/e;##### 16 - various lypes of loop{ my $x; }##### 17while (1) { my $k; }##### 18my ($x,@a);$x=1 for @a;>>>>my($x, @a);$x = 1 foreach (@a);##### 19for (my $i = 0; $i < 2;) { my $z = 1;}##### 20for (my $i = 0; $i < 2; ++$i) { my $z = 1;}##### 21for (my $i = 0; $i < 2; ++$i) { my $z = 1;}##### 22my $i;while ($i) { my $z = 1; } continue { $i = 99; }##### 23foreach my $i (1, 2) { my $z = 1;}##### 24my $i;foreach $i (1, 2) { my $z = 1;}##### 25my $i;foreach my $i (1, 2) { my $z = 1;}##### 26foreach my $i (1, 2) { my $z = 1;}##### 27foreach our $i (1, 2) { my $z = 1;}##### 28my $i;foreach our $i (1, 2) { my $z = 1;}##### 29my @x;print reverse sort(@x);##### 30my @x;print((sort {$b cmp $a} @x));##### 31my @x;print((reverse sort {$b <=> $a} @x));##### 32our @a;print $_ foreach (reverse @a);##### 33our @a;print $_ foreach (reverse 1, 2..5);##### 34 (bug #38684)our @ary;@ary = split(' ', 'foo', 0);##### 35 (bug #40055)do { () }; ##### 36 (ibid.)do { my $x = 1; $x }; ##### 37 <20061012113037.GJ25805@c4.convolution.nl>my $f = sub { +{[]};} ;##### 38 (bug #43010)'!@$%'->();##### 39 (ibid.)::();##### 40 (ibid.)'::::'->();##### 41 (ibid.)&::::;##### 42my $bar;'Foo'->$bar('orz');##### 43'Foo'->bar('orz');##### 44'Foo'->bar;##### SKIP ?$] < 5.010 && "say not implemented on this Perl version"# 45 saysay 'foo';##### SKIP ?$] < 5.010 && "state vars not implemented on this Perl version"# 46 state varsstate $x = 42;##### SKIP ?$] < 5.010 && "state vars not implemented on this Perl version"# 47 state var assignment{ my $y = (state $x = 42);}##### SKIP ?$] < 5.010 && "state vars not implemented on this Perl version"# 48 state vars in anoymous subroutines$a = sub { state $x; return $x++;};
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -