NAME

Mite::Manual::Features - other features provided by Mite

MANUAL

Class Methods

Your class can or will provide the following methods:

new( %attributes ) or new( \%attributes )

Constructor for your class. It takes some arguments and returns an object.

Mite generates this for you.

Mite automatically provides a similar feature to MooseX::StrictConstructor, so your constructor will die if you pass it unknown attributes.

BUILDARGS

Works as in Moose and allows your constructor to be called with something other than a hash of attributes. Mite does not generate this for you.

FOREIGNBUILDARGS

Works as in Moo and MooseX::NonMoose. Mite does not generate this for you.

BUILD / BUILDALL.

Works as in Moose. Mite generates BUILDALL for you.

From Mite 0.007004 onwards, your BUILD method gets called before the strict constructor check, which allows you to remove keys from $args if you don't want them to trigger an exception.

DEMOLISH / DESTROY

Works as in Moose. Mite generates DESTROY for you.

On Perl older than 5.14, the $in_global_destruction argument will be undefined unless Devel::GlobalDestruction is installed, so add that to your project's dependencies if you are relying on it and need to support older versions of Perl.

DOES / does

DOES allows you to check if your class/object performs a particular role. See UNIVERSAL.

does is just an alias.

If you want to fake support for a role:

$Your::Project::SomeClass::DOES{'Your::Project::SomeRole'} = 1;

strict

Mite will turn strict on for you.

warnings

Mite will turn warnings on for you.

Clean Classes

Mite will automatically import namespace::autoclean into your classes if it is installed on the end user's system. If it's not available, your classes will quietly be left with imported keywords cluttering up their namespace.

To force namespace::autoclean, then just use it manually:

use Your::Project::Mite;
use namespace::autoclean;

To force it to not be used:

use Your::Project::Mite qw( -unclean );

BUGS

Please report any bugs to https://github.com/tobyink/p5-mite/issues.

AUTHOR

Michael G Schwern <mschwern@cpan.org>.

Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE

This software is copyright (c) 2011-2014 by Michael G Schwern.

This software is copyright (c) 2022 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.