PHP 8.5.2
Preview: bytes.pm Size: 3.69 KB
//usr/share/perl/5.38.2/bytes.pm

package bytes;

use strict;
use warnings;

our $VERSION = '1.08';

$bytes::hint_bits = 0x00000008;

sub import {
    $^H |= $bytes::hint_bits;
}

sub unimport {
    $^H &= ~$bytes::hint_bits;
}

our $AUTOLOAD;
sub AUTOLOAD {
    require "bytes_heavy.pl";
    goto &$AUTOLOAD if defined &$AUTOLOAD;
    require Carp;
    Carp::croak("Undefined subroutine $AUTOLOAD called");
}

sub length (_);
sub chr (_);
sub ord (_);
sub substr ($$;$$);
sub index ($$;$);
sub rindex ($$;$);

1;
__END__

=head1 NAME

bytes - Perl pragma to expose the individual bytes of characters

=head1 NOTICE

Because the bytes pragma breaks encapsulation (i.e. it exposes the innards of
how the perl executable currently happens to store a string), the byte values
that result are in an unspecified encoding.

B<Use of this module for anything other than debugging purposes is
strongly discouraged.>  If you feel that the functions here within
might be useful for your application, this possibly indicates a
mismatch between your mental model of Perl Unicode and the current
reality. In that case, you may wish to read some of the perl Unicode
documentation: L<perluniintro>, L<perlunitut>, L<perlunifaq> and
L<perlunicode>.

=head1 SYNOPSIS

    use bytes;
    ... chr(...);       # or bytes::chr
    ... index(...);     # or bytes::index
    ... length(...);    # or bytes::length
    ... ord(...);       # or bytes::ord
    ... rindex(...);    # or bytes::rindex
    ... substr(...);    # or bytes::substr
    no bytes;


=head1 DESCRIPTION

Perl's characters are stored internally as sequences of one or more bytes.
This pragma allows for the examination of the individual bytes that together
comprise a character.

Originally the pragma was designed for the loftier goal of helping incorporate
Unicode into Perl, but the approach that used it was found to be defective,
and the one remaining legitimate use is for debugging when you need to
non-destructively examine characters' individual bytes.  Just insert this
pragma temporarily, and remove it after the debugging is finished.

The original usage can be accomplished by explicit (rather than this pragma's
implicit) encoding using the L<Encode> module:

    use Encode qw/encode/;

    my $utf8_byte_string   = encode "UTF8",   $string;
    my $latin1_byte_string = encode "Latin1", $string;

Or, if performance is needed and you are only interested in the UTF-8
representation:

    utf8::encode(my $utf8_byte_string = $string);

C<no bytes> can be used to reverse the effect of C<use bytes> within the
current lexical scope.

As an example, when Perl sees C<$x = chr(400)>, it encodes the character
in UTF-8 and stores it in C<$x>. Then it is marked as character data, so,
for instance, C<length $x> returns C<1>. However, in the scope of the
C<bytes> pragma, C<$x> is treated as a series of bytes - the bytes that make
up the UTF8 encoding - and C<length $x> returns C<2>:

 $x = chr(400);
 print "Length is ", length $x, "\n";     # "Length is 1"
 printf "Contents are %vd\n", $x;         # "Contents are 400"
 {
     use bytes; # or "require bytes; bytes::length()"
     print "Length is ", length $x, "\n"; # "Length is 2"
     printf "Contents are %vd\n", $x;     # "Contents are 198.144 (on
                                          # ASCII platforms)"
 }

C<chr()>, C<ord()>, C<substr()>, C<index()> and C<rindex()> behave similarly.

For more on the implications, see L<perluniintro> and L<perlunicode>.

C<bytes::length()> is admittedly handy if you need to know the
B<byte length> of a Perl scalar.  But a more modern way is:

   use Encode 'encode';
   length(encode('UTF-8', $scalar))

=head1 LIMITATIONS

C<bytes::substr()> does not work as an I<lvalue()>.

=head1 SEE ALSO

L<perluniintro>, L<perlunicode>, L<utf8>, L<Encode>

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