Pangloss::Category::Error - errors specific to Categories.


Pangloss documentation Contained in the Pangloss distribution.

Index


Code Index:

NAME

Top

Pangloss::Category::Error - errors specific to Categories.

SYNOPSIS

Top

  use Pangloss::Category::Error;
  use Pangloss::StoredObject::Error;

  throw Pangloss::Category::Error(flag => eExists, category => $category);
  throw Pangloss::Category::Error(flag => eNonExistent, name => $name);
  throw Pangloss::Category::Error(flag => eInvalid, category => $category,
                               invalid => {eNameRequired => 1});

  # with caught errors:
  print $e->category->name;

DESCRIPTION

Top

Category Errors class. Inherits interface from Pangloss::StoredObject::Error. May contain a category object associated with the error.

METHODS

Top

$e->category

set/get Pangloss::Category for this error.

AUTHOR

Top

Steve Purkis <spurkis@quiup.com>

SEE ALSO

Top

Error, Pangloss::StoredObject::Error, Pangloss::Category, Pangloss::Categories


Pangloss documentation Contained in the Pangloss distribution.
package Pangloss::Category::Error;

use strict;
use warnings::register;

use Pangloss::Category;

use base      qw( Pangloss::StoredObject::Error );
use accessors qw( category );

our $VERSION  = ((require Pangloss::Version), $Pangloss::VERSION)[1];
our $REVISION = (split(/ /, ' $Revision: 1.9 $ '))[2];

sub new {
    my $class = shift;
    my %args  = @_;
    local $Error::Depth = $Error::Depth + 1;
    if (my $name = delete $args{name}) {
	$args{category} = new Pangloss::Category()->name($name);
    }
    $class->SUPER::new(map { /^category$/ ? '-category' : $_; } %args);
}

sub stringify {
    my $self = shift;
    my $str  = $self->SUPER::stringify . ': category';
    $str    .= '=' . $self->category->key if $self->category;
    return $str;
}

1;

__END__

#------------------------------------------------------------------------------