PHP 8.5.2
Preview: open.pm Size: 8.30 KB
//usr/share/perl/5.38/open.pm

package open;
use warnings;

our $VERSION = '1.13';

require 5.008001; # for PerlIO::get_layers()

my $locale_encoding;

sub _get_encname {
    return ($1, Encode::resolve_alias($1)) if $_[0] =~ /^:?encoding\((.+)\)$/;
    return;
}

sub croak {
    require Carp; goto &Carp::croak;
}

sub _drop_oldenc {
    # If by the time we arrive here there already is at the top of the
    # perlio layer stack an encoding identical to what we would like
    # to push via this open pragma, we will pop away the old encoding
    # (+utf8) so that we can push ourselves in place (this is easier
    # than ignoring pushing ourselves because of the way how ${^OPEN}
    # works).  So we are looking for something like
    #
    #   stdio encoding(xxx) utf8
    #
    # in the existing layer stack, and in the new stack chunk for
    #
    #   :encoding(xxx)
    #
    # If we find a match, we pop the old stack (once, since
    # the utf8 is just a flag on the encoding layer)
    my ($h, @new) = @_;
    return unless @new >= 1 && $new[-1] =~ /^:encoding\(.+\)$/;
    my @old = PerlIO::get_layers($h);
    return unless @old >= 3 &&
	          $old[-1] eq 'utf8' &&
                  $old[-2] =~ /^encoding\(.+\)$/;
    require Encode;
    my ($loname, $lcname) = _get_encname($old[-2]);
    unless (defined $lcname) { # Should we trust get_layers()?
	croak("open: Unknown encoding '$loname'");
    }
    my ($voname, $vcname) = _get_encname($new[-1]);
    unless (defined $vcname) {
	croak("open: Unknown encoding '$voname'");
    }
    if ($lcname eq $vcname) {
	binmode($h, ":pop"); # utf8 is part of the encoding layer
    }
}

sub import {
    my ($class,@args) = @_;
    croak("open: needs explicit list of PerlIO layers") unless @args;
    my $std;
    my ($in,$out) = split(/\0/,(${^OPEN} || "\0"), -1);
    while (@args) {
	my $type = shift(@args);
	my $dscp;
	if ($type =~ /^:?(utf8|locale|encoding\(.+\))$/) {
	    $type = 'IO';
	    $dscp = ":$1";
	} elsif ($type eq ':std') {
	    $std = 1;
	    next;
	} else {
	    $dscp = shift(@args) || '';
	}
	my @val;
	foreach my $layer (split(/\s+/,$dscp)) {
            $layer =~ s/^://;
	    if ($layer eq 'locale') {
		require Encode;
		require encoding;
		$locale_encoding = encoding::_get_locale_encoding()
		    unless defined $locale_encoding;
		(warnings::warnif("layer", "Cannot figure out an encoding to use"), last)
		    unless defined $locale_encoding;
                $layer = "encoding($locale_encoding)";
		$std = 1;
	    } else {
		my $target = $layer;		# the layer name itself
		$target =~ s/^(\w+)\(.+\)$/$1/;	# strip parameters

		unless(PerlIO::Layer::->find($target,1)) {
		    warnings::warnif("layer", "Unknown PerlIO layer '$target'");
		}
	    }
	    push(@val,":$layer");
	    if ($layer =~ /^(crlf|raw)$/) {
		$^H{"open_$type"} = $layer;
	    }
	}
	if ($type eq 'IN') {
	    _drop_oldenc(*STDIN, @val) if $std;
	    $in  = join(' ', @val);
	}
	elsif ($type eq 'OUT') {
	    if ($std) {
		_drop_oldenc(*STDOUT, @val);
		_drop_oldenc(*STDERR, @val);
	    }
	    $out = join(' ', @val);
	}
	elsif ($type eq 'IO') {
	    if ($std) {
		_drop_oldenc(*STDIN, @val);
		_drop_oldenc(*STDOUT, @val);
		_drop_oldenc(*STDERR, @val);
	    }
	    $in = $out = join(' ', @val);
	}
	else {
	    croak "Unknown PerlIO layer class '$type' (need IN, OUT or IO)";
	}
    }
    ${^OPEN} = join("\0", $in, $out);
    if ($std) {
	if ($in) {
	    binmode STDIN, $in;
	}
	if ($out) {
	    binmode(STDOUT, $out);
	    binmode(STDERR, $out);
	}
    }
}

1;
__END__

=head1 NAME

open - perl pragma to set default PerlIO layers for input and output

=head1 SYNOPSIS

    use open IN  => ':crlf', OUT => ':raw';
    open my $in, '<', 'foo.txt' or die "open failed: $!";
    my $line = <$in>; # CRLF translated
    close $in;
    open my $out, '>', 'bar.txt' or die "open failed: $!";
    print $out $line; # no translation of bytes
    close $out;

    use open OUT => ':encoding(UTF-8)';
    use open IN  => ':encoding(iso-8859-7)';

    use open IO  => ':locale';

    # IO implicit only for :utf8, :encoding, :locale
    use open ':encoding(UTF-8)';
    use open ':encoding(iso-8859-7)';
    use open ':locale';

    # with :std, also affect global standard handles
    use open ':std', ':encoding(UTF-8)';
    use open ':std', OUT => ':encoding(cp1252)';
    use open ':std', IO => ':raw :encoding(UTF-16LE)';

=head1 DESCRIPTION

Full-fledged support for I/O layers is now implemented provided
Perl is configured to use PerlIO as its IO system (which has been the
default since 5.8, and the only supported configuration since 5.16).

The C<open> pragma serves as one of the interfaces to declare default
"layers" (previously known as "disciplines") for all I/O. Any open(),
readpipe() (aka qx//) and similar operators found within the
lexical scope of this pragma will use the declared defaults via the
L<C<${^OPEN}>|perlvar/${^OPEN}> variable.

Layers are specified with a leading colon by convention. You can
specify a stack of multiple layers as a space-separated string.
See L<PerlIO> for more information on the available layers.

With the C<IN> subpragma you can declare the default layers
of input streams, and with the C<OUT> subpragma you can declare
the default layers of output streams.  With the C<IO> subpragma
(may be omitted for C<:utf8>, C<:locale>, or C<:encoding>) you
can control both input and output streams simultaneously.

When open() is given an explicit list of layers (with the three-arg
syntax), they override the list declared using this pragma.  open() can
also be given a single colon (:) for a layer name, to override this pragma
and use the default as detailed in
L<PerlIO/Defaults and how to override them>.

To translate from and to an arbitrary text encoding, use the C<:encoding>
layer.  The matching of encoding names in C<:encoding> is loose: case does
not matter, and many encodings have several aliases.  See
L<Encode::Supported> for details and the list of supported locales.

If you want to set your encoding layers based on your
locale environment variables, you can use the C<:locale> pseudo-layer.
For example:

    $ENV{LANG} = 'ru_RU.KOI8-R';
    # the :locale will probe the locale environment variables like LANG
    use open OUT => ':locale';
    open(my $out, '>', 'koi8') or die "open failed: $!";
    print $out chr(0x430); # CYRILLIC SMALL LETTER A = KOI8-R 0xc1
    close $out;
    open(my $in, '<', 'koi8') or die "open failed: $!";
    printf "%#x\n", ord(<$in>); # this should print 0xc1
    close $in;

The logic of C<:locale> is described in full in
L<encoding/The C<:locale> sub-pragma>,
but in short it is first trying nl_langinfo(CODESET) and then
guessing from the LC_ALL and LANG locale environment variables.
C<:locale> also implicitly turns on C<:std>.

C<:std> is not a layer but an additional subpragma.  When specified in the
import list, it activates an additional functionality of pushing the
layers selected for input/output handles to the standard filehandles
(STDIN, STDOUT, STDERR).  If the new layers and existing layer stack both
end with an C<:encoding> layer, the existing C<:encoding> layer will also
be removed.

For example, if both input and out are chosen to be C<:encoding(UTF-8)>, a
C<:std> will mean that STDIN, STDOUT, and STDERR will also have
C<:encoding(UTF-8)> set.  On the other hand, if only output is chosen to
be in C<:encoding(koi8r)>, a C<:std> will cause only the STDOUT and STDERR
to be in C<koi8r>.

The effect of C<:std> is not lexical as it modifies the layer stack of the
global handles.  If you wish to apply only this global effect and not the
effect on handles that are opened in that scope, you can isolate the call
to this pragma in its own lexical scope.

    { use open ':std', IO => ':encoding(UTF-8)' }

Before Perl 5.34, C<:std> would only apply the first layer provided that is
either C<:utf8> or has a layer argument, e.g. C<:encoding(UTF-8)>. Since
Perl 5.34 it will apply the same layer stack it provides to C<${^OPEN}>.

=head1 IMPLEMENTATION DETAILS

There is a class method in C<PerlIO::Layer> C<find> which is
implemented as XS code.  It is called by C<import> to validate the
layers:

   PerlIO::Layer::->find("perlio")

The return value (if defined) is a Perl object, of class
C<PerlIO::Layer> which is created by the C code in F<perlio.c>.  As
yet there is nothing useful you can do with the object at the perl
level.

=head1 SEE ALSO

L<perlfunc/"binmode">, L<perlfunc/"open">, L<perlunicode>, L<PerlIO>,
L<encoding>

=cut

Directory Contents

Dirs: 51 × Files: 76

Name Size Perms Modified Actions
App DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Archive DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Attribute DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
autodie DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
B DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Carp DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Class DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Compress DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Config DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
CPAN DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Devel DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Digest DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Encode DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
encoding DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Exporter DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
ExtUtils DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
File DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Filter DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Getopt DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
HTTP DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
I18N DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
IO DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
IPC DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
JSON DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Locale DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Math DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Memoize DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Module DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Net DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
overload DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Params DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Parse DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Perl DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
PerlIO DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Pod DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
pod DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Search DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
TAP DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Term DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Test DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Test2 DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Text DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Thread DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Tie DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Time DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
Unicode DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
unicore DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
User DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
version DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
warnings DIR
- drwxr-xr-x 2026-01-08 12:55:28
Edit Download
2.56 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
12.14 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
15.43 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
19.18 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.14 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
10.70 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
30.30 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
21.45 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
22.70 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
27.56 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
20.64 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.01 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
10.15 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.69 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
758 B lrw-r--r-- 2025-07-25 17:26:40
Edit Download
35.15 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
20.56 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
14.38 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.11 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
144.50 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
18.48 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
14.05 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.92 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
18.88 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
10.96 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.04 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
17.25 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
15.19 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.65 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
5.44 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
8.72 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
18.76 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
57.85 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
53.32 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
9.25 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
5.42 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
6.65 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.91 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.51 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.55 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.18 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.51 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
3.13 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.77 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
31.82 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.02 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
18.54 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
967 B lrw-r--r-- 2025-07-25 17:26:40
Edit Download
8.30 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
53.44 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
1.77 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.64 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
310.13 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
77 B lrw-r--r-- 2025-07-25 17:26:40
Edit Download
13.92 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
24.76 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
1.05 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
17.27 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
8.53 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.92 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.55 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.67 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
945 B lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.79 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
29.34 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
6.24 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
8.09 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
6.67 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
10.63 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
2.40 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
1.93 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
9.60 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
4.21 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
55.73 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
11.13 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download
34.84 KB lrw-r--r-- 2025-07-25 17:26:40
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).