/usr/share/perl5/RG/Exception.pm is in librg-exception-perl 1.0.3-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 | package RG::Exception;
##############################################################################
#
# Copyright: 2008 László Kaján
#
# License: This program is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself, either Perl version 5.8.8 or,
# at your option, any later version of Perl 5 you may have available.
#
##############################################################################
# RG exception base class
# Typical use:
# die RG::Exception->new( { msg => 'error message' } );
##############################################################################
use strict;
use Carp;
$Carp::CarpInternal{ 'RG::Exception' }++;
sub new
{
my $this = shift;
my $class = ref($this) || $this;
my $self = {};
bless $self, $class;
$self->_initialize( @_ );
return $self;
}
sub _initialize # protected method
{
my( $self, %__p ) = @_;
# { msg => str }
if( !$__p{msg} ) { $__p{msg} = ''; }
# set properties
while( my( $key, $val ) = each( %__p ) ) { $self->$key( $val ); }
}
# Overloaded string conversion operator. Returns "Uncaught exception 'REFERENCE':".msg(). Normally you would catch the exception and emit the message msg() of it.
use overload '""' => sub{ return 'Uncaught exception \''.ref($_[0])."\':\n".$_[0]->msg_stack_backtrace(); };
sub msg # error message
{
if( @_ > 1 )
{
$_[0]->msg_stack_backtrace( Carp::longmess( $_[1] ) );
return $_[0]->{_msg} = Carp::shortmess( $_[1] );
}
else
{
return $_[0]->{_msg};
}
}
# Error message appended with the output of Carp::longmess(), a stack backtrace. See: L<Carp>.
sub msg_stack_backtrace # error message
{ return ( @_ > 1 ? $_[0]->{_msg_stack_backtrace} = $_[1] : $_[0]->{_msg_stack_backtrace} ); }
package RG::Exception::NotImplemented;
use strict;
use Carp;
$Carp::CarpInternal{ 'RG::Exception::NotImplemented' }++;
use base qw( RG::Exception ); # inheritance
##############################################################################
# Typical use:
# die RG::Exception::NotImplemented->new();
##############################################################################
sub _initialize # protected method
{
my( $self ) = @_;
$self->SUPER::_initialize( msg => 'not implemented' );
}
package RG::Exception::SyntaxError;
use strict;
use Carp;
$Carp::CarpInternal{ 'RG::Exception::SyntaxError' }++;
use base qw( RG::Exception ); # inheritance
##############################################################################
# Typical use:
# die RG::Exception::Parser::SyntaxError->new( { msg => 'syntax error on line $lineno' } );
##############################################################################
1;
# vim:et:ts=2:ai:
|