NAME

KinoSearch::Obj::Err - Exception.

SYNOPSIS

use Scalar::Util qw( blessed );
my $bg_merger;
while (1) {
    $bg_merger = eval {
        KinoSearch::Index::BackgroundMerger->new( index => $index );
    };
    last if $bg_merger;
    if ( blessed($@) and $@->isa("KinoSearch::Store::LockErr") ) {
        warn "Retrying...\n";
    }
    else {
        # Re-throw.
        die "Failed to open BackgroundMerger: $@";
    }
}

DESCRIPTION

Exception.

Most of the time when KinoSearch encounters an error, it tries to raise a KinoSearch::Obj::Err exception with an error message and context information.

At present, it is only safe to catch exceptions which are specifically documented as catchable; most times when an Err is raised, KinoSearch leaks memory.

INHERITANCE

KinoSearch::Obj::Err isa KinoSearch::Obj.

COPYRIGHT AND LICENSE

Copyright 2005-2009 Marvin Humphrey

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.