NAME "overload::substr" - overload Perl's "substr()" function SYNOPSIS package My::Stringlike::Object; use overload::substr; sub _substr { my $self = shift; if( @_ > 2 ) { $self->replace_substr( @_ ); } else { return $self->get_substr( @_ ); } } ... DESCRIPTION This module allows an object class to overload the "substr" core function, which Perl's "overload" pragma does not allow by itself. It is invoked similarly to the "overload" pragma, being passed a single named argument which should be a code reference or method name to implement the "substr" function. use overload::substr substr => \&SUBSTR; use overload::substr substr => "SUBSTR"; The referred method will be invoked as per core's "substr"; namely, it will take the string to be operated on (which will be an object in this case), an offset, optionally a length, and optionally a replacement. $str->SUBSTR( $offset ); $str->SUBSTR( $offset, $length ); $str->SUBSTR( $offset, $length, $replacement ); In each case, whatever it returns will be the return value of the "substr" function that invoked it. If the "substr" argument is not provided, it defaults to a method called "_substr". It is not required that the return value be a plain string; any Perl value may be returned unmodified from the "substr" method, or passed in as the value of the replacement. This allows objects to behave in whatever way is deemed most appropriate. TODO * More testing - edge cases, especially in LVALUE logic. * Test for memory leaks, especially in LVALUE logic. * Look into / implement fixup of substr() ops compiled before module is loaded * Consider if implementations of split(), and "m//" and "s///" regexps should be done that also uses the overloaded substr() method. ACKNOWLEDGEMENTS With thanks to Matt S Trout <mst@shadowcat.co.uk> for suggesting the possibility, and Joshua ben Jore <jjore@cpan.org> for the inspiration by way of UNIVERSAL::ref. AUTHOR Paul Evans <leonerd@leonerd.org.uk>