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