open(3p) Perl Programmers Reference Guide open(3p)

open(3p) Perl Programmers Reference Guide open(3p) #

open(3p) Perl Programmers Reference Guide open(3p)

NNAAMMEE #

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

SSYYNNOOPPSSIISS #

     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)';

DDEESSCCRRIIPPTTIIOONN #

 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 "open" pragma serves as one of the interfaces to declare default
 "layers" (previously known as "disciplines") for all I/O. Any ooppeenn(()),
 rreeaaddppiippee(()) (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.  See PerlIO for
 more information on the available layers.

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

 When ooppeenn(()) is given an explicit list of layers (with the three-arg
 syntax), they override the list declared using this pragma.  ooppeenn(()) 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.  See
 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 ":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 ":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 in "koi8r".

 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}".

IIMMPPLLEEMMEENNTTAATTIIOONN DDEETTAAIILLSS #

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

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

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

SSEEEE AALLSSOO #

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

perl v5.36.3 2023-02-15 open(3p)