use strict;
use overload '""' => sub { shift->name }, # stringify to method name
fallback => 1;
our $VERSION = '1.21';
$VERSION = eval $VERSION;
our $AUTHORITY = 'cpan:STEVAN';
# This is not a Moose::Meta::Role::Method because it has no implementation, it
# is just a name
__PACKAGE__->meta->add_attribute('name' => (
reader => 'name',
required => 1,
));
sub new { shift->_new(@_) }
1;
__END__
=pod
=head1 NAME
Moose::Meta::Role::Method::Required - A Moose metaclass for required methods in Roles
=head1 DESCRIPTION
=head1 INHERITANCE
C<Moose::Meta::Role::Method::Required> is a subclass of L<Class::MOP::Object>.
It is B<not> a subclass of C<Moose::Meta::Role::Method> since it does not
provide an implementation of the method.
=head1 METHODS
=over 4
=item B<< Moose::Meta::Role::Method::Required->new(%options) >>
This creates a new type constraint based on the provided C<%options>:
=over 8
=item * name
The method name. This is required.
=back
=item B<< $method->name >>
Returns the required method's name, as provided to the constructor.
=back
=head1 BUGS
See L<Moose/BUGS> for details on reporting bugs.
=head1 AUTHOR
Stevan Little E<lt>stevan@iinteractive.comE<gt>
=head1 COPYRIGHT AND LICENSE
Copyright 2006-2010 by Infinity Interactive, Inc.
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=cut