8 our $AUTHORITY = 'cpan:STEVAN';
13 $package = $_[1] || 'Class';
14 if ($package =~ /^\+/) {
16 Class::MOP::load_class($package);
19 use Filter::Simple sub { s/^/package $package;\nuse Moose;\n/; }
30 oose - syntactic sugar to make Moose one-liners easier
34 # create a Moose class on the fly ...
35 perl -Moose=Foo -e 'has bar => ( is=>q[ro], default => q[baz] ); print Foo->new->bar' # prints baz
37 # loads an existing class (Moose or non-Moose)
38 # and re-"opens" the package definition to make
39 # debugging/introspection easier
40 perl -Moose=+My::Class -e 'print join ", " => __PACKAGE__->meta->get_method_list'
44 oose.pm is a simple source filter that adds C<package $name; use Moose;>
45 to the beginning of your script and was entirely created because typing
46 perl -e'package Foo; use Moose; ...' was annoying me.
50 oose provides exactly one method and it's automically called by perl:
54 =item B<import($package)>
56 Pass a package name to import to be used by the source filter.
62 You will need L<Filter::Simple> and eventually L<Moose>
64 =head1 INCOMPATIBILITIES
66 None reported. But it is a source filter and might have issues there.
70 All complex software has bugs lurking in it, and this module is no
71 exception. If you find a bug please either email me, or add the bug
76 Chris Prather C<< <perigrin@cpan.org> >>
78 =head1 COPYRIGHT AND LICENSE
80 Copyright 2007-2008 by Infinity Interactive, Inc.
82 L<http://www.iinteractive.com>
84 This library is free software; you can redistribute it and/or modify
85 it under the same terms as Perl itself.