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

Attribute::Overload::Match - argument-dependent handlers for overloaded operators

DESCRIPTION

The module is a wrapper for overload, that provides a simple syntax for calling different operator handlers for different passed arguments. The idea is a curious ( but probably not a very practical ) mix of Attribute::Overload and Sub::PatMat .

SYNOPSIS

   use Attribute::Overload::Match;

Suppose we declare a class that overloads operations on integers:

   sub new($)               { my $x = $_[0]; bless \$x, __PACKAGE__ }
   sub val($)               { ${$_[0]} }
   sub eq       : op(==)    { val(shift) == shift }
   sub subtract : op(-)     { new val(shift) - shift }
   sub mul      : op(*)     { new val(shift) * shift }
   sub add      : op(+)     { new val(shift) + shift }
   sub qq       : op("")    { val(shift) }
   sub le       : op(<)     { val(shift) < shift }
   ...

then we can change meaning of some operators with a touch of functional style:

   no warnings 'redefine';
   sub fac      : op(!,1)   { new 1 }
   sub fac      : op(!)     { !($_[0] - 1) * $_[0] }

or

   sub fib      : op(~,<2)  { new 1 }
   sub fib      : op(~)     { ~( $_[0] - 1) + ~($_[0] - 2) }

(if you don't like no warnings 'redefine', just use different sub names for fac etc) thus

   my $x = !new(10);
   print "$x\n";
   3628800    

and

   my $x = ~new(10);
   print "$x\n";
   89

SYNTAX

The only syntax available here is syntax that is passed to op attributes, which is in general sub mysub : op(OPERATOR,CODE[,CODE[,CODE ...]]), where OPERATOR belongs to strings defined in overload ( such as +, [], "" etc), and CODE strings are perl code, matching a parameter. However, for the sake of readability, CODE can be also one of the following signatures:

Empty string

Parameter is never checked

String starting with a digit

Pataremeter must be defined and be equal (==) to the value if the string

Single-quoted string

Parameter must be defined and be equal (eq) to the value if the string

Non-quoted string beginning with a capital letter

The string defined as a class name. Parameter must be defined and be an instance of the class (or its descendant).

//

Parameter must be defined.

One of <,>,lt,gt,eq,==,ne,!= followed by an expression

Parameter must be defined and return true when compared with the expression using given comparison operator

Anything else

Anything else is passed directly to eval and is treated in a boolean context thereafter.

ACKNOWLEDGEMENTS

Thanks to Anton Berezin for ideas on Sub::PatMat . Thanks to H. Merijn Brandt for //.

SEE ALSO

Attribute::Overload, Sub::PatMat, overload.

COPYRIGHT

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

AUTHOR

Dmitry Karasik <dmitry@karasik.eu.org>