The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Try::Lite - easy exception catcher with auto rethrow

SYNOPSIS

  use Try::Lite;
  try {
      YourExceptionClass->throw;
  } (
      'YourExceptionClass' => sub {
          say ref($@); # show 'YourExceptionClass'
      }
  );

You can catch base exception class:

  package YourExceptionClass {
      use parent 'BaseExceptionClass';
  }
  
  try {
      YourExceptionClass->throw;
  } (
      'BaseExceptionClass' => sub {
          say ref($@); # show 'YourExceptionClass'
      }
  );

You can catch any exception:

  try {
      die "oops\n";
  } (
      '*' => sub {
          say $@; # show "oops\n";
      }
  );

If there is no matched catch clause, Try::Lite rethrow the exception automatically:

  eval {
      try {
          die "oops\n";
      } (
          'YourExceptionClass' => sub {}
      );
  };
  say $@; # show "oops\n"

You can receives the try block return value and catechs subs return value:

  my $ret = try {
      'foo'
  } ( '*' => sub {} );
  say $ret; # show 'foo'
  
  my $ret = try {
      die 'foo'
  } ( '*' => sub { 'bar' } );
  say $ret; # show 'bar'

You can catch any exceptions:

  sub run (&) {
    my $code = shift;
  
    try { $code->() } (
      'FileException'    => sub { say 'file exception' },
      'NetworkException' => sub { say 'network exception' }
    );
  }
  
  run { FileException->throw };    # show 'file exception'
  run { NetworkException->throw }; # show 'network exception'
  run { die 'oops' };              # Died

DESCRIPTION

Try::Lite is easy exception catch with Exception classes. Exception other than the all specified conditions are It run rethrow.

THIS IS A DEVELOPMENT RELEASE. API MAY CHANGE WITHOUT NOTICE.

EXPORT

try $code_ref, %catche_rules

AUTHOR

Kazuhiro Osawa <yappo {@} shibuya {dot} pl>

SEE ALSO

try function base is Try::Tiny

LICENSE

Copyright (C) Kazuhiro Osawa

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