NAME

MooseX::RoleFor - limit the applicability of a Moose::Role

SYNOPSIS

package Watchdog;

use Moose::Role;
use MooseX::RoleFor;

role_for 'Dog';
requires 'make_noise';

sub hear_intruder
{
  my ($self) = @_;
  $self->make_noise;
}

1;

DESCRIPTION

This package allows your Moose roles to limit what classes and objects they may be composed with. This is often not a good idea - one of the advantages of roles is that they can be reused in such different contexts.

However, if you search CPAN for "TraitFor" you'll see that it's quite a common desire to indicate that a role should only be applies to certain classes.

role_for $class, $consequence

$class is a string (class name) or arrayref of strings indicating which classes this role may be composed with. Inheritance is respected.

$consequence is either "carp" (the default) or "croak".

How it works

Adding use MooseX::RoleFor to your role imports the role_for function to your class, and applies the MooseX::RoleFor::Meta::Role::Trait::RoleFor role to your role's metaclass.

The role_for function is basically:

sub role_for
{
  __PACKAGE__->meta->role_is_for($_[0])
  __PACKAGE__->meta->role_misapplication_consequence($_[1])
    if defined $_[1];
}

MooseX::RoleFor::Meta::Role::Trait::RoleFor hooks onto Moose::Meta::Role's apply method to enforce your restriction.

BUGS

Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=MooseX-RoleFor.

SEE ALSO

Moose, Moose::Meta::Role.

MooseX::RoleFor::Meta::Role::Trait::RoleFor - internals.

AUTHOR

Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE

This software is copyright (c) 2011 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.