CINXE.COM

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

<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>open - perl pragma to set default PerlIO layers for input and output - Perldoc Browser</title> <link rel="search" href="/opensearch.xml" type="application/opensearchdescription+xml" title="Perldoc Browser"> <link rel="canonical" href="https://perldoc.perl.org/open"> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" integrity="sha384-JcKb8q3iqJ61gNV9KGb8thSsNjpSL0n8PARn9HuZOnIxN0hoP+VmmDGMN5t9UJ0Z" crossorigin="anonymous"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/stackoverflow-light.min.css" integrity="sha512-cG1IdFxqipi3gqLmksLtuk13C+hBa57a6zpWxMeoY3Q9O6ooFxq50DayCdm0QrDgZjMUn23z/0PMZlgft7Yp5Q==" crossorigin="anonymous" /> <style> body { background: #f4f4f5; color: #020202; } .navbar-dark { background-image: -webkit-linear-gradient(top, #005f85 0, #002e49 100%); background-image: -o-linear-gradient(top, #005f85 0, #002e49 100%); background-image: linear-gradient(to bottom, #005f85 0, #002e49 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff005f85', endColorstr='#ff002e49', GradientType=0); background-repeat: repeat-x; } .navbar-dark .navbar-nav .nav-link, .navbar-dark .navbar-nav .nav-link:focus { color: #fff } .navbar-dark .navbar-nav .nav-link:hover { color: #ffef68 } #wrapperlicious { margin: 0 auto; font: 0.9em 'Helvetica Neue', Helvetica, sans-serif; font-weight: normal; line-height: 1.5em; margin: 0; padding: 0; } #wrapperlicious h1 { font-size: 1.5em } #wrapperlicious h2 { font-size: 1.3em } #wrapperlicious h3 { font-size: 1.1em } #wrapperlicious h4 { font-size: 0.9em } #wrapperlicious h1, #wrapperlicious h2, #wrapperlicious h3, #wrapperlicious h4, #wrapperlicious dt { color: #020202; margin-top: 1em; margin-bottom: 1em; position: relative; font-weight: bold; } #wrapperlicious a { color: inherit; text-decoration: underline } #wrapperlicious #toc { text-decoration: none } #wrapperlicious a:hover { color: #2a2a2a } #wrapperlicious a img { border: 0 } #wrapperlicious :not(pre) > code { color: inherit; background-color: rgba(0, 0, 0, 0.04); border-radius: 3px; font: 0.9em Consolas, Menlo, Monaco, monospace; padding: 0.3em; } #wrapperlicious dd { margin: 0; margin-left: 2em; } #wrapperlicious dt { color: #2a2a2a; font-weight: bold; margin-left: 0.9em; } #wrapperlicious p { margin-bottom: 1em; margin-top: 1em; } #wrapperlicious li > p { margin-bottom: 0; margin-top: 0; } #wrapperlicious pre { border: 1px solid #c1c1c1; border-radius: 3px; font: 100% Consolas, Menlo, Monaco, monospace; margin-bottom: 1em; margin-top: 1em; } #wrapperlicious pre > code { display: block; background-color: #f6f6f6; font: 0.9em Consolas, Menlo, Monaco, monospace; line-height: 1.5em; text-align: left; white-space: pre; padding: 1em; } #wrapperlicious dl, #wrapperlicious ol, #wrapperlicious ul { margin-bottom: 1em; margin-top: 1em; } #wrapperlicious ul { list-style-type: square; } #wrapperlicious ul ul { margin-bottom: 0px; margin-top: 0px; } #footer { font-size: 0.8em; padding-top: 0.5em; text-align: center; } #more { display: inline; font-size: 0.8em; } #perldocdiv { background-color: #fff; border: 1px solid #c1c1c1; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; margin-left: auto; margin-right: auto; padding: 3em; padding-top: 1em; max-width: 960px; } #moduleversion { float: right } #wrapperlicious .leading-notice { font-style: italic; padding-left: 1em; margin-top: 1em; margin-bottom: 1em; } #wrapperlicious .permalink { display: none; left: -0.75em; position: absolute; padding-right: 0.25em; text-decoration: none; } #wrapperlicious h1:hover .permalink, #wrapperlicious h2:hover .permalink, #wrapperlicious h3:hover .permalink, #wrapperlicious h4:hover .permalink, #wrapperlicious dt:hover .permalink { display: block; } </style> <!-- Global site tag (gtag.js) - Google Analytics --> <script async src="https://www.googletagmanager.com/gtag/js?id=G-KVNWBNT5FB"></script> <script> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-KVNWBNT5FB'); gtag('config', 'UA-50555-3'); </script> </head> <body> <nav class="navbar navbar-expand-md navbar-dark bg-dark justify-content-between"> <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <a class="navbar-brand" href="/"><img src="/images/perl_camel_30.png" width="30" height="30" class="d-inline-block align-top" alt="Perl Camel Logo"> Perldoc Browser</a> <div class="collapse navbar-collapse" id="navbarNav"> <ul class="navbar-nav mr-auto"> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-stable" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">5.39.7</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-stable"> <a class="dropdown-item" href="/open">Latest</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.40.1/open">5.40.1</a> <a class="dropdown-item" href="/5.40.0/open">5.40.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.38.3/open">5.38.3</a> <a class="dropdown-item" href="/5.38.2/open">5.38.2</a> <a class="dropdown-item" href="/5.38.1/open">5.38.1</a> <a class="dropdown-item" href="/5.38.0/open">5.38.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.36.3/open">5.36.3</a> <a class="dropdown-item" href="/5.36.2/open">5.36.2</a> <a class="dropdown-item" href="/5.36.1/open">5.36.1</a> <a class="dropdown-item" href="/5.36.0/open">5.36.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.34.3/open">5.34.3</a> <a class="dropdown-item" href="/5.34.2/open">5.34.2</a> <a class="dropdown-item" href="/5.34.1/open">5.34.1</a> <a class="dropdown-item" href="/5.34.0/open">5.34.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.32.1/open">5.32.1</a> <a class="dropdown-item" href="/5.32.0/open">5.32.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.30.3/open">5.30.3</a> <a class="dropdown-item" href="/5.30.2/open">5.30.2</a> <a class="dropdown-item" href="/5.30.1/open">5.30.1</a> <a class="dropdown-item" href="/5.30.0/open">5.30.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.28.3/open">5.28.3</a> <a class="dropdown-item" href="/5.28.2/open">5.28.2</a> <a class="dropdown-item" href="/5.28.1/open">5.28.1</a> <a class="dropdown-item" href="/5.28.0/open">5.28.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.26.3/open">5.26.3</a> <a class="dropdown-item" href="/5.26.2/open">5.26.2</a> <a class="dropdown-item" href="/5.26.1/open">5.26.1</a> <a class="dropdown-item" href="/5.26.0/open">5.26.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.24.4/open">5.24.4</a> <a class="dropdown-item" href="/5.24.3/open">5.24.3</a> <a class="dropdown-item" href="/5.24.2/open">5.24.2</a> <a class="dropdown-item" href="/5.24.1/open">5.24.1</a> <a class="dropdown-item" href="/5.24.0/open">5.24.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.22.4/open">5.22.4</a> <a class="dropdown-item" href="/5.22.3/open">5.22.3</a> <a class="dropdown-item" href="/5.22.2/open">5.22.2</a> <a class="dropdown-item" href="/5.22.1/open">5.22.1</a> <a class="dropdown-item" href="/5.22.0/open">5.22.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.20.3/open">5.20.3</a> <a class="dropdown-item" href="/5.20.2/open">5.20.2</a> <a class="dropdown-item" href="/5.20.1/open">5.20.1</a> <a class="dropdown-item" href="/5.20.0/open">5.20.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.18.4/open">5.18.4</a> <a class="dropdown-item" href="/5.18.3/open">5.18.3</a> <a class="dropdown-item" href="/5.18.2/open">5.18.2</a> <a class="dropdown-item" href="/5.18.1/open">5.18.1</a> <a class="dropdown-item" href="/5.18.0/open">5.18.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.16.3/open">5.16.3</a> <a class="dropdown-item" href="/5.16.2/open">5.16.2</a> <a class="dropdown-item" href="/5.16.1/open">5.16.1</a> <a class="dropdown-item" href="/5.16.0/open">5.16.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.14.4/open">5.14.4</a> <a class="dropdown-item" href="/5.14.3/open">5.14.3</a> <a class="dropdown-item" href="/5.14.2/open">5.14.2</a> <a class="dropdown-item" href="/5.14.1/open">5.14.1</a> <a class="dropdown-item" href="/5.14.0/open">5.14.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.12.5/open">5.12.5</a> <a class="dropdown-item" href="/5.12.4/open">5.12.4</a> <a class="dropdown-item" href="/5.12.3/open">5.12.3</a> <a class="dropdown-item" href="/5.12.2/open">5.12.2</a> <a class="dropdown-item" href="/5.12.1/open">5.12.1</a> <a class="dropdown-item" href="/5.12.0/open">5.12.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.10.1/open">5.10.1</a> <a class="dropdown-item" href="/5.10.0/open">5.10.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.8.9/open">5.8.9</a> <a class="dropdown-item" href="/5.8.8/open">5.8.8</a> <a class="dropdown-item" href="/5.8.7/open">5.8.7</a> <a class="dropdown-item" href="/5.8.6/open">5.8.6</a> <a class="dropdown-item" href="/5.8.5/open">5.8.5</a> <a class="dropdown-item" href="/5.8.4/open">5.8.4</a> <a class="dropdown-item" href="/5.8.3/open">5.8.3</a> <a class="dropdown-item" href="/5.8.2/open">5.8.2</a> <a class="dropdown-item" href="/5.8.1/open">5.8.1</a> <a class="dropdown-item" href="/5.8.0/open">5.8.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.6.2/open">5.6.2</a> <a class="dropdown-item" href="/5.6.1/open">5.6.1</a> <a class="dropdown-item" href="/5.6.0/open">5.6.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.005_04/open">5.005_04</a> <a class="dropdown-item" href="/5.005_03/open">5.005_03</a> <a class="dropdown-item" href="/5.005_02/open">5.005_02</a> <a class="dropdown-item" href="/5.005_01/open">5.005_01</a> <a class="dropdown-item" href="/5.005/open">5.005</a> </div> </li> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-dev" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Dev</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-dev"> <a class="dropdown-item" href="/blead/open">blead</a> <a class="dropdown-item" href="/5.41.9/open">5.41.9</a> <a class="dropdown-item" href="/5.41.8/open">5.41.8</a> <a class="dropdown-item" href="/5.41.7/open">5.41.7</a> <a class="dropdown-item" href="/5.41.6/open">5.41.6</a> <a class="dropdown-item" href="/5.41.5/open">5.41.5</a> <a class="dropdown-item" href="/5.41.4/open">5.41.4</a> <a class="dropdown-item" href="/5.41.3/open">5.41.3</a> <a class="dropdown-item" href="/5.41.2/open">5.41.2</a> <a class="dropdown-item" href="/5.41.1/open">5.41.1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.40.1-RC1/open">5.40.1-RC1</a> <a class="dropdown-item" href="/5.40.0-RC2/open">5.40.0-RC2</a> <a class="dropdown-item" href="/5.40.0-RC1/open">5.40.0-RC1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.39.10/open">5.39.10</a> <a class="dropdown-item" href="/5.39.9/open">5.39.9</a> <a class="dropdown-item" href="/5.39.8/open">5.39.8</a> <a class="dropdown-item active" href="/5.39.7/open">5.39.7</a> <a class="dropdown-item" href="/5.39.6/open">5.39.6</a> <a class="dropdown-item" href="/5.39.5/open">5.39.5</a> <a class="dropdown-item" href="/5.39.4/open">5.39.4</a> <a class="dropdown-item" href="/5.39.3/open">5.39.3</a> <a class="dropdown-item" href="/5.39.2/open">5.39.2</a> <a class="dropdown-item" href="/5.39.1/open">5.39.1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.38.3-RC1/open">5.38.3-RC1</a> </div> </li> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-nav" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Documentation</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-nav"> <a class="dropdown-item" href="/5.39.7/perl">Perl</a> <a class="dropdown-item" href="/5.39.7/perlintro">Intro</a> <a class="dropdown-item" href="/5.39.7/perl#Tutorials">Tutorials</a> <a class="dropdown-item" href="/5.39.7/perlfaq">FAQs</a> <a class="dropdown-item" href="/5.39.7/perl#Reference-Manual">Reference</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.39.7/perlop">Operators</a> <a class="dropdown-item" href="/5.39.7/functions">Functions</a> <a class="dropdown-item" href="/5.39.7/variables">Variables</a> <a class="dropdown-item" href="/5.39.7/modules">Modules</a> <a class="dropdown-item" href="/5.39.7/perlutil">Utilities</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.39.7/perldelta">Release Notes</a> <a class="dropdown-item" href="/5.39.7/perlcommunity">Community</a> <a class="dropdown-item" href="/5.39.7/perlhist">History</a> </div> </li> </ul> <ul class="navbar-nav"> <script> function set_expand (expand) { var perldocdiv = document.getElementById('perldocdiv'); var width = window.getComputedStyle(perldocdiv).getPropertyValue('max-width'); var expanded = (width == '' || width == 'none') ? true : false; if (expand === null) { expand = !expanded; } if ((expand && !expanded) || (!expand && expanded)) { perldocdiv.style.setProperty('max-width', expand ? 'none' : '960px'); var button_classlist = document.getElementById('content-expand-button').classList; if (expand) { button_classlist.add('btn-light'); button_classlist.remove('btn-outline-light'); } else { button_classlist.add('btn-outline-light'); button_classlist.remove('btn-light'); } } return expand; } function toggle_expand () { var expand = set_expand(null); document.cookie = 'perldoc_expand=' + (expand ? 1 : 0) + '; path=/; expires=Tue, 19 Jan 2038 03:14:07 UTC'; } function read_expand () { return document.cookie.split(';').some(function (item) { return item.indexOf('perldoc_expand=1') >= 0 }); } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', function () { if (read_expand()) { set_expand(true); } }); } else if (read_expand()) { set_expand(true); } </script> <button id="content-expand-button" type="button" class="btn btn-outline-light d-none d-lg-inline-block mr-4" onclick="toggle_expand()">Expand</button> </ul> <form class="form-inline" method="get" action="/5.39.7/search"> <input class="form-control mr-3" type="search" name="q" placeholder="Search" aria-label="Search" value=""> </form> </div> </nav> <div id="wrapperlicious" class="container-fluid"> <div id="perldocdiv"> <div id="links"> <a href="/5.39.7/open">open</a> <div id="more"> (<a href="/5.39.7/open.txt">source</a>, <a href="https://metacpan.org/pod/open">CPAN</a>) </div> <div id="moduleversion">version 1.13</div> </div> <div class="leading-notice"> You are viewing the version of this documentation from Perl 5.39.7. This is a development version of Perl. </div> <div class="leading-notice"> <strong>open</strong> may also refer to the function: <a href="/5.39.7/functions/open">open</a> </div> <h1><a id="toc">CONTENTS</a></h1> <ul> <li> <a class="text-decoration-none" href="#NAME">NAME</a> </li> <li> <a class="text-decoration-none" href="#SYNOPSIS">SYNOPSIS</a> </li> <li> <a class="text-decoration-none" href="#DESCRIPTION">DESCRIPTION</a> </li> <li> <a class="text-decoration-none" href="#IMPLEMENTATION-DETAILS">IMPLEMENTATION DETAILS</a> </li> <li> <a class="text-decoration-none" href="#SEE-ALSO">SEE ALSO</a> </li> </ul> <h1 id="NAME"><a class="permalink" href="#NAME">#</a>NAME</h1> <p>open - perl pragma to set default PerlIO layers for input and output</p> <h1 id="SYNOPSIS"><a class="permalink" href="#SYNOPSIS">#</a>SYNOPSIS</h1> <pre><code>use open IN =&gt; &#39;:crlf&#39;, OUT =&gt; &#39;:raw&#39;; open my $in, &#39;&lt;&#39;, &#39;foo.txt&#39; or die &quot;open failed: $!&quot;; my $line = &lt;$in&gt;; # CRLF translated close $in; open my $out, &#39;&gt;&#39;, &#39;bar.txt&#39; or die &quot;open failed: $!&quot;; print $out $line; # no translation of bytes close $out; use open OUT =&gt; &#39;:encoding(UTF-8)&#39;; use open IN =&gt; &#39;:encoding(iso-8859-7)&#39;; use open IO =&gt; &#39;:locale&#39;; # IO implicit only for :utf8, :encoding, :locale use open &#39;:encoding(UTF-8)&#39;; use open &#39;:encoding(iso-8859-7)&#39;; use open &#39;:locale&#39;; # with :std, also affect global standard handles use open &#39;:std&#39;, &#39;:encoding(UTF-8)&#39;; use open &#39;:std&#39;, OUT =&gt; &#39;:encoding(cp1252)&#39;; use open &#39;:std&#39;, IO =&gt; &#39;:raw :encoding(UTF-16LE)&#39;;</code></pre> <h1 id="DESCRIPTION"><a class="permalink" href="#DESCRIPTION">#</a>DESCRIPTION</h1> <p>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).</p> <p>The <code>open</code> pragma serves as one of the interfaces to declare default &quot;layers&quot; (previously known as &quot;disciplines&quot;) 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 <a href="/5.39.7/perlvar#%24%7B%5EOPEN%7D"><code>${^OPEN}</code></a> variable.</p> <p>Layers are specified with a leading colon by convention. You can specify a stack of multiple layers as a space-separated string. See <a href="/5.39.7/PerlIO">PerlIO</a> for more information on the available layers.</p> <p>With the <code>IN</code> subpragma you can declare the default layers of input streams, and with the <code>OUT</code> subpragma you can declare the default layers of output streams. With the <code>IO</code> subpragma (may be omitted for <code>:utf8</code>, <code>:locale</code>, or <code>:encoding</code>) you can control both input and output streams simultaneously.</p> <p>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 <a href="/5.39.7/PerlIO#Defaults-and-how-to-override-them">&quot;Defaults and how to override them&quot; in PerlIO</a>.</p> <p>To translate from and to an arbitrary text encoding, use the <code>:encoding</code> layer. The matching of encoding names in <code>:encoding</code> is loose: case does not matter, and many encodings have several aliases. See <a href="/5.39.7/Encode::Supported">Encode::Supported</a> for details and the list of supported locales.</p> <p>If you want to set your encoding layers based on your locale environment variables, you can use the <code>:locale</code> pseudo-layer. For example:</p> <pre><code>$ENV{LANG} = &#39;ru_RU.KOI8-R&#39;; # the :locale will probe the locale environment variables like LANG use open OUT =&gt; &#39;:locale&#39;; open(my $out, &#39;&gt;&#39;, &#39;koi8&#39;) or die &quot;open failed: $!&quot;; print $out chr(0x430); # CYRILLIC SMALL LETTER A = KOI8-R 0xc1 close $out; open(my $in, &#39;&lt;&#39;, &#39;koi8&#39;) or die &quot;open failed: $!&quot;; printf &quot;%#x\n&quot;, ord(&lt;$in&gt;); # this should print 0xc1 close $in;</code></pre> <p>The logic of <code>:locale</code> is described in full in <a href="/5.39.7/encoding#The-%3Alocale-sub-pragma">&quot;The <code>:locale</code> sub-pragma&quot; in encoding</a>, but in short it is first trying nl_langinfo(CODESET) and then guessing from the LC_ALL and LANG locale environment variables. <code>:locale</code> also implicitly turns on <code>:std</code>.</p> <p><code>:std</code> 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 <code>:encoding</code> layer, the existing <code>:encoding</code> layer will also be removed.</p> <p>For example, if both input and out are chosen to be <code>:encoding(UTF-8)</code>, a <code>:std</code> will mean that STDIN, STDOUT, and STDERR will also have <code>:encoding(UTF-8)</code> set. On the other hand, if only output is chosen to be in <code>:encoding(koi8r)</code>, a <code>:std</code> will cause only the STDOUT and STDERR to be in <code>koi8r</code>.</p> <p>The effect of <code>:std</code> 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.</p> <pre><code class="plaintext">{ use open &#39;:std&#39;, IO =&gt; &#39;:encoding(UTF-8)&#39; }</code></pre> <p>Before Perl 5.34, <code>:std</code> would only apply the first layer provided that is either <code>:utf8</code> or has a layer argument, e.g. <code>:encoding(UTF-8)</code>. Since Perl 5.34 it will apply the same layer stack it provides to <code>${^OPEN}</code>.</p> <h1 id="IMPLEMENTATION-DETAILS"><a class="permalink" href="#IMPLEMENTATION-DETAILS">#</a><a id="IMPLEMENTATION"></a>IMPLEMENTATION DETAILS</h1> <p>There is a class method in <code>PerlIO::Layer</code> <code>find</code> which is implemented as XS code. It is called by <code>import</code> to validate the layers:</p> <pre><code>PerlIO::Layer::-&gt;find(&quot;perlio&quot;)</code></pre> <p>The return value (if defined) is a Perl object, of class <code>PerlIO::Layer</code> which is created by the C code in <i>perlio.c</i>. As yet there is nothing useful you can do with the object at the perl level.</p> <h1 id="SEE-ALSO"><a class="permalink" href="#SEE-ALSO">#</a><a id="SEE"></a>SEE ALSO</h1> <p><a href="/5.39.7/perlfunc#binmode">&quot;binmode&quot; in perlfunc</a>, <a href="/5.39.7/perlfunc#open">&quot;open&quot; in perlfunc</a>, <a href="/5.39.7/perlunicode">perlunicode</a>, <a href="/5.39.7/PerlIO">PerlIO</a>, <a href="/5.39.7/encoding">encoding</a></p> </div> <div id="footer"> <p>Perldoc Browser is maintained by Dan Book (<a href="https://metacpan.org/author/DBOOK">DBOOK</a>). Please contact him via the <a href="https://github.com/Grinnz/perldoc-browser/issues">GitHub issue tracker</a> or <a href="mailto:dbook@cpan.org">email</a> regarding any issues with the site itself, search, or rendering of documentation.</p> <p>The Perl documentation is maintained by the Perl 5 Porters in the development of Perl. Please contact them via the <a href="https://github.com/Perl/perl5/issues">Perl issue tracker</a>, the <a href="https://lists.perl.org/list/perl5-porters.html">mailing list</a>, or <a href="https://kiwiirc.com/client/irc.perl.org/p5p">IRC</a> to report any issues with the contents or format of the documentation.</p> </div> </div> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.slim.min.js" integrity="sha512-/DXTXr6nQodMUiq+IUJYCt2PPOUjrHJ9wFrqpJ3XkgPNOZVfMok7cRw6CSxyCQxXn6ozlESsSh1/sMCTF1rL/g==" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.1/umd/popper.min.js" integrity="sha512-ubuT8Z88WxezgSqf3RLuNi5lmjstiJcyezx34yIU2gAHonIi27Na7atqzUZCOoY4CExaoFumzOsFQ2Ch+I/HCw==" crossorigin="anonymous"></script> <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js" integrity="sha384-B4gt1jrGC7Jh4AgTPSdUtOBvfO8shuf57BaghqFfPlYxofvL8/KUEfYiJOMMV+rV" crossorigin="anonymous"></script> <script src="/js/highlight.pack.js"></script> <script>hljs.highlightAll();</script> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10