chdir 't' if -d 't';
@INC = '../lib';
require './test.pl';
- unless (find PerlIO::Layer 'perlio') {
- print "1..0 # Skip: not perlio\n";
- exit 0;
- }
- eval 'use Encode';
- if ($@ =~ /dynamic loading not available/) {
- print "1..0 # miniperl cannot load Encode\n";
- exit 0;
- }
+ skip_all_without_perlio();
+ # FIXME - more of these could be tested without Encode or full perl
+ skip_all_without_dynamic_extension('Encode');
+
# Makes testing easier.
$ENV{PERLIO} = 'stdio' if exists $ENV{PERLIO} && $ENV{PERLIO} eq '';
- if (exists $ENV{PERLIO} && $ENV{PERLIO} !~ /^(stdio|perlio|mmap)$/) {
- # We are not prepared for anything else.
- print "1..0 # PERLIO='$ENV{PERLIO}' unknown\n";
- exit 0;
- }
+ skip_all("PERLIO='$ENV{PERLIO}' unknown")
+ if exists $ENV{PERLIO} && $ENV{PERLIO} !~ /^(stdio|perlio|mmap)$/;
$PERLIO = exists $ENV{PERLIO} ? $ENV{PERLIO} : "(undef)";
}
use Config;
-my $DOSISH = $^O =~ /^(?:MSWin32|os2|dos|NetWare|mint)$/ ? 1 : 0;
+my $DOSISH = $^O =~ /^(?:MSWin32|os2|dos|NetWare)$/ ? 1 : 0;
$DOSISH = 1 if !$DOSISH and $^O =~ /^uwin/;
my $NONSTDIO = exists $ENV{PERLIO} && $ENV{PERLIO} ne 'stdio' ? 1 : 0;
my $FASTSTDIO = $Config{d_faststdio} && $Config{usefaststdio} ? 1 : 0;
-my $UNICODE_STDIN;
+my $UTF8_STDIN;
if (${^UNICODE} & 1) {
if (${^UNICODE} & 64) {
# Conditional on the locale
- $UNICODE_STDIN = ${^UTF8LOCALE};
+ $UTF8_STDIN = ${^UTF8LOCALE};
} else {
# Unconditional
- $UNICODE_STDIN = 1;
+ $UTF8_STDIN = 1;
}
} else {
- $UNICODE_STDIN = 0;
+ $UTF8_STDIN = 0;
}
-my $NTEST = 44 - (($DOSISH || !$FASTSTDIO) ? 7 : 0) - ($DOSISH ? 5 : 0)
- + $UNICODE_STDIN;
+my $NTEST = 60 - (($DOSISH || !$FASTSTDIO) ? 7 : 0) - ($DOSISH ? 7 : 0)
+ + $UTF8_STDIN;
sub PerlIO::F_UTF8 () { 0x00008000 } # from perliol.h
# FASTSTDIO = $FASTSTDIO
# UNICODE = ${^UNICODE}
# UTF8LOCALE = ${^UTF8LOCALE}
-# UNICODE_STDIN = $UNICODE_STDIN
+# UTF8_STDIN = $UTF8_STDIN
__EOH__
-SKIP: {
- # FIXME - more of these could be tested without Encode or full perl
- skip("This perl does not have Encode", $NTEST)
- unless " $Config{extensions} " =~ / Encode /;
- skip("miniperl does not have Encode", $NTEST) if $ENV{PERL_CORE_MINITEST};
-
+{
sub check {
my ($result, $expected, $id) = @_;
# An interesting dance follows where we try to make the following
# 5 tests potentially skipped because
# DOSISH systems already have a CRLF layer
# which will make new ones not stick.
- @$expected = grep { $_ ne 'crlf' } @$expected;
+ splice @$expected, 1, 1 if $expected->[1] eq 'crlf';
}
my $n = scalar @$expected;
is(scalar @$result, $n, "$id - layers == $n");
}
check([ PerlIO::get_layers(STDIN) ],
- $UNICODE_STDIN ? [ "stdio", "utf8" ] : [ "stdio" ],
+ $UTF8_STDIN ? [ "stdio", "utf8" ] : [ "stdio" ],
"STDIN");
- open(F, ">:crlf", "afile");
+ my $afile = tempfile();
+ open(F, ">:crlf", $afile);
check([ PerlIO::get_layers(F) ],
[ qw(stdio crlf) ],
"open :crlf");
- binmode(F, ":encoding(sjis)"); # "sjis" will be canonized to "shiftjis"
+ binmode(F, ":crlf");
check([ PerlIO::get_layers(F) ],
- [ qw[stdio crlf encoding(shiftjis) utf8] ],
- ":encoding(sjis)");
+ [ qw(stdio crlf) ],
+ "binmode :crlf");
+
+ binmode(F, ":encoding(cp1047)");
+
+ check([ PerlIO::get_layers(F) ],
+ [ qw[stdio crlf encoding(cp1047) utf8] ],
+ ":encoding(cp1047)");
+
+ binmode(F, ":crlf");
+
+ check([ PerlIO::get_layers(F) ],
+ [ qw[stdio crlf encoding(cp1047) utf8 crlf utf8] ],
+ ":encoding(cp1047):crlf");
- binmode(F, ":pop");
+ binmode(F, ":pop:pop");
check([ PerlIO::get_layers(F) ],
[ qw(stdio crlf) ],
[ "stdio" ],
"binmode");
+ # RT78844
+ {
+ local $@ = "foo";
+ binmode(F, ":encoding(utf8)");
+ is( $@, "foo", '$@ not clobbered by binmode and :encoding');
+ }
+
close F;
{
use open(IN => ":crlf", OUT => ":encoding(cp1252)");
- open F, "<afile";
- open G, ">afile";
+ open F, '<', $afile;
+ open G, '>', $afile;
check([ PerlIO::get_layers(F, input => 1) ],
[ qw(stdio crlf) ],
# Check that PL_sigwarn's reference count is correct, and that
# &PerlIO::Layer::NoWarnings isn't prematurely freed.
- fresh_perl_like (<<'EOT', qr/^CODE/);
-open(UTF, "<:raw:encoding(utf8)", "afile") or die $!;
+ fresh_perl_like (<<"EOT", qr/^CODE/);
+open(UTF, "<:raw:encoding(utf8)", '$afile') or die \$!;
print ref *PerlIO::Layer::NoWarnings{CODE};
EOT
- 1 while unlink "afile";
+ # [perl #97956] Not calling FETCH all the time on tied variables
+ my $f;
+ sub TIESCALAR { bless [] }
+ sub FETCH { ++$f; $_[0][0] = $_[1] }
+ sub STORE { $_[0][0] }
+ tie my $t, "";
+ $t = *f;
+ $f = 0; PerlIO::get_layers $t;
+ is $f, 1, '1 fetch on tied glob';
+ $t = \*f;
+ $f = 0; PerlIO::get_layers $t;
+ is $f, 1, '1 fetch on tied globref';
+ $t = *f;
+ $f = 0; PerlIO::get_layers \$t;
+ is $f, 1, '1 fetch on referenced tied glob';
+ $t = '';
+ $f = 0; PerlIO::get_layers $t;
+ is $f, 1, '1 fetch on tied string';
+
+ # No distinction between nums and strings
+ open "12", "<:crlf", "test.pl" or die "$0 cannot open test.pl: $!";
+ ok PerlIO::get_layers(12), 'str/num arguments are treated identically';
}