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

Tie::MooseObject.

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.