NAME

Perl::Critic::Policy::TestingAndDebugging::RequireUseWarnings

DESCRIPTION

Using warnings is probably the single most effective way to improve the quality of your code. This policy requires that the 'use warnings' statement must come before any other statements except package, require, and other use statements. Thus, all the code in the entire package will be affected.

NOTES

Up through version 0.15, this Policy only reported a violation for the first offending statement. Starting in version 0.16, this Policy was modified to report a violation for every offending statement. This change closes a loophole with the "## no critic" pseudo-pragmas. But for old legacy code that doesn't use warnings, it produces a lot of violations. The best way to alleviate the problem is to organize your code like this.

## no critic 'RequireUseWarnings';

## Legacy code goes here...

## use critic;
use warnings;

## New code goes here...

In this manner, you can develop new code with warnings enabled, but still allow the warnings to be disabled for all your legacy code. Perl::Critic will only report violations of this policy that occur on lines after the "## use critic" pseudo-pragma.

SEE ALSO

Perl::Critic::Policy::TestingAndDebugging::RequirePackageStricture

AUTHOR

Jeffrey Ryan Thalhammer <thaljef@cpan.org>

COPYRIGHT

Copyright (c) 2005-2006 Jeffrey Ryan Thalhammer. 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