NAME
Tie::Moose - tie a hash to a Moose object (yeah, like Tie::MooseObject)
SYNOPSIS
use v5.14;
package Person {
use Moose;
has name => (
is => "rw",
isa => "Str",
);
has age => (
is => "rw",
isa => "Num",
reader => "get_age",
writer => "set_age",
);
}
my $bob = Person->new(name => "Robert");
tie my %bob, "Tie::Moose", $bob;
$bob{age} = 32; # calls the "set_age" method
$bob{age} = "x"; # would croak
$bob{xyz} = "x"; # would croak
DESCRIPTION
This module is much like Tie::MooseObject. It ties a hash to an instance of a Moose-based class, allowing you to access attributes as hash keys. It uses the accessors provided by Moose, and thus honours read-only attributes, type constraints and coercions, triggers, etc.
There are a few key differences with Tie::MooseObject:
It handles differently named getters/setters more to my liking. Given the example in the SYNOPSIS, with Tie::MooseObject you need to write:
$bob{set_age} = 32; say $bob{get_age};
Whereas with Tie::Moose, you just use the
age
hash key for both fetching from and storing to the hash.Implements
DELETE
from the Tie::Hash interface. Tie::MooseObject does not allow keys to be deleted from its hashes.(
DELETE
only works on Moose attributes that have a "clearer" method.)Supplied with various traits to influence the behaviour of the tied hash.
tie my %bob, "Tie::Moose"->with_traits("ReadOnly"), $bob;
(Note that by design, many of the traits supplied with Tie::Moose are mutually exclusive.)
BUGS
Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=Tie-Moose.
SEE ALSO
Traits for Tie::Moose hashes: Tie::Moose::ReadOnly, Tie::Moose::Forgiving, Tie::Moose::FallbackHash, Tie::Moose::FallbackSlot.
AUTHOR
Toby Inkster <tobyink@cpan.org>.
COPYRIGHT AND LICENCE
This software is copyright (c) 2013 by Toby Inkster.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
DISCLAIMER OF WARRANTIES
THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.