X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMooseX%2FGetopt%2FMeta%2FAttribute.pm;h=6a37acd32ac3cbf5c7c5bf15e6d11a64bbe7850c;hb=195fb408a61ad34e0e41887b4f9f8dc384dd5da5;hp=387060f8414daeeaa1029b69577a931bc0b16aaa;hpb=7ff9f8b5e03f470cef8d8e630a92d7a18784a1a1;p=gitmo%2FMooseX-Getopt.git diff --git a/lib/MooseX/Getopt/Meta/Attribute.pm b/lib/MooseX/Getopt/Meta/Attribute.pm index 387060f..6a37acd 100644 --- a/lib/MooseX/Getopt/Meta/Attribute.pm +++ b/lib/MooseX/Getopt/Meta/Attribute.pm @@ -1,46 +1,36 @@ - package MooseX::Getopt::Meta::Attribute; +# ABSTRACT: Optional meta attribute for custom option names + use Moose; use Moose::Util::TypeConstraints; -our $VERSION = '0.19'; -our $AUTHORITY = 'cpan:STEVAN'; - extends 'Moose::Meta::Attribute'; # << Moose extending Moose :) with 'MooseX::Getopt::Meta::Attribute::Trait'; no Moose; # register this as a metaclass alias ... -package # stop confusing PAUSE +package # stop confusing PAUSE Moose::Meta::Attribute::Custom::Getopt; sub register_implementation { 'MooseX::Getopt::Meta::Attribute' } 1; -__END__ - -=pod - -=head1 NAME - -MooseX::Getopt::Meta::Attribute - Optional meta attribute for custom option names - =head1 SYNOPSIS package App; use Moose; - + with 'MooseX::Getopt'; - + has 'data' => ( - metaclass => 'MooseX::Getopt::Meta::Attribute', + metaclass => ['Getopt'], is => 'ro', isa => 'Str', default => 'file.dat', - # tells MooseX::Getopt to use --somedata as the - # command line flag instead of the normal + # tells MooseX::Getopt to use --somedata as the + # command line flag instead of the normal # autogenerated one (--data) cmd_flag => 'somedata', @@ -55,65 +45,44 @@ MooseX::Getopt::Meta::Attribute - Optional meta attribute for custom option name =head1 DESCRIPTION -This is a custom attribute metaclass which can be used to specify a -the specific command line flag to use instead of the default one -which L will create for you. +This is a custom attribute metaclass which can be used to specify a +the specific command line flag to use instead of the default one +which L will create for you. -This is certainly not the prettiest way to go about this, but for +This is certainly not the prettiest way to go about this, but for now it works for those who might need such a feature. +=head2 Use 'traits' instead of 'metaclass' + +You should rarely need to explicitly set the attribute metaclass. It is much +preferred to simply provide a trait (a role applied to the attribute +metaclass), which allows other code to futher modify the attribute by applying +additional roles. + +Therefore, you should first try to do this: + + has 'foo' => (traits => ['Getopt'], cmd_flag => 'f'); + =head2 Custom Metaclass alias -This now takes advantage of the Moose 0.19 feature to support +This now takes advantage of the Moose 0.19 feature to support custom attribute metaclass aliases. This means you can also use this as the B alias, like so: has 'foo' => (metaclass => 'Getopt', cmd_flag => 'f'); -=head1 METHODS - -These methods are of little use to most users, they are used interally -within L. - -=over 4 - -=item B +=method B Changes the commandline flag to be this value, instead of the default, which is the same as the attribute name. -=item B +=method B Adds more aliases for this commandline flag, useful for short options and such. -=item B - -=item B - -=item B - -=back - -=head1 BUGS - -All complex software has bugs lurking in it, and this module is no -exception. If you find a bug please either email me, or add the bug -to cpan-RT. - -=head1 AUTHOR - -Stevan Little Estevan@iinteractive.comE - -Brandon L. Black, Eblblack@gmail.comE - -=head1 COPYRIGHT AND LICENSE - -Copyright 2007-2008 by Infinity Interactive, Inc. - -L +=method B -This library is free software; you can redistribute it and/or modify -it under the same terms as Perl itself. +=method B =cut