Beginning of dzilization
[gitmo/Moose.git] / lib / Moose / Error / Default.pm
CommitLineData
bf6fa6b3 1package Moose::Error::Default;
2
c0e91e5f 3use strict;
4use warnings;
5
ae18d5ec 6our $AUTHORITY = 'cpan:STEVAN';
7
41daa828 8use Carp::Heavy;
68567b15 9use Class::MOP::MiniTrait;
41daa828 10
4f5ca7c5 11use base 'Class::MOP::Object';
12
68567b15 13Class::MOP::MiniTrait::apply(__PACKAGE__, 'Moose::Meta::Object::Trait');
41daa828 14
bf6fa6b3 15sub new {
16 my ( $self, @args ) = @_;
692a93f6 17 if (defined $ENV{MOOSE_ERROR_STYLE} && $ENV{MOOSE_ERROR_STYLE} eq 'croak') {
aeef093c 18 $self->create_error_croak( @args );
19 }
20 else {
21 $self->create_error_confess( @args );
22 }
bf6fa6b3 23}
24
25sub create_error_croak {
26 my ( $self, @args ) = @_;
41daa828 27 $self->_create_error_carpmess( @args );
bf6fa6b3 28}
29
30sub create_error_confess {
31 my ( $self, @args ) = @_;
32 $self->_create_error_carpmess( @args, longmess => 1 );
33}
34
35sub _create_error_carpmess {
36 my ( $self, %args ) = @_;
37
38 my $carp_level = 3 + ( $args{depth} || 1 );
41daa828 39 local $Carp::MaxArgNums = 20; # default is 8, usually we use named args which gets messier though
bf6fa6b3 40
41 my @args = exists $args{message} ? $args{message} : ();
42
43 if ( $args{longmess} || $Carp::Verbose ) {
44 local $Carp::CarpLevel = ( $Carp::CarpLevel || 0 ) + $carp_level;
45 return Carp::longmess(@args);
41daa828 46 } else {
47 return Carp::ret_summary($carp_level, @args);
bf6fa6b3 48 }
49}
50
51__PACKAGE__
52
ad46f524 53# ABSTRACT: L<Carp> based error generation for Moose.
54
bf6fa6b3 55__END__
56
57=pod
58
bf6fa6b3 59=head1 DESCRIPTION
60
61This class implements L<Carp> based error generation.
62
1b27b2a6 63The default behavior is like L<Moose::Error::Confess>. To override this to
64default to L<Moose::Error::Croak>'s behaviour on a system wide basis, set the
65MOOSE_ERROR_STYLE environment variable to C<croak>. The use of this
66environment variable is considered experimental, and may change in a future
67release.
bf6fa6b3 68
69=head1 METHODS
70
71=over 4
72
ad3882b5 73=item B<< Moose::Error::Default->new(@args) >>
bf6fa6b3 74
cef1e197 75Create a new error. Delegates to C<create_error_confess> or
76C<create_error_croak>.
bf6fa6b3 77
ad3882b5 78=item B<< $error->create_error_confess(@args) >>
bf6fa6b3 79
ad3882b5 80=item B<< $error->create_error_croak(@args) >>
bf6fa6b3 81
82Creates a new errors string of the specified style.
83
84=back
85
86=cut
87
88