NAME

Data::Object::Role::Proxyable

ABSTRACT

Data-Object Proxyable Role

SYNOPSIS

use Data::Object::Class;

with 'Data::Object::Role::Proxyable';

sub BUILDPROXY {
  my ($class, $method, @args) = @_;

  return if $method eq 'execute'; # die with method missing error

  return sub { time }; # process method call
}

DESCRIPTION

This role provides a wrapper around the AUTOLOAD routine which processes calls to routines which don't exist.

LIBRARIES

This package uses type constraints defined by:

Data::Object::Library

METHODS

This package implements the following methods.

autoload

AUTOLOAD(Str $arg1, Str $arg2, Object $self, Any @args) : Any

The AUTOLOAD method is called when the object doesn't have the method being called. This method is called and handled automatically.

AUTOLOAD example
AUTOLOAD($class, $method, $self, @args);

destroy

DESTROY() : Any

The DESTROY method is called when the object goes out of scope. This method is called and handled automatically.

DESTROY example
$self->DESTROY();

CREDITS

Al Newkirk, +319

Anthony Brummett, +10

Adam Hopkins, +2

José Joaquín Atria, +1

AUTHOR

Al Newkirk, awncorp@cpan.org

LICENSE

Copyright (C) 2011-2019, Al Newkirk, et al.

This is free software; you can redistribute it and/or modify it under the terms of the The Apache License, Version 2.0, as elucidated here, https://github.com/iamalnewkirk/do/blob/master/LICENSE.

PROJECT

Wiki

Project

Initiatives

Milestones

Contributing

Issues

SEE ALSO

To get the most out of this distribution, consider reading the following:

Do

Data::Object

Data::Object::Class

Data::Object::ClassHas

Data::Object::Role

Data::Object::RoleHas

Data::Object::Library