use 5.008; use strict; use warnings; package Error::Hierarchy::Mixin; BEGIN { $Error::Hierarchy::Mixin::VERSION = '1.103530'; } # ABSTRACT: Provides often-used exception-related methods use Error; # to get $Error::Depth BEGIN { *CORE::GLOBAL::die = sub (@) { # Error.pm die()s as well, but we don't want an endless recursion. CORE::die(@_) if (caller)[0] eq 'Error' || ref $_[0]; local $Error::Depth = $Error::Depth + 1; # skip this level throw Error::Hierarchy::Internal::CustomMessage( custom_message => join(' ', @_),); }; } # Any class that wants to throw an exception can simply use or inherit from # this module and call 'throw Error::Whatever' without having to 'require' it # first. By putting the throw() method in UNIVERSAL:: we catch method calls on # exception classes that haven't been loaded yet. We load the class, then # throw the exception. sub UNIVERSAL::throw { # use Data::Dumper; print Dumper \@_; exit if ++(our $cnt) > 5; my ($exception_class, %args) = @_; # need to modify $Error::Depth (see Error.pm) to make certain parts # of the call stack invisible to caller() # +1 to make UNIVERSAL::throw() invisible # in case it wasn't loaded; to make sure $Error::Depth isn't undef require Error; local $Error::Depth = $Error::Depth + 1; eval "require $exception_class"; CORE::die($@) if $@; $exception_class->throw(%args); } # Similar reasoning for record(). sub UNIVERSAL::record { my ($exception_class, %args) = @_; # need to modify $Error::Depth (see Error.pm) to make certain parts # of the call stack invisible to caller() # +1 to make UNIVERSAL::record() invisible # in case it wasn't loaded; to make sure $Error::Depth isn't undef require Error; local $Error::Depth = $Error::Depth + 1; eval "require $exception_class"; CORE::die $@ if $@; $exception_class->record(%args); } 1; __END__ =pod =head1 NAME Error::Hierarchy::Mixin - Provides often-used exception-related methods =head1 VERSION version 1.103530 =head1 SYNOPSIS package MyClass; use Error::Hierarchy::Mixin; Some::Exception->throw(foo => 'bar'); =head1 DESCRIPTION This mixin provides several methods that you will often use when dealing with exceptions. It also overrides C so C will produce an L. If you have to use the original C, use C instead. =head1 METHODS =head2 throw Takes an exception class name (a string) and a hash of arguments. Loads the exception class, constructs an exception object, passes it the arguments and throws it by calling the exception object's C method. It populates the UNIVERSAL namespace, so all packages get this ability. =head2 record Like C, but records the exception using the exception object's C method. =head1 INSTALLATION See perlmodinstall for information and options on installing Perl modules. =head1 BUGS AND LIMITATIONS No bugs have been reported. Please report any bugs or feature requests through the web interface at L. =head1 AVAILABILITY The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit L to find a CPAN site near you, or see L. The development version lives at L and may be cloned from L. Instead of sending patches, please fork this project using the standard git and github infrastructure. =head1 AUTHOR Marcel Gruenauer =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2004 by Marcel Gruenauer. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut