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