NAME

Perl::Critic::Policy::ControlStructures::ProhibitUnreachableCode

DESCRIPTION

This policy prohibits code following a statement which unconditionally alters the program flow. This includes calls to exit, die, return, next, last and goto. Due to common usage, croak and confess from Carp are also included.

Code is reachable if any of the following conditions are true:

* Flow-altering statement has a conditional attached to it
* Statement is on the right side of an operator C<&&>, C<||>, C<and>, or C<or>.
* Code is prefixed with a label (can potentially be reached via C<goto>)
* Code is a subroutine
*

EXAMPLES

# not ok

exit;
print "123\n";

# ok

exit if !$xyz;
print "123\n";

# not ok

for ( 1 .. 10 ) {
    next;
    print 1;
}

# ok

for ( 1 .. 10 ) {
    next if $_ == 5;
    print 1;
}

# not ok

sub foo {
    my $bar = shift;
    return;
    print 1;
}

# ok

sub foo {
    my $bar = shift;
    return if $bar->baz();
    print 1;
}


# not ok

die;
print "123\n";

# ok

die;
LABEL: print "123\n";

# not ok

croak;
do_something();

# ok

croak;
sub do_something {}

SEE ALSO

Perl::Critic::Policy::ControlStructures::ProhibitPostfixControls

AUTHOR

Peter Guzis <pguzis@cpan.org>

COPYRIGHT

Copyright (c) 2006 Peter Guzis. All rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The full text of this license can be found in the LICENSE file included with this module.