The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

invoker - implicit invoker, sort of

SYNOPSIS

use invoker;

sub foo {
  my $self = shift;
  $->bar; # calls $self->bar;
}

use methods-invoker;
method {
  $->bar # ditto
}

DESCRIPTION

The invoker pragma enables the $-> syntax for invoking methods on $self , inspired by Perl6's $.method invocation.

The module does not inject the $self variable for you. you are encouraged to use it in conjunction with self, selfvars, <Method::Signatures::Simple>, or other similar modules.

The following syntax works:

$->foo( .. args ...)
$->foo
$->$method_name
$->$method_name( .. args ...)

CAVEATS

Regular hash access must still be written as $self->{attr} instead of $->{attr}.

Internally, the module installs a parser hook to replace $-> ($- and the gt operator) with $--> (an invocation on the $- perlvar. It also injects an entersub hook to replace $- with $self.

BUGS

TODO

custom invoker name with "use invoker '$this'"

AUTHOR

Chia-liang Kao <clkao@clkao.org> Audrey Tang <audreyt@audreyt.org>

LICENSE

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

SEE ALSO

methods