/usr/lib/x86_64-linux-gnu/perl5/5.26/Text/Bidi/Array.pm is in libtext-bidi-perl 2.12-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | # Created: Wed 11 Sep 2013 09:47:56 AM IDT
# Last Changed: Mon 23 Sep 2013 09:20:16 AM IDT
use 5.10.0;
use warnings;
use integer;
use strict;
package Text::Bidi::Array;
# ABSTRACT: Base class for dual life arrays
$Text::Bidi::Array::VERSION = '2.12';
use Carp;
use Tie::Array;
use base qw(Tie::Array);
use overload
'${}' => 'as_scalar', '@{}' => 'as_array', '""' => 'data', fallback => 1;
sub new {
my $class = shift;
my $self = tie(my @magic, $class, @_);
$self->{'magic'} = \@magic;
$self
}
sub TIEARRAY {
my $class = shift;
my $data = shift || 0;
my $self = { @_ };
bless $self => $class;
$self->_init($data)
}
sub _init {
my ($self, $data) = @_;
if ( ref($data) ) {
my @data = eval { @$data };
croak $@ if $@;
$data = $self->pack(@data);
}
$self->{'data'} = $data;
return $self
}
sub data { $_[0]->{'data'} }
sub as_scalar { \$_[0]->{'data'} }
sub as_array { $_[0]->{'magic'} }
sub CLEAR {
$_[0]->{'data'} = 0
}
1;
__END__
=pod
=head1 NAME
Text::Bidi::Array - Base class for dual life arrays
=head1 VERSION
version 2.12
=head1 SYNOPSIS
use Text::Bidi::Array::Byte;
my $a = new Text::Bidi::Array::Byte "abc";
say $a->[1]; # says 98
say $$a; # says abc
say "$a"; # also says abc
=head1 DESCRIPTION
This is an abstract base class for objects that function as ``dual-life''
arrays: When viewed as an array reference, it functions as a usual array of
numbers. When used as a scalar reference, it returns the same array as a
packed string. The packing specification depends on the sub-class. These
classes are used in L<Text::Bidi> to conveniently pass arrays to the
underlying fribidi library, but could be of independent interest.
=head1 OVERLOADED OPERATORS
An object of this type can be dereferenced either as a scalar or as an array.
In the first case, it returns the packed (string) representation of the
array. In the second, it returns the unpacked array of numbers.
The packed representation is also returned when the object is used as a
string.
=head1 CONSTRUCTION
$a = new Text::Bidi::Array::<Type> $data
Create a new array of the given B<Type>, and initialise it with I<$data>.
I<$data> can be either a string, which the new object then view as an array
of the given type, or an array reference (more precisely, anything that can
be dereferenced as an array), which is then packed according to the rules of
B<Type>. If no I<$data> is given, it defaults to 0.
=for Pod::Coverage new
=head1 SEE ALSO
L<Text::Bidi::Array::Byte>, L<Text::Bidi::Array::Long>
=head1 FOR IMPLEMENTORS
The rest of this documentation is for writing specific derived classes. The
object is represented internally as a hashref. To implement a particular
instance, the following methods should be implemented. Each of these should
manipulate the field C<data>, which is the string that stores the actual
value. Unimplemented methods will lead to croaking. See
L<Text::Bidi::Array::Byte> and L<Text::Bidi::Array::Long> for examples.
=over
=item $self->pack(@data)
Convert (pack) an array of numbers into a string according to the format of
the current class (this will probably be a class method). Returns the string.
=back
The following methods should behave as described in L<Tie::Array>.
=over
=item $self->STORE($index, $value)
Store the I<$value> in the part of C<$self-E<gt>{'data'}> corresponding to
I<$index>.
=item $self->FETCH($index)
Fetch the value at I<$index> from the correct part of C<$self-E<gt>{'data'}>.
=item $self->STORESIZE($count)
Modify C<$self-E<gt>{'data'}> to represent an array of size I<$count>.
=item $self->FETCHSIZE()
Return the size of the array represented by C<$self-E<gt>{'data'}>.
=back
=for Pod::Coverage data as_scalar as_array
=head1 AUTHOR
Moshe Kamensky <kamensky@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Moshe Kamensky.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
|