NAME
Perl::Critic::Policy::CodeLayout::ProhibitQuotedWordLists
DESCRIPTION
Conway doesn't mention this, but I think qw()
is an underutilized feature of Perl. Whenever you need to declare a list of one-word literals, the qw()
operator is wonderfully concise and saves you lots of keystrokes. And uusing qw()
makes it easy to add to the list in the future.
@list = ('foo', 'bar', 'baz'); #not ok
@list = qw(foo bar baz); #ok
CONSTRUCTOR
This Policy accepts an additional key-value pair in the constructor. The key must be 'min_elements' and the value is the minimum number of elements in the list. Lists with fewer elements will be overlooked by this Policy. The default is 2. Users of Perl::Critic can configure this in their .perlcriticrc file like this:
[CodeLayout::ProhibitQuotedWordLists]
min_elements = 4
NOTES
In the PPI parlance, a "list" is almost anything with parens. I've tried to make this Policy smart by targeting only "lists" that could be sensibly expressed with qw()
. However, there may be some edge cases that I haven't covered. If you find one, send me a note.
IMPORTANT CHANGES
This policy was formerly called "RequireQuotedWords" which seemed a little counterintuitive. If you get lots of "Cannot load policy module" errors, then you probably need to change "RequireQuotedWords" to "ProhibitQuotedWordLists" in your .perlcriticrc file.
AUTHOR
Jeffrey Ryan Thalhammer <thaljef@cpan.org>
Copyright (c) 2005 Jeffrey Ryan Thalhammer. All rights reserved.
COPYRIGHT
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.