NAME

Aspect::Advice::AfterReturning - Execute code when a function returns without throwing an exception.

SYNOPSIS

use Aspect;

after_returning {
    # Trace all normally returning calls to your module
    print STDERR "Called my function " . $_->sub_name . "\n";

    # Throw an exception if foo() returns 'bar'
    if ( $_->short_name eq 'foo' and $_->return_value eq 'bar' ) {
        $_->exception("Missing or invalid arguments to foo()");
    }

} call qr/^ MyModule::\w+ $/

DESCRIPTION

The after_returning advice type is used to execute code after a function has returned, but WITHOUT trapping exceptions (they will propogate upwards normally).

As well as creating side effects that run after the main code, the after_returning advice type is particularly useful for selectively altering the return value of a function or API-shifting functions which signal errors by returning undef so they throw exceptions instead.

AUTHORS

Adam Kennedy <adamk@cpan.org>

COPYRIGHT AND LICENSE

Copyright 2010 Adam Kennedy.

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