NAME
Exception::Caught - Sugar for class-based exception handlers
VERSION
version 0.01
SYNOPSIS
use Try::Tiny;
use Exception::Caught;
use Exception::Class qw(MyException);
try {
MyException->throw();
}
catch {
rethrow unless caught('MyException');
# do something special with $_
};
WHY?
Doing different things with an exception based on its class is a common pattern. TryCatch does a good job with this, but is a bit heavyweight. Try::Tiny is nice and lightweight, but doesn't help out with the type dispatching problem. Hence, this module. You don't have to use it with Try::Tiny, but that's what it's best at.
EXPORTS
Exception::Caught uses Sub::Exporter, so see that module if you want to rename these subroutines to something else. The subs are only exported for your lexical scope so that you don't get extra methods/subs in your package/class. If this isn't what you want, consider using Sub::Import.
caught
and rethrow
are exported by default.
caught(classname, exception?)
Returns true if the exception (optional argument, defaults to $_) passes isa() for the given classname.
rethrow(exception?)
Calls rethrow on the exception (optional argument, defaults to $_) if it is an object with a rethrow method, otherwise just dies with the exception.
AUTHOR
Paul Driver <frodwith@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Paul Driver <frodwith@cpan.org>.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.