Movatterモバイル変換


[0]ホーム

URL:


open
(source,CPAN)
version 1.13
You are viewing the version of this documentation from Perl 5.41.7. This is a development version of Perl.
open may also refer to the function:open

CONTENTS

#NAME

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

#SYNOPSIS

use open IN  => ':crlf', OUT => ':raw';open my $in, '<', 'foo.txt' or die "open failed: $!";my $line = <$in>; # CRLF translatedclose $in;open my $out, '>', 'bar.txt' or die "open failed: $!";print $out $line; # no translation of bytesclose $out;use open OUT => ':encoding(UTF-8)';use open IN  => ':encoding(iso-8859-7)';use open IO  => ':locale';# IO implicit only for :utf8, :encoding, :localeuse open ':encoding(UTF-8)';use open ':encoding(iso-8859-7)';use open ':locale';# with :std, also affect global standard handlesuse open ':std', ':encoding(UTF-8)';use open ':std', OUT => ':encoding(cp1252)';use open ':std', IO => ':raw :encoding(UTF-16LE)';

#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).

Theopen 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${^OPEN} variable.

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

With theIN subpragma you can declare the default layers of input streams, and with theOUT subpragma you can declare the default layers of output streams. With theIO subpragma (may be omitted for:utf8,:locale, or: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"Defaults and how to override them" in PerlIO.

To translate from and to an arbitrary text encoding, use the:encoding layer. The matching of encoding names in:encoding is loose: case does not matter, and many encodings have several aliases. SeeEncode::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:locale pseudo-layer. For example:

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

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

: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:encoding layer, the existing:encoding layer will also be removed.

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

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

#IMPLEMENTATION DETAILS

There is a class method inPerlIO::Layerfind which is implemented as XS code. It is called byimport to validate the layers:

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

The return value (if defined) is a Perl object, of classPerlIO::Layer which is created by the C code inperlio.c. As yet there is nothing useful you can do with the object at the perl level.

#SEE ALSO

"binmode" in perlfunc,"open" in perlfunc,perlunicode,PerlIO,encoding

Perldoc Browser is maintained by Dan Book (DBOOK). Please contact him via theGitHub issue tracker oremail regarding any issues with the site itself, search, or rendering of documentation.

The Perl documentation is maintained by the Perl 5 Porters in the development of Perl. Please contact them via thePerl issue tracker, themailing list, orIRC to report any issues with the contents or format of the documentation.


[8]ページ先頭

©2009-2025 Movatter.jp