0.12
[gitmo/MooseX-Getopt.git] / lib / MooseX / Getopt / Meta / Attribute / Trait / NoGetopt.pm
diff --git a/lib/MooseX/Getopt/Meta/Attribute/Trait/NoGetopt.pm b/lib/MooseX/Getopt/Meta/Attribute/Trait/NoGetopt.pm
new file mode 100644 (file)
index 0000000..4603936
--- /dev/null
@@ -0,0 +1,75 @@
+
+package MooseX::Getopt::Meta::Attribute::Trait::NoGetopt;
+use Moose::Role;
+
+our $VERSION   = '0.01';
+our $AUTHORITY = 'cpan:STEVAN';
+
+no Moose::Role;
+
+# register this as a metaclass alias ...
+package # stop confusing PAUSE
+    Moose::Meta::Attribute::Custom::Trait::NoGetopt;
+sub register_implementation { 'MooseX::Getopt::Meta::Attribute::Trait::NoGetopt' }
+
+1;
+
+__END__
+
+=pod
+
+=head1 NAME
+
+MooseX::Getopt::Meta::Attribute::Trait::NoGetopt - Optional meta attribute trait for ignoring params
+
+=head1 SYNOPSIS
+
+  package App;
+  use Moose;
+  
+  with 'MooseX::Getopt';
+  
+  has 'data' => (
+      traits  => [ 'NoGetopt' ],  # do not attempt to capture this param  
+      is      => 'ro',
+      isa     => 'Str',
+      default => 'file.dat',
+  );
+
+=head1 DESCRIPTION
+
+This is a custom attribute metaclass trait which can be used to 
+specify that a specific attribute should B<not> be processed by 
+C<MooseX::Getopt>. All you need to do is specify the C<NoGetopt> 
+metaclass trait.
+
+  has 'foo' => (traits => [ 'NoGetopt', ... ], ... );
+
+=head1 METHODS
+
+=over 4
+
+=item B<meta>
+
+=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 E<lt>stevan@iinteractive.comE<gt>
+
+=head1 COPYRIGHT AND LICENSE
+
+Copyright 2007-2008 by Infinity Interactive, Inc.
+
+L<http://www.iinteractive.com>
+
+This library is free software; you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut