package Specio::Exception; use strict; use warnings; use overload q{""} => 'as_string', fallback => 1; our $VERSION = '0.42'; use Devel::StackTrace; use Scalar::Util qw( blessed ); use Specio::OO; { my $attrs = { message => { isa => 'Str', required => 1, }, type => { does => 'Specio::Constraint::Role::Interface', required => 1, }, value => { required => 1, }, stack_trace => { init_arg => undef, }, }; ## no critic (Subroutines::ProhibitUnusedPrivateSubroutines) sub _attrs { return $attrs; } } sub BUILD { my $self = shift; $self->{stack_trace} = Devel::StackTrace->new( ignore_package => __PACKAGE__ ); return; } sub as_string { my $self = shift; my $str = $self->message; $str .= "\n\n" . $self->stack_trace->as_string; return $str; } sub throw { my $self = shift; die $self if blessed $self; die $self->new(@_); } __PACKAGE__->_ooify; 1; # ABSTRACT: An exception class for type constraint failures __END__ =pod =encoding UTF-8 =head1 NAME Specio::Exception - An exception class for type constraint failures =head1 VERSION version 0.42 =head1 SYNOPSIS use Try::Tiny; try { $type->validate_or_die($value); } catch { if ( $_->isa('Specio::Exception') ) { print $_->message, "\n"; print $_->type->name, "\n"; print $_->value, "\n"; } }; =head1 DESCRIPTION This exception class is thrown by Specio when a type check fails. It emulates the L API, but doesn't use that module to avoid adding a dependency on L. =for Pod::Coverage BUILD throw =head1 API This class provides the following methods: =head2 $exception->message The error message associated with the exception. =head2 $exception->stack_trace A L object for the exception. =head2 $exception->type The type constraint object against which the value failed. =head2 $exception->value The value that failed the type check. =head2 $exception->as_string The exception as a string. This includes the method and the stack trace. =head1 OVERLOADING This class overloads stringification to call the C method. =head1 SUPPORT Bugs may be submitted at L. I am also usually active on IRC as 'autarch' on C. =head1 SOURCE The source code repository for Specio can be found at L. =head1 AUTHOR Dave Rolsky =head1 COPYRIGHT AND LICENSE This software is Copyright (c) 2012 - 2017 by Dave Rolsky. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) The full text of the license can be found in the F file included with this distribution. =cut