NAME
    methods - Provide method syntax and autoclean namespaces

SYNOPSIS
        use methods;

        # with signature
        method foo($bar, %opts) {
           $self->bar(reverse $bar) if $opts{rev};
        }

        # attributes
        method foo : lvalue { $self->{foo} }

        # change invocant name
        method foo ($class: $bar) { $class->bar($bar) }

        # "1;" no longer required here

    With invoker support:

        use methods-invoker;
        method foo() {
           $->bar(); # Write "$self->method" as "$->method"
        }

DESCRIPTION
    This module uses Method::Signatures::Simple to provide named and
    anonymous methods with parameters, except with a shorter module name.

    It also imports namespace::autoclean so the "method" helper function (as
    well as any imported helper functions) won't become methods in the
    importing module.

    Finally, it also imports true so there's no need to put "1;" in the end
    of the importing module anymore.

OPTIONS
    If the first argument on the "use" line is "-invoker", then it also
    imports invoker automatically so one can write "$self->method" as
    "$->method".

    Other arguments are passed verbatim into Method::Signatures::Simple's
    "import" function.

SEE ALSO
    invoker, signatures

AUTHORS
    唐鳳 <cpan@audreyt.org>

CC0 1.0 Universal
    To the extent possible under law, 唐鳳 has waived all copyright and
    related or neighboring rights to methods.

    This work is published from Taiwan.

    <http://creativecommons.org/publicdomain/zero/1.0>