Provided by: libclass-tiny-antlers-perl_0.024-2_all bug

NAME

       Class::Tiny::Antlers - Moose-like sugar for Class::Tiny

SYNOPSIS

          {
             package Point;
             use Class::Tiny::Antlers;
             has x => (is => 'ro');
             has y => (is => 'ro');
          }

          {
             package Point3D;
             use Class::Tiny::Antlers;
             extends 'Point';
             has z => (is => 'ro');
          }

DESCRIPTION

       Class::Tiny::Antlers provides Moose-like "has", "extends", "with", "before", "after" and
       "around" keywords for Class::Tiny.  (The "with" keyword requires Role::Tiny; method
       modifiers require Class::Method::Modifiers.)

       Class::Tiny doesn't support all Moose's attribute options; "has" should throw you an error
       if you try to do something it doesn't support (like triggers).

       Class::Tiny::Antlers does however hack in support for "is => 'ro'" and Moo-style "is =>
       'rwp'", clearers and predicates.

       From version 0.24, Class::Tiny::Antlers also adds support for `isa` and `coerce` using
       Type::Tiny. (I mean, this is a TOBYINK module, so what do you expect?!) Technically
       MooseX::Types, MouseX::Types, Specio, and Type::Nano should work, but these are less
       tested.

   Export
       By default, Class::Tiny::Antlers exports "has", "with" and "extends", and also imports
       strict into its caller. You can optionally also import "confess" and warnings:

          use Class::Tiny::Antlers qw( -default confess warnings );

       And Class::Method::Modifiers keywords:

          use Class::Tiny::Antlers qw( -default before after around );
          use Class::Tiny::Antlers qw( -default -cmm );  # same thing

       If you just want everything:

          use Class::Tiny::Antlers qw( -all );

       Class::Tiny::Antlers also ensures that Class::Tiny's import method is called for your
       class.

       You can put a "no Class::Tiny::Antlers" statement at the end of your class definition to
       wipe the imported functions out of your namespace. (This does not unimport strict/warnings
       though.) To clean up your namespace more thoroughly, use something like namespace::sweep.

   Functions
       "has $attr, %spec"
           Create an attribute. The specification hash roughly supports "is", "default",
           "clearer" and "predicate" as per Moose and Moo.

       "extends @classes"
           Set the base class(es) for your class.

       "with @roles"
           Compose Role::Tiny roles with your class.

       "before $name, \&code"
           Install a "before" modifier using Class::Method::Modifiers.

       "after $name, \&code"
           Install a "after" modifier using Class::Method::Modifiers.

       "around $name, \&code"
           Install a "around" modifier using Class::Method::Modifiers.

       "confess $format, @list"
           "sprintf"-fueled version of Carp's "confess".

   Methods
       Class::Tiny::Antlers inherits the "get_all_attributes_for" and
       "get_all_attribute_defaults_for" methods from Class::Tiny, and also provides:

       "Class::Tiny::Antlers->get_all_attribute_specs_for($class)"
           Gets Moose-style attribute specification hashes for all the class' attributes as a big
           hashref. (Includes inherited attributes.)

BUGS

       Please report any bugs to <http://rt.cpan.org/Dist/Display.html?Queue=Class-Tiny-Antlers>.

SEE ALSO

       Class::Tiny, Role::Tiny, Class::Method::Modifiers, Type::Tiny::Manual.

       Moose, Mouse, Moo.

AUTHOR

       Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE

       This software is copyright (c) 2013, 2019 by Toby Inkster.

       This is free software; you can redistribute it and/or modify it under the same terms as
       the Perl 5 programming language system itself.

DISCLAIMER OF WARRANTIES

       THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
       WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
       PURPOSE.