| MooseX-Role-Restricted documentation | view source | Contained in the MooseX-Role-Restricted distribution. |
MooseX::Role::Restricted - (DEPRECATED) Restrict which sub are exported by a role
package MyApp::MyRole;
use MooseX::Role::Restricted;
sub method1 { ... }
sub _private1 { ... }
sub _method2 :Public { ... }
sub private2 :Private { ... }
This module is no longer supported. I suggest looking at namespace::autoclean as an alternative.
In its default form MooseX::Role::Restricted simple excludes ann sub with names starting with _
to be excluded. This can be accomplished using
use namespace::autoclean -also => qr/^_/;
If you are using lazy_build or other Moose features that require the use of _ prefixed methods
make sure to change the pattern to not match those. Or use some other prefix, for example a double
_, for your private subs that you do not want included in the role.
By default Moose::Role will export any sub you define in a role package. However it does not export any sub which was imported from another package
MooseX::Role::Restricted give a little more control over which subs are exported and which are not.
By default an sub with a name starting with _ is considered private and will not
be exported. However MooseX::Role::Restricted provides two subroutine attributes
:Public and :Private which can control is any sub is exported or kept private
Graham Barr <gbarr@cpan.org>
Copyright (C) 2009 Graham Barr
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| MooseX-Role-Restricted documentation | view source | Contained in the MooseX-Role-Restricted distribution. |