Additionally to the answers you already got on SO you should use my for all variables including $i .
have a look at use diagnostics to improve error messages (and read them ;-)
use strict;
use warnings;
use diagnostics;
for $i (0..10) {
print $i;
}
read the part about lexically scoped variables:
Global symbol "$i" requires explicit package name at /tmp/tst2.pl line
+ 6.
Global symbol "$i" requires explicit package name at /tmp/tst2.pl line
+ 7.
Execution of /tmp/tst2.pl aborted due to compilation errors (#1)
(F) You've said "use strict" or "use strict vars", which indicates
+
that all variables must either be lexically scoped (using "my" or
+"state"),
declared beforehand using "our", or explicitly qualified to say
which package the global variable is in (using "::").
Uncaught exception from user code:
Global symbol "$i" requires explicit package name at /tmp/tst2.pl
+line 6.
Global symbol "$i" requires explicit package name at /tmp/tst2.pl line
+ 7.
Execution of /tmp/tst2.pl aborted due to compilation errors.
at /tmp/tst2.pl line 10
if you don't know what lexically scoped is, have a look at Coping with Scoping
Cheers Rolf
(addicted to the Perl Programming Language and ☆☆☆☆ :)
PS: crossposting provokes downvotes! :)
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link or
or How to display code and escape characters
are good places to start.
|