Acme-Sort-Sleep
view release on metacpan or search on metacpan
local/lib/perl5/Struct/Dumb.pm view on Meta::CPAN
printf "Point is now at (%d, %d)\n", $point->x, $point->y;
Z<>
struct Point3D => [qw( x y z )], named_constructor => 1;
my $point3d = Point3D( z => 12, x => 100, y => 50 );
printf "Point3d's height is %d\n", $point3d->z;
Z<>
struct Point3D => [qw( x y z )], predicate => "is_Point3D";
my $point3d = Point3D( 1, 2, 3 );
printf "This is a Point3D\n" if is_Point3D( $point3d );
Z<>
use Struct::Dumb qw( -named_constructors )
struct Point3D => [qw( x y z ];
my $point3d = Point3D( x => 100, z => 12, y => 50 );
=head1 DESCRIPTION
C<Struct::Dumb> creates record-like structure types, similar to the C<struct>
keyword in C, C++ or C#, or C<Record> in Pascal. An invocation of this module
will create a construction function which returns new object references with
the given field values. These references all respond to lvalue methods that
access or modify the values stored.
It's specifically and intentionally not meant to be an object class. You
cannot subclass it. You cannot provide additional methods. You cannot apply
roles or mixins or metaclasses or traits or antlers or whatever else is in
fashion this week.
On the other hand, it is tiny, creates cheap lightweight array-backed
structures, uses nothing outside of core. It's intended simply to be a
slightly nicer way to store data structures, where otherwise you might be
tempted to abuse a hash, complete with the risk of typoing key names. The
constructor will C<croak> if passed the wrong number of arguments, as will
attempts to refer to fields that don't exist. Accessor-mutators will C<croak>
if invoked with arguments. (This helps detect likely bugs such as accidentally
passing in the new value as an argument, or attempting to invoke a stored
C<CODE> reference by passing argument values directly to the accessor.)
$ perl -E 'use Struct::Dumb; struct Point => [qw( x y )]; Point(30)'
usage: main::Point($x, $y) at -e line 1
$ perl -E 'use Struct::Dumb; struct Point => [qw( x y )]; Point(10,20)->z'
main::Point does not have a 'z' field at -e line 1
$ perl -E 'use Struct::Dumb; struct Point => [qw( x y )]; Point(1,2)->x(3)'
main::Point->x invoked with arguments at -e line 1.
Objects in this class are (currently) backed by an ARRAY reference store,
though this is an internal implementation detail and should not be relied on
by using code. Attempting to dereference the object as an ARRAY will throw an
exception.
=head2 CONSTRUCTOR FORMS
The C<struct> and C<readonly_struct> declarations create two different kinds
of constructor function, depending on the setting of the C<named_constructor>
option. When false, the constructor takes positional values in the same order
as the fields were declared. When true, the constructor takes a key/value pair
list in no particular order, giving the value of each named field.
This option can be specified to the C<struct> and C<readonly_struct>
functions. It defaults to false, but it can be set on a per-package basis to
default true by supplying the C<-named_constructors> option on the C<use>
statement.
=cut
sub import
{
my $pkg = shift;
my $caller = caller;
my %default_opts;
my %syms;
foreach ( @_ ) {
if( $_ eq "-named_constructors" ) {
$default_opts{named_constructor} = 1;
}
else {
$syms{$_}++;
}
}
keys %syms or $syms{struct}++;
my %export;
if( delete $syms{struct} ) {
$export{struct} = sub {
my ( $name, $fields, @opts ) = @_;
_struct( $name, $fields, scalar caller, lvalue => 1, %default_opts, @opts );
};
}
if( delete $syms{readonly_struct} ) {
$export{readonly_struct} = sub {
my ( $name, $fields, @opts ) = @_;
_struct( $name, $fields, scalar caller, lvalue => 0, %default_opts, @opts );
};
}
if( keys %syms ) {
croak "Unrecognised export symbols " . join( ", ", keys %syms );
}
no strict 'refs';
*{"${caller}::$_"} = $export{$_} for keys %export;
}
=head1 FUNCTIONS
( run in 0.339 second using v1.01-cache-2.11-cpan-39bf76dae61 )