An open API service indexing awesome lists of open source software.

https://github.com/sysread/filter-cleanup

A flat, stackable error handler for Perl.
https://github.com/sysread/filter-cleanup

Last synced: 8 months ago
JSON representation

A flat, stackable error handler for Perl.

Awesome Lists containing this project

README

          

=pod

=encoding UTF-8

=head1 NAME

Filter::Cleanup - Execute cleanup statements when scope closes, regardless of errors

=head1 VERSION

version 0.03

=head1 SYNOPSIS

use Filter::Cleanup;

open my $fh, $file_path or die $!;
cleanup { close $fh };
do_risky_stuff_with_fh($fh);

=head1 DESCRIPTION

Defines a block of code to be evaluated once the current scope has completed
execution. If an error is thrown during the execution of statements after the
C block, the error is trapped and rethrown after the C block
is executed.

=head1 NAME

Filter::Cleanup

=head1 CAVEATS

=head2 ORDERING OF CLEANUP BLOCKS

A cleanup block will execute ahead of any cleanups defined before it. That is,
for a given scope, cleanup blocks will be called in the opposite order in which
they were declared.

=head2 IMPLEMENTATION

This module was originally implemented as a source filter (hence the name), but
now uses L.

=head1 SEE ALSO

=head2 Guard

L is implemented in XS and attaches a code block to the actual stack
frame, ensuring it is executed regardless of how the scope was exited. In many
cases, this may be preferable to the behavior of C, which will
not be executed if the block calls C or C (note that C I
handled correctly).

=head1 AUTHOR

Jeff Ober L

=head1 LICENSE

Perl5

=head1 AUTHOR

Jeff Ober

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by Jeff Ober.

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

=cut