1B::Lint(3pm) Perl Programmers Reference Guide B::Lint(3pm)
2
3
4
6 B::Lint - Perl lint
7
9 perl -MO=Lint[,OPTIONS] foo.pl
10
12 The B::Lint module is equivalent to an extended version of the -w
13 option of perl. It is named after the program lint which carries out a
14 similar process for C programs.
15
17 Option words are separated by commas (not whitespace) and follow the
18 usual conventions of compiler backend options. Following any options
19 (indicated by a leading -) come lint check arguments. Each such
20 argument (apart from the special all and none options) is a word
21 representing one possible lint check (turning on that check) or is no-
22 foo (turning off that check). Before processing the check arguments, a
23 standard list of checks is turned on. Later options override earlier
24 ones. Available options are:
25
26 magic-diamond
27 Produces a warning whenever the magic "<>" readline is used.
28 Internally it uses perl's two-argument open which itself treats
29 filenames with special characters specially. This could allow
30 interestingly named files to have unexpected effects when
31 reading.
32
33 % touch 'rm *|'
34 % perl -pe 1
35
36 The above creates a file named "rm *|". When perl opens it with
37 "<>" it actually executes the shell program "rm *". This makes
38 "<>" dangerous to use carelessly.
39
40 context Produces a warning whenever an array is used in an implicit
41 scalar context. For example, both of the lines
42
43 $foo = length(@bar);
44 $foo = @bar;
45
46 will elicit a warning. Using an explicit scalar() silences the
47 warning. For example,
48
49 $foo = scalar(@bar);
50
51 implicit-read and implicit-write
52 These options produce a warning whenever an operation
53 implicitly reads or (respectively) writes to one of Perl's
54 special variables. For example, implicit-read will warn about
55 these:
56
57 /foo/;
58
59 and implicit-write will warn about these:
60
61 s/foo/bar/;
62
63 Both implicit-read and implicit-write warn about this:
64
65 for (@a) { ... }
66
67 bare-subs
68 This option warns whenever a bareword is implicitly quoted, but
69 is also the name of a subroutine in the current package.
70 Typical mistakes that it will trap are:
71
72 use constant foo => 'bar';
73 @a = ( foo => 1 );
74 $b{foo} = 2;
75
76 Neither of these will do what a naive user would expect.
77
78 dollar-underscore
79 This option warns whenever $_ is used either explicitly
80 anywhere or as the implicit argument of a print statement.
81
82 private-names
83 This option warns on each use of any variable, subroutine or
84 method name that lives in a non-current package but begins with
85 an underscore ("_"). Warnings aren't issued for the special
86 case of the single character name "_" by itself (e.g. $_ and
87 @_).
88
89 undefined-subs
90 This option warns whenever an undefined subroutine is invoked.
91 This option will only catch explicitly invoked subroutines such
92 as "foo()" and not indirect invocations such as "&$subref()" or
93 "$obj->meth()". Note that some programs or modules delay
94 definition of subs until runtime by means of the AUTOLOAD
95 mechanism.
96
97 regexp-variables
98 This option warns whenever one of the regexp variables "$`", $&
99 or "$'" is used. Any occurrence of any of these variables in
100 your program can slow your whole program down. See perlre for
101 details.
102
103 all Turn all warnings on.
104
105 none Turn all warnings off.
106
108 -u Package
109 Normally, Lint only checks the main code of the program
110 together with all subs defined in package main. The -u option
111 lets you include other package names whose subs are then
112 checked by Lint.
113
115 Lint can be extended by with plugins. Lint uses Module::Pluggable to
116 find available plugins. Plugins are expected but not required to inform
117 Lint of which checks they are adding.
118
119 The "B::Lint->register_plugin( MyPlugin => \@new_checks )" method adds
120 the list of @new_checks to the list of valid checks. If your module
121 wasn't loaded by Module::Pluggable then your class name is added to the
122 list of plugins.
123
124 You must create a "match( \%checks )" method in your plugin class or
125 one of its parents. It will be called on every op as a regular method
126 call with a hash ref of checks as its parameter.
127
128 The class methods "B::Lint->file" and "B::Lint->line" contain the
129 current filename and line number.
130
131 package Sample;
132 use B::Lint;
133 B::Lint->register_plugin( Sample => [ 'good_taste' ] );
134
135 sub match {
136 my ( $op, $checks_href ) = shift @_;
137 if ( $checks_href->{good_taste} ) {
138 ...
139 }
140 }
141
143 while(<FH>) stomps $_
144 strict oo
145 unchecked system calls
146 more tests, validate against older perls
147
149 This is only a very preliminary version.
150
152 Malcolm Beattie, mbeattie@sable.ox.ac.uk.
153
155 Sebastien Aperghis-Tramoni - bug fixes
156
157
158
159perl v5.10.1 2009-02-12 B::Lint(3pm)