Skip to content

Commit

Permalink
allow '*' prototype to autoquote even barewords that happen to be
Browse files Browse the repository at this point in the history
function names; parens or ampersand continue to force the other
interpretation; makes C<sub Foo {'bar'} CORE::GLOBAL::require Foo;>
do the right thing, for example

p4raw-id: //depot/perl@3449
  • Loading branch information
Gurusamy Sarathy committed May 24, 1999
1 parent e969301 commit 1822861
Showing 1 changed file with 33 additions and 1 deletion.
34 changes: 33 additions & 1 deletion t/comp/proto.t
Expand Up @@ -16,7 +16,7 @@ BEGIN {

use strict;

print "1..87\n";
print "1..100\n";

my $i = 1;

Expand Down Expand Up @@ -417,9 +417,41 @@ print "ok ", $i++, "\n";
# test if the (*) prototype allows barewords, constants, scalar expressions,
# globs and globrefs (just as CORE::open() does), all under stricture
sub star (*&) { &{$_[1]} }
sub star2 (**&) { &{$_[2]} }
sub BAR { "quux" }
my $star = 'FOO';
star FOO, sub { print "ok $i\n" if $_[0] eq 'FOO' }; $i++;
star(FOO, sub { print "ok $i\n" if $_[0] eq 'FOO' }); $i++;
star "FOO", sub { print "ok $i\n" if $_[0] eq 'FOO' }; $i++;
star("FOO", sub { print "ok $i\n" if $_[0] eq 'FOO' }); $i++;
star $star, sub { print "ok $i\n" if $_[0] eq 'FOO' }; $i++;
star($star, sub { print "ok $i\n" if $_[0] eq 'FOO' }); $i++;
star *FOO, sub { print "ok $i\n" if $_[0] eq \*FOO }; $i++;
star(*FOO, sub { print "ok $i\n" if $_[0] eq \*FOO }); $i++;
star \*FOO, sub { print "ok $i\n" if $_[0] eq \*FOO }; $i++;
star(\*FOO, sub { print "ok $i\n" if $_[0] eq \*FOO }); $i++;
star2 FOO, BAR, sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'BAR' }; $i++;
star2(BAR, FOO, sub { print "ok $i\n"
if $_[0] eq 'BAR' and $_[1] eq 'FOO' }); $i++;
star2 BAR(), FOO, sub { print "ok $i\n"
if $_[0] eq 'quux' and $_[1] eq 'FOO' }; $i++;
star2(FOO, BAR(), sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'quux' }); $i++;
star2 "FOO", "BAR", sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'BAR' }; $i++;
star2("FOO", "BAR", sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'BAR' }); $i++;
star2 $star, $star, sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'FOO' }; $i++;
star2($star, $star, sub { print "ok $i\n"
if $_[0] eq 'FOO' and $_[1] eq 'FOO' }); $i++;
star2 *FOO, *BAR, sub { print "ok $i\n"
if $_[0] eq \*FOO and $_[0] eq \*BAR }; $i++;
star2(*FOO, *BAR, sub { print "ok $i\n"
if $_[0] eq \*FOO and $_[0] eq \*BAR }); $i++;
star2 \*FOO, \*BAR, sub { no strict 'refs'; print "ok $i\n"
if $_[0] eq \*{'FOO'} and $_[0] eq \*{'BAR'} }; $i++;
star2(\*FOO, \*BAR, sub { no strict 'refs'; print "ok $i\n"
if $_[0] eq \*{'FOO'} and $_[0] eq \*{'BAR'} }); $i++;

0 comments on commit 1822861

Please sign in to comment.