X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMooseX%2FGetopt%2FMeta%2FAttribute.pm;h=70aaa615a3687006273dc2d02afa009a5d4aa46c;hb=75c37b0c2063f0029600645a9dff111631b87816;hp=55d17503f9a4e0efc3d833fadb1f44f838a77921;hpb=61c9baa93d25ec267a2997c06e8222c425e6015a;p=gitmo%2FMooseX-Getopt.git diff --git a/lib/MooseX/Getopt/Meta/Attribute.pm b/lib/MooseX/Getopt/Meta/Attribute.pm index 55d1750..70aaa61 100644 --- a/lib/MooseX/Getopt/Meta/Attribute.pm +++ b/lib/MooseX/Getopt/Meta/Attribute.pm @@ -1,61 +1,36 @@ - package MooseX::Getopt::Meta::Attribute; +# ABSTRACT: Optional meta attribute for custom option names + use Moose; use Moose::Util::TypeConstraints; -our $VERSION = '0.01'; -our $AUTHORITY = 'cpan:STEVAN'; - extends 'Moose::Meta::Attribute'; # << Moose extending Moose :) + with 'MooseX::Getopt::Meta::Attribute::Trait'; -has 'cmd_flag' => ( - is => 'rw', - isa => 'Str', - predicate => 'has_cmd_flag', -); - -# This subtype is to support scalar -> arrayref coercion -# without polluting the built-in types -subtype '_MooseX_Getopt_CmdAliases' - => as 'ArrayRef' - => where { 1 }; -coerce '_MooseX_Getopt_CmdAliases' - => from 'Value' - => via { [$_] }; - -has 'cmd_aliases' => ( - is => 'rw', - isa => '_MooseX_Getopt_CmdAliases', - predicate => 'has_cmd_aliases', - coerce => 1, -); - -no Moose; 1; - -__END__ +no Moose; +# register this as a metaclass alias ... +package # stop confusing PAUSE + Moose::Meta::Attribute::Custom::Getopt; +sub register_implementation { 'MooseX::Getopt::Meta::Attribute' } -=pod - -=head1 NAME - -MooseX::Getopt::Meta::Attribute - Optional meta attribute for custom option names +1; =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', @@ -70,55 +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. -=head1 METHODS +=head2 Use 'traits' instead of 'metaclass' -These methods are of little use to most users, they are used interally -within L. +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. -=over 4 +Therefore, you should first try to do this: -=item B + has 'foo' => (traits => ['Getopt'], cmd_flag => 'f'); -Changes the commandline flag to be this value, instead of the default, -which is the same as the attribute name. +=head2 Custom Metaclass alias -=item B +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: -Adds more aliases for this commandline flag, useful for short options -and such. - -=item B - -=item B - -=item B - -=back + has 'foo' => (metaclass => 'Getopt', cmd_flag => 'f'); -=head1 BUGS +=method B -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 +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