| Moose documentation | Contained in the Moose distribution. |
oose - syntactic sugar to make Moose one-liners easier
version 2.0010
# create a Moose class on the fly ...
perl -Moose=Foo -e 'has bar => ( is=>q[ro], default => q[baz] ); print Foo->new->bar' # prints baz
# loads an existing class (Moose or non-Moose)
# and re-"opens" the package definition to make
# debugging/introspection easier
perl -Moose=+My::Class -e 'print join ", " => __PACKAGE__->meta->get_method_list'
# also loads Moose::Util::TypeConstraints to allow subtypes etc
perl -Moose=Person -e'subtype q[ValidAge] => as q[Int] => where { $_ > 0 && $_ < 78 }; has => age ( isa => q[ValidAge], is => q[ro]); Person->new(age => 90)'
oose.pm is a simple source filter that adds
package $name; use Moose; use Moose::Util::TypeConstraints;
to the beginning of your script and was entirely created because typing
perl -e'package Foo; use Moose; ...' was annoying me.
oose provides exactly one method and it's automatically called by perl:
Pass a package name to import to be used by the source filter. The
package defaults to Class if none is given.
You will need Filter::Simple and eventually Moose
None reported. But it is a source filter and might have issues there.
See BUGS in Moose for details on reporting bugs.
Stevan Little <stevan@iinteractive.com>
This software is copyright (c) 2011 by Infinity Interactive, Inc..
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
| Moose documentation | Contained in the Moose distribution. |
package oose; BEGIN { $oose::AUTHORITY = 'cpan:STEVAN'; } BEGIN { $oose::VERSION = '2.0010'; } use strict; use warnings; use Class::MOP; BEGIN { my $package; sub import { $package = $_[1] || 'Class'; if ($package =~ /^\+/) { $package =~ s/^\+//; Class::MOP::load_class($package); } } use Filter::Simple sub { s/^/package $package;\nuse Moose;use Moose::Util::TypeConstraints;\n/; } } 1; # ABSTRACT: syntactic sugar to make Moose one-liners easier
__END__