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=5f35fecaab2d0df8766982669163615594d93c29;hpb=5dac17c3fb3f25ba558e70565462826017f0c91c;p=gitmo%2FMooseX-Getopt.git diff --git a/lib/MooseX/Getopt/Meta/Attribute.pm b/lib/MooseX/Getopt/Meta/Attribute.pm index 5f35fec..6a37acd 100644 --- a/lib/MooseX/Getopt/Meta/Attribute.pm +++ b/lib/MooseX/Getopt/Meta/Attribute.pm @@ -1,59 +1,88 @@ - package MooseX::Getopt::Meta::Attribute; +# ABSTRACT: Optional meta attribute for custom option names + use Moose; +use Moose::Util::TypeConstraints; -extends 'Moose::Meta::Attribute'; +extends 'Moose::Meta::Attribute'; # << Moose extending Moose :) + with 'MooseX::Getopt::Meta::Attribute::Trait'; -has 'cmd_flag' => ( - is => 'rw', - isa => 'Str', - predicate => 'has_cmd_flag', -); +no Moose; + +# register this as a metaclass alias ... +package # stop confusing PAUSE + Moose::Meta::Attribute::Custom::Getopt; +sub register_implementation { 'MooseX::Getopt::Meta::Attribute' } 1; -__END__ +=head1 SYNOPSIS + package App; + use Moose; -=pod + with 'MooseX::Getopt'; -=head1 NAME + has 'data' => ( + metaclass => ['Getopt'], + is => 'ro', + isa => 'Str', + default => 'file.dat', -MooseX::Getopt::Meta::Attribute - + # tells MooseX::Getopt to use --somedata as the + # command line flag instead of the normal + # autogenerated one (--data) + cmd_flag => 'somedata', -=head1 SYNOPSIS + # tells MooseX::Getopt to also allow --moosedata, + # -m, and -d as aliases for this same option on + # the commandline. + cmd_aliases => [qw/ moosedata m d /], + + # Or, you can use a plain scalar for a single alias: + cmd_aliases => 'm', + ); =head1 DESCRIPTION -=head1 METHODS +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 +now it works for those who might need such a feature. -=over 4 +=head2 Use 'traits' instead of 'metaclass' -=item B +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. -=item B +Therefore, you should first try to do this: -=item B + has 'foo' => (traits => ['Getopt'], cmd_flag => 'f'); -=back +=head2 Custom Metaclass alias -=head1 BUGS +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: -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. + has 'foo' => (metaclass => 'Getopt', cmd_flag => 'f'); -=head1 AUTHOR +=method B -Stevan Little Estevan@iinteractive.comE +Changes the commandline flag to be this value, instead of the default, +which is the same as the attribute name. -=head1 COPYRIGHT AND LICENSE +=method B -Copyright 2007 by Infinity Interactive, Inc. +Adds more aliases for this commandline flag, useful for short options +and such. -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 \ No newline at end of file +=cut