Scroll to navigation

MooX::Aliases(3pm) User Contributed Perl Documentation MooX::Aliases(3pm)

NAME

MooX::Aliases - easy aliasing of methods and attributes in Moo

SYNOPSIS

  package MyClass;
  use Moo;
  use MooX::Aliases;
  has this => (
      is    => 'rw',
      alias => 'that',
  );
  sub foo { my $self = shift; print $self->that }
  alias bar => 'foo';
  my $o = MyApp->new();
  $o->this('Hello World');
  $o->bar; # prints 'Hello World'

or

  package MyRole;
  use Moo::Role;
  use MooX::Aliases;
  has this => (
      is    => 'rw',
      alias => 'that',
  );
  sub foo { my $self = shift; print $self->that }
  alias bar => 'foo';

DESCRIPTION

The MooX::Aliases module will allow you to quickly alias methods in Moo. It provides an alias parameter for has() to generate aliased accessors as well as the standard ones. Attributes can also be initialized in the constructor via their aliased names.

You can create more than one alias at once by passing a listref:

  has ip_addr => (
    alias => [ qw(ipAddr ip) ],
  );

FUNCTIONS

Creates $alias as a method that is aliased to $method.

CAVEATS

This module uses the "BUILDARGS" to map the attributes. If a class uses a custom "BUILDARGS", this module may not behave properly.

SEE ALSO

AUTHOR

haarg - Graham Knop (cpan:HAARG) <haarg@haarg.org>

CONTRIBUTORS

  • Chris Prather <chris@prather.org>
  • Jesse Luehrs <doy@tozt.net>
  • Justin Hunter <justin.d.hunter@gmail.com>
  • Karen Etheridge <ether@cpan.org>
  • Yuval Kogman <nothingmuch@woobling.org>
  • Daniel Gempesaw <gempesaw@gmail.com>
  • Denis Ibaev <dionys@gmail.com>

COPYRIGHT

Copyright (c) 2013 the MooX::Alises "AUTHOR" and "CONTRIBUTORS" as listed above.

LICENSE

This library is free software and may be distributed under the same terms as perl itself.

2022-04-09 perl v5.34.0