This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
e445d0806016541e3995f88efbee49719f0e8e07
[perl5.git] / pod / perldiag.pod
1 =head1 NAME
2
3 perldiag - various Perl diagnostics
4
5 =head1 DESCRIPTION
6
7 These messages are classified as follows (listed in increasing order of
8 desperation):
9
10     (W) A warning (optional).
11     (D) A deprecation (optional).
12     (S) A severe warning (default).
13     (F) A fatal error (trappable).
14     (P) An internal error you should never see (trappable).
15     (X) A very fatal error (nontrappable).
16     (A) An alien error message (not generated by Perl).
17
18 The majority of messages from the first three classifications above
19 (W, D & S) can be controlled using the C<warnings> pragma.
20
21 If a message can be controlled by the C<warnings> pragma, its warning
22 category is included with the classification letter in the description
23 below.
24
25 Optional warnings are enabled by using the C<warnings> pragma or the B<-w>
26 and B<-W> switches. Warnings may be captured by setting C<$SIG{__WARN__}>
27 to a reference to a routine that will be called on each warning instead
28 of printing it.  See L<perlvar>.
29
30 Default warnings are always enabled unless they are explicitly disabled
31 with the C<warnings> pragma or the B<-X> switch.
32
33 Trappable errors may be trapped using the eval operator.  See
34 L<perlfunc/eval>.  In almost all cases, warnings may be selectively
35 disabled or promoted to fatal errors using the C<warnings> pragma.
36 See L<warnings>.
37
38 The messages are in alphabetical order, without regard to upper or
39 lower-case.  Some of these messages are generic.  Spots that vary are
40 denoted with a %s or other printf-style escape.  These escapes are
41 ignored by the alphabetical order, as are all characters other than
42 letters.  To look up your message, just ignore anything that is not a
43 letter.
44
45 =over 4
46
47 =item accept() on closed socket %s
48
49 (W closed) You tried to do an accept on a closed socket.  Did you forget
50 to check the return value of your socket() call?  See
51 L<perlfunc/accept>.
52
53 =item Allocation too large: %lx
54
55 (X) You can't allocate more than 64K on an MS-DOS machine.
56
57 =item '!' allowed only after types %s
58
59 (F) The '!' is allowed in pack() or unpack() only after certain types.
60 See L<perlfunc/pack>.
61
62 =item Ambiguous call resolved as CORE::%s(), qualify as such or use &
63
64 (W ambiguous) A subroutine you have declared has the same name as a Perl
65 keyword, and you have used the name without qualification for calling
66 one or the other.  Perl decided to call the builtin because the
67 subroutine is not imported.
68
69 To force interpretation as a subroutine call, either put an ampersand
70 before the subroutine name, or qualify the name with its package.
71 Alternatively, you can import the subroutine (or pretend that it's
72 imported with the C<use subs> pragma).
73
74 To silently interpret it as the Perl operator, use the C<CORE::> prefix
75 on the operator (e.g. C<CORE::log($x)>) or declare the subroutine
76 to be an object method (see L<perlsub/"Subroutine Attributes"> or
77 L<attributes>).
78
79 =item Ambiguous range in transliteration operator
80
81 (F) You wrote something like C<tr/a-z-0//> which doesn't mean anything at
82 all.  To include a C<-> character in a transliteration, put it either
83 first or last.  (In the past, C<tr/a-z-0//> was synonymous with
84 C<tr/a-y//>, which was probably not what you would have expected.)
85
86 =item Ambiguous use of %s resolved as %s
87
88 (W ambiguous)(S) You said something that may not be interpreted the way
89 you thought.  Normally it's pretty easy to disambiguate it by supplying
90 a missing quote, operator, parenthesis pair or declaration.
91
92 =item '|' and '<' may not both be specified on command line
93
94 (F) An error peculiar to VMS.  Perl does its own command line
95 redirection, and found that STDIN was a pipe, and that you also tried to
96 redirect STDIN using '<'.  Only one STDIN stream to a customer, please.
97
98 =item '|' and '>' may not both be specified on command line
99
100 (F) An error peculiar to VMS.  Perl does its own command line
101 redirection, and thinks you tried to redirect stdout both to a file and
102 into a pipe to another command.  You need to choose one or the other,
103 though nothing's stopping you from piping into a program or Perl script
104 which 'splits' output into two streams, such as
105
106     open(OUT,">$ARGV[0]") or die "Can't write to $ARGV[0]: $!";
107     while (<STDIN>) {
108         print;
109         print OUT;
110     }
111     close OUT;
112
113 =item Applying %s to %s will act on scalar(%s)
114
115 (W misc) The pattern match (C<//>), substitution (C<s///>), and
116 transliteration (C<tr///>) operators work on scalar values.  If you apply
117 one of them to an array or a hash, it will convert the array or hash to
118 a scalar value -- the length of an array, or the population info of a
119 hash -- and then work on that scalar value.  This is probably not what
120 you meant to do.  See L<perlfunc/grep> and L<perlfunc/map> for
121 alternatives.
122
123 =item Args must match #! line
124
125 (F) The setuid emulator requires that the arguments Perl was invoked
126 with match the arguments specified on the #! line.  Since some systems
127 impose a one-argument limit on the #! line, try combining switches;
128 for example, turn C<-w -U> into C<-wU>.
129
130 =item Arg too short for msgsnd
131
132 (F) msgsnd() requires a string at least as long as sizeof(long).
133
134 =item %s argument is not a HASH or ARRAY element
135
136 (F) The argument to exists() must be a hash or array element, such as:
137
138     $foo{$bar}
139     $ref->{"susie"}[12]
140
141 =item %s argument is not a HASH or ARRAY element or slice
142
143 (F) The argument to delete() must be either a hash or array element,
144 such as:
145
146     $foo{$bar}
147     $ref->{"susie"}[12]
148
149 or a hash or array slice, such as:
150
151     @foo[$bar, $baz, $xyzzy]
152     @{$ref->[12]}{"susie", "queue"}
153
154 =item %s argument is not a subroutine name
155
156 (F) The argument to exists() for C<exists &sub> must be a subroutine
157 name, and not a subroutine call.  C<exists &sub()> will generate this
158 error.
159
160 =item Argument "%s" isn't numeric%s
161
162 (W numeric) The indicated string was fed as an argument to an operator
163 that expected a numeric value instead.  If you're fortunate the message
164 will identify which operator was so unfortunate.
165
166 =item Argument list not closed for PerlIO layer "%s"
167
168 (W layer) When pushing a layer with arguments onto the Perl I/O system you
169 forgot the ) that closes the argument list.  (Layers take care of transforming
170 data between external and internal representations.)  Perl stopped parsing
171 the layer list at this point and did not attempt to push this layer.
172 If your program didn't explicitly request the failing operation, it may be
173 the result of the value of the environment variable PERLIO.
174
175 =item Array @%s missing the @ in argument %d of %s()
176
177 (D deprecated) Really old Perl let you omit the @ on array names in some
178 spots.  This is now heavily deprecated.
179
180 =item assertion botched: %s
181
182 (P) The malloc package that comes with Perl had an internal failure.
183
184 =item Assertion failed: file "%s"
185
186 (P) A general assertion failed.  The file in question must be examined.
187
188 =item Assignment to both a list and a scalar
189
190 (F) If you assign to a conditional operator, the 2nd and 3rd arguments
191 must either both be scalars or both be lists.  Otherwise Perl won't
192 know which context to supply to the right side.
193
194 =item A thread exited while %d threads were running
195
196 (W) When using threaded Perl, a thread (not necessarily the main
197 thread) exited while there were still other threads running.
198 Usually it's a good idea to first collect the return values of the
199 created threads by joining them, and only then exit from the main
200 thread.  See L<threads>.
201
202 =item Attempt to access disallowed key '%s' in a restricted hash
203
204 (F) The failing code has attempted to get or set a key which is not in
205 the current set of allowed keys of a restricted hash.
206
207 =item Attempt to bless into a reference
208
209 (F) The CLASSNAME argument to the bless() operator is expected to be
210 the name of the package to bless the resulting object into. You've
211 supplied instead a reference to something: perhaps you wrote
212
213     bless $self, $proto;
214
215 when you intended
216
217     bless $self, ref($proto) || $proto;
218
219 If you actually want to bless into the stringified version
220 of the reference supplied, you need to stringify it yourself, for
221 example by:
222
223     bless $self, "$proto";
224
225 =item Attempt to delete disallowed key '%s' from a restricted hash
226
227 (F) The failing code attempted to delete from a restricted hash a key
228 which is not in its key set.
229
230 =item Attempt to delete readonly key '%s' from a restricted hash
231
232 (F) The failing code attempted to delete a key whose value has been
233 declared readonly from a restricted hash.
234
235 =item Attempt to free non-arena SV: 0x%lx
236
237 (P internal) All SV objects are supposed to be allocated from arenas
238 that will be garbage collected on exit.  An SV was discovered to be
239 outside any of those arenas.
240
241 =item Attempt to free nonexistent shared string
242
243 (P internal) Perl maintains a reference counted internal table of
244 strings to optimize the storage and access of hash keys and other
245 strings.  This indicates someone tried to decrement the reference count
246 of a string that can no longer be found in the table.
247
248 =item Attempt to free temp prematurely
249
250 (W debugging) Mortalized values are supposed to be freed by the
251 free_tmps() routine.  This indicates that something else is freeing the
252 SV before the free_tmps() routine gets a chance, which means that the
253 free_tmps() routine will be freeing an unreferenced scalar when it does
254 try to free it.
255
256 =item Attempt to free unreferenced glob pointers
257
258 (P internal) The reference counts got screwed up on symbol aliases.
259
260 =item Attempt to free unreferenced scalar
261
262 (W internal) Perl went to decrement the reference count of a scalar to
263 see if it would go to 0, and discovered that it had already gone to 0
264 earlier, and should have been freed, and in fact, probably was freed.
265 This could indicate that SvREFCNT_dec() was called too many times, or
266 that SvREFCNT_inc() was called too few times, or that the SV was
267 mortalized when it shouldn't have been, or that memory has been
268 corrupted.
269
270 =item Attempt to join self
271
272 (F) You tried to join a thread from within itself, which is an
273 impossible task.  You may be joining the wrong thread, or you may need
274 to move the join() to some other thread.
275
276 =item Attempt to pack pointer to temporary value
277
278 (W pack) You tried to pass a temporary value (like the result of a
279 function, or a computed expression) to the "p" pack() template.  This
280 means the result contains a pointer to a location that could become
281 invalid anytime, even before the end of the current statement.  Use
282 literals or global values as arguments to the "p" pack() template to
283 avoid this warning.
284
285 =item Attempt to use reference as lvalue in substr
286
287 (W substr) You supplied a reference as the first argument to substr()
288 used as an lvalue, which is pretty strange.  Perhaps you forgot to
289 dereference it first.  See L<perlfunc/substr>.
290
291 =item Bad arg length for %s, is %d, should be %s
292
293 (F) You passed a buffer of the wrong size to one of msgctl(), semctl()
294 or shmctl().  In C parlance, the correct sizes are, respectively,
295 S<sizeof(struct msqid_ds *)>, S<sizeof(struct semid_ds *)>, and
296 S<sizeof(struct shmid_ds *)>.
297
298 =item Bad evalled substitution pattern
299
300 (F) You've used the C</e> switch to evaluate the replacement for a
301 substitution, but perl found a syntax error in the code to evaluate,
302 most likely an unexpected right brace '}'.
303
304 =item Bad filehandle: %s
305
306 (F) A symbol was passed to something wanting a filehandle, but the
307 symbol has no filehandle associated with it.  Perhaps you didn't do an
308 open(), or did it in another package.
309
310 =item Bad free() ignored
311
312 (S malloc) An internal routine called free() on something that had never
313 been malloc()ed in the first place. Mandatory, but can be disabled by
314 setting environment variable C<PERL_BADFREE> to 0.
315
316 This message can be seen quite often with DB_File on systems with "hard"
317 dynamic linking, like C<AIX> and C<OS/2>. It is a bug of C<Berkeley DB>
318 which is left unnoticed if C<DB> uses I<forgiving> system malloc().
319
320 =item Bad hash
321
322 (P) One of the internal hash routines was passed a null HV pointer.
323
324 =item Badly placed ()'s
325
326 (A) You've accidentally run your script through B<csh> instead
327 of Perl.  Check the #! line, or manually feed your script into
328 Perl yourself.
329
330 =item Bad name after %s::
331
332 (F) You started to name a symbol by using a package prefix, and then
333 didn't finish the symbol.  In particular, you can't interpolate outside
334 of quotes, so
335
336     $var = 'myvar';
337     $sym = mypack::$var;
338
339 is not the same as
340
341     $var = 'myvar';
342     $sym = "mypack::$var";
343
344 =item Bad realloc() ignored
345
346 (S malloc) An internal routine called realloc() on something that had
347 never been malloc()ed in the first place. Mandatory, but can be disabled
348 by setting environment variable C<PERL_BADFREE> to 1.
349
350 =item Bad symbol for array
351
352 (P) An internal request asked to add an array entry to something that
353 wasn't a symbol table entry.
354
355 =item Bad symbol for filehandle
356
357 (P) An internal request asked to add a filehandle entry to something
358 that wasn't a symbol table entry.
359
360 =item Bad symbol for hash
361
362 (P) An internal request asked to add a hash entry to something that
363 wasn't a symbol table entry.
364
365 =item Bareword found in conditional
366
367 (W bareword) The compiler found a bareword where it expected a
368 conditional, which often indicates that an || or && was parsed as part
369 of the last argument of the previous construct, for example:
370
371     open FOO || die;
372
373 It may also indicate a misspelled constant that has been interpreted as
374 a bareword:
375
376     use constant TYPO => 1;
377     if (TYOP) { print "foo" }
378
379 The C<strict> pragma is useful in avoiding such errors.
380
381 =item Bareword "%s" not allowed while "strict subs" in use
382
383 (F) With "strict subs" in use, a bareword is only allowed as a
384 subroutine identifier, in curly brackets or to the left of the "=>"
385 symbol.  Perhaps you need to predeclare a subroutine?
386
387 =item Bareword "%s" refers to nonexistent package
388
389 (W bareword) You used a qualified bareword of the form C<Foo::>, but the
390 compiler saw no other uses of that namespace before that point.  Perhaps
391 you need to predeclare a package?
392
393 =item BEGIN failed--compilation aborted
394
395 (F) An untrapped exception was raised while executing a BEGIN
396 subroutine.  Compilation stops immediately and the interpreter is
397 exited.
398
399 =item BEGIN not safe after errors--compilation aborted
400
401 (F) Perl found a C<BEGIN {}> subroutine (or a C<use> directive, which
402 implies a C<BEGIN {}>) after one or more compilation errors had already
403 occurred.  Since the intended environment for the C<BEGIN {}> could not
404 be guaranteed (due to the errors), and since subsequent code likely
405 depends on its correct operation, Perl just gave up.
406
407 =item \1 better written as $1
408
409 (W syntax) Outside of patterns, backreferences live on as variables.
410 The use of backslashes is grandfathered on the right-hand side of a
411 substitution, but stylistically it's better to use the variable form
412 because other Perl programmers will expect it, and it works better if
413 there are more than 9 backreferences.
414
415 =item Binary number > 0b11111111111111111111111111111111 non-portable
416
417 (W portable) The binary number you specified is larger than 2**32-1
418 (4294967295) and therefore non-portable between systems.  See
419 L<perlport> for more on portability concerns.
420
421 =item bind() on closed socket %s
422
423 (W closed) You tried to do a bind on a closed socket.  Did you forget to
424 check the return value of your socket() call?  See L<perlfunc/bind>.
425
426 =item binmode() on closed filehandle %s
427
428 (W unopened) You tried binmode() on a filehandle that was never opened.
429 Check you control flow and number of arguments.
430
431 =item Bit vector size > 32 non-portable
432
433 (W portable) Using bit vector sizes larger than 32 is non-portable.
434
435 =item Bizarre copy of %s in %s
436
437 (P) Perl detected an attempt to copy an internal value that is not
438 copyable.
439
440 =item Buffer overflow in prime_env_iter: %s
441
442 (W internal) A warning peculiar to VMS.  While Perl was preparing to
443 iterate over %ENV, it encountered a logical name or symbol definition
444 which was too long, so it was truncated to the string shown.
445
446 =item Callback called exit
447
448 (F) A subroutine invoked from an external package via call_sv()
449 exited by calling exit.
450
451 =item %s() called too early to check prototype
452
453 (W prototype) You've called a function that has a prototype before the
454 parser saw a definition or declaration for it, and Perl could not check
455 that the call conforms to the prototype.  You need to either add an
456 early prototype declaration for the subroutine in question, or move the
457 subroutine definition ahead of the call to get proper prototype
458 checking.  Alternatively, if you are certain that you're calling the
459 function correctly, you may put an ampersand before the name to avoid
460 the warning.  See L<perlsub>.
461
462 =item Cannot compress integer in pack
463
464 (F) An argument to pack("w",...) was too large to compress.  The BER
465 compressed integer format can only be used with positive integers, and you
466 attempted to compress Infinity or a very large number (> 1e308).
467 See L<perlfunc/pack>.
468
469 =item Cannot compress negative numbers in pack
470
471 (F) An argument to pack("w",...) was negative.  The BER compressed integer
472 format can only be used with positive integers.  See L<perlfunc/pack>.
473
474 =item Can only compress unsigned integers in pack
475
476 (F) An argument to pack("w",...) was not an integer.  The BER compressed
477 integer format can only be used with positive integers, and you attempted
478 to compress something else.  See L<perlfunc/pack>.
479
480 =item Can't bless non-reference value
481
482 (F) Only hard references may be blessed.  This is how Perl "enforces"
483 encapsulation of objects.  See L<perlobj>.
484
485 =item Can't call method "%s" in empty package "%s"
486
487 (F) You called a method correctly, and it correctly indicated a package
488 functioning as a class, but that package doesn't have ANYTHING defined
489 in it, let alone methods.  See L<perlobj>.
490
491 =item Can't call method "%s" on an undefined value
492
493 (F) You used the syntax of a method call, but the slot filled by the
494 object reference or package name contains an undefined value.  Something
495 like this will reproduce the error:
496
497     $BADREF = undef;
498     process $BADREF 1,2,3;
499     $BADREF->process(1,2,3);
500
501 =item Can't call method "%s" on unblessed reference
502
503 (F) A method call must know in what package it's supposed to run.  It
504 ordinarily finds this out from the object reference you supply, but you
505 didn't supply an object reference in this case.  A reference isn't an
506 object reference until it has been blessed.  See L<perlobj>.
507
508 =item Can't call method "%s" without a package or object reference
509
510 (F) You used the syntax of a method call, but the slot filled by the
511 object reference or package name contains an expression that returns a
512 defined value which is neither an object reference nor a package name.
513 Something like this will reproduce the error:
514
515     $BADREF = 42;
516     process $BADREF 1,2,3;
517     $BADREF->process(1,2,3);
518
519 =item Can't chdir to %s
520
521 (F) You called C<perl -x/foo/bar>, but C</foo/bar> is not a directory
522 that you can chdir to, possibly because it doesn't exist.
523
524 =item Can't check filesystem of script "%s" for nosuid
525
526 (P) For some reason you can't check the filesystem of the script for
527 nosuid.
528
529 =item Can't coerce array into hash
530
531 (F) You used an array where a hash was expected, but the array has no
532 information on how to map from keys to array indices.  You can do that
533 only with arrays that have a hash reference at index 0.
534
535 =item Can't coerce %s to integer in %s
536
537 (F) Certain types of SVs, in particular real symbol table entries
538 (typeglobs), can't be forced to stop being what they are.  So you can't
539 say things like:
540
541     *foo += 1;
542
543 You CAN say
544
545     $foo = *foo;
546     $foo += 1;
547
548 but then $foo no longer contains a glob.
549
550 =item Can't coerce %s to number in %s
551
552 (F) Certain types of SVs, in particular real symbol table entries
553 (typeglobs), can't be forced to stop being what they are.
554
555 =item Can't coerce %s to string in %s
556
557 (F) Certain types of SVs, in particular real symbol table entries
558 (typeglobs), can't be forced to stop being what they are.
559
560 =item Can't create pipe mailbox
561
562 (P) An error peculiar to VMS.  The process is suffering from exhausted
563 quotas or other plumbing problems.
564
565 =item Can't declare class for non-scalar %s in "%s"
566
567 (F) Currently, only scalar variables can be declared with a specific
568 class qualifier in a "my" or "our" declaration.  The semantics may be
569 extended for other types of variables in future.
570
571 =item Can't declare %s in "%s"
572
573 (F) Only scalar, array, and hash variables may be declared as "my" or
574 "our" variables.  They must have ordinary identifiers as names.
575
576 =item Can't do inplace edit: %s is not a regular file
577
578 (S inplace) You tried to use the B<-i> switch on a special file, such as
579 a file in /dev, or a FIFO.  The file was ignored.
580
581 =item Can't do inplace edit on %s: %s
582
583 (S inplace) The creation of the new file failed for the indicated
584 reason.
585
586 =item Can't do inplace edit without backup
587
588 (F) You're on a system such as MS-DOS that gets confused if you try
589 reading from a deleted (but still opened) file.  You have to say
590 C<-i.bak>, or some such.
591
592 =item Can't do inplace edit: %s would not be unique
593
594 (S inplace) Your filesystem does not support filenames longer than 14
595 characters and Perl was unable to create a unique filename during
596 inplace editing with the B<-i> switch.  The file was ignored.
597
598 =item Can't do {n,m} with n > m in regex; marked by <-- HERE in m/%s/
599
600 (F) Minima must be less than or equal to maxima. If you really want your
601 regexp to match something 0 times, just put {0}. The <-- HERE shows in the
602 regular expression about where the problem was discovered. See L<perlre>.
603
604 =item Can't do setegid!
605
606 (P) The setegid() call failed for some reason in the setuid emulator of
607 suidperl.
608
609 =item Can't do seteuid!
610
611 (P) The setuid emulator of suidperl failed for some reason.
612
613 =item Can't do setuid
614
615 (F) This typically means that ordinary perl tried to exec suidperl to do
616 setuid emulation, but couldn't exec it.  It looks for a name of the form
617 sperl5.000 in the same directory that the perl executable resides under
618 the name perl5.000, typically /usr/local/bin on Unix machines.  If the
619 file is there, check the execute permissions.  If it isn't, ask your
620 sysadmin why he and/or she removed it.
621
622 =item Can't do waitpid with flags
623
624 (F) This machine doesn't have either waitpid() or wait4(), so only
625 waitpid() without flags is emulated.
626
627 =item Can't emulate -%s on #! line
628
629 (F) The #! line specifies a switch that doesn't make sense at this
630 point.  For example, it'd be kind of silly to put a B<-x> on the #!
631 line.
632
633 =item Can't exec "%s": %s
634
635 (W exec) A system(), exec(), or piped open call could not execute the
636 named program for the indicated reason.  Typical reasons include: the
637 permissions were wrong on the file, the file wasn't found in
638 C<$ENV{PATH}>, the executable in question was compiled for another
639 architecture, or the #! line in a script points to an interpreter that
640 can't be run for similar reasons.  (Or maybe your system doesn't support
641 #! at all.)
642
643 =item Can't exec %s
644
645 (F) Perl was trying to execute the indicated program for you because
646 that's what the #! line said.  If that's not what you wanted, you may
647 need to mention "perl" on the #! line somewhere.
648
649 =item Can't execute %s
650
651 (F) You used the B<-S> switch, but the copies of the script to execute
652 found in the PATH did not have correct permissions.
653
654 =item Can't find an opnumber for "%s"
655
656 (F) A string of a form C<CORE::word> was given to prototype(), but there
657 is no builtin with the name C<word>.
658
659 =item Can't find %s character property "%s"
660
661 (F) You used C<\p{}> or C<\P{}> but the character property by that name
662 could not be found. Maybe you misspelled the name of the property
663 (remember that the names of character properties consist only of
664 alphanumeric characters), or maybe you forgot the C<Is> or C<In> prefix?
665
666 =item Can't find label %s
667
668 (F) You said to goto a label that isn't mentioned anywhere that it's
669 possible for us to go to.  See L<perlfunc/goto>.
670
671 =item Can't find %s on PATH
672
673 (F) You used the B<-S> switch, but the script to execute could not be
674 found in the PATH.
675
676 =item Can't find %s on PATH, '.' not in PATH
677
678 (F) You used the B<-S> switch, but the script to execute could not be
679 found in the PATH, or at least not with the correct permissions.  The
680 script exists in the current directory, but PATH prohibits running it.
681
682 =item Can't find %s property definition %s
683
684 (F) You may have tried to use C<\p> which means a Unicode property (for
685 example C<\p{Lu}> is all uppercase letters).  If you did mean to use a
686 Unicode property, see L<perlunicode> for the list of known properties.
687 If you didn't mean to use a Unicode property, escape the C<\p>, either
688 by C<\\p> (just the C<\p>) or by C<\Q\p> (the rest of the string, until
689 possible C<\E>).
690
691 =item Can't find string terminator %s anywhere before EOF
692
693 (F) Perl strings can stretch over multiple lines.  This message means
694 that the closing delimiter was omitted.  Because bracketed quotes count
695 nesting levels, the following is missing its final parenthesis:
696
697     print q(The character '(' starts a side comment.);
698
699 If you're getting this error from a here-document, you may have included
700 unseen whitespace before or after your closing tag. A good programmer's
701 editor will have a way to help you find these characters.
702
703 =item Can't fork
704
705 (F) A fatal error occurred while trying to fork while opening a
706 pipeline.
707
708 =item Can't get filespec - stale stat buffer?
709
710 (S) A warning peculiar to VMS.  This arises because of the difference
711 between access checks under VMS and under the Unix model Perl assumes.
712 Under VMS, access checks are done by filename, rather than by bits in
713 the stat buffer, so that ACLs and other protections can be taken into
714 account.  Unfortunately, Perl assumes that the stat buffer contains all
715 the necessary information, and passes it, instead of the filespec, to
716 the access checking routine.  It will try to retrieve the filespec using
717 the device name and FID present in the stat buffer, but this works only
718 if you haven't made a subsequent call to the CRTL stat() routine,
719 because the device name is overwritten with each call.  If this warning
720 appears, the name lookup failed, and the access checking routine gave up
721 and returned FALSE, just to be conservative.  (Note: The access checking
722 routine knows about the Perl C<stat> operator and file tests, so you
723 shouldn't ever see this warning in response to a Perl command; it arises
724 only if some internal code takes stat buffers lightly.)
725
726 =item Can't get pipe mailbox device name
727
728 (P) An error peculiar to VMS.  After creating a mailbox to act as a
729 pipe, Perl can't retrieve its name for later use.
730
731 =item Can't get SYSGEN parameter value for MAXBUF
732
733 (P) An error peculiar to VMS.  Perl asked $GETSYI how big you want your
734 mailbox buffers to be, and didn't get an answer.
735
736 =item Can't "goto" into the middle of a foreach loop
737
738 (F) A "goto" statement was executed to jump into the middle of a foreach
739 loop.  You can't get there from here.  See L<perlfunc/goto>.
740
741 =item Can't "goto" out of a pseudo block
742
743 (F) A "goto" statement was executed to jump out of what might look like
744 a block, except that it isn't a proper block.  This usually occurs if
745 you tried to jump out of a sort() block or subroutine, which is a no-no.
746 See L<perlfunc/goto>.
747
748 =item Can't goto subroutine from an eval-string
749
750 (F) The "goto subroutine" call can't be used to jump out of an eval
751 "string".  (You can use it to jump out of an eval {BLOCK}, but you
752 probably don't want to.)
753
754 =item Can't goto subroutine outside a subroutine
755
756 (F) The deeply magical "goto subroutine" call can only replace one
757 subroutine call for another.  It can't manufacture one out of whole
758 cloth.  In general you should be calling it out of only an AUTOLOAD
759 routine anyway.  See L<perlfunc/goto>.
760
761 =item Can't ignore signal CHLD, forcing to default
762
763 (W signal) Perl has detected that it is being run with the SIGCHLD
764 signal (sometimes known as SIGCLD) disabled.  Since disabling this
765 signal will interfere with proper determination of exit status of child
766 processes, Perl has reset the signal to its default value.  This
767 situation typically indicates that the parent program under which Perl
768 may be running (e.g. cron) is being very careless.
769
770 =item Can't "last" outside a loop block
771
772 (F) A "last" statement was executed to break out of the current block,
773 except that there's this itty bitty problem called there isn't a current
774 block.  Note that an "if" or "else" block doesn't count as a "loopish"
775 block, as doesn't a block given to sort(), map() or grep().  You can
776 usually double the curlies to get the same effect though, because the
777 inner curlies will be considered a block that loops once.  See
778 L<perlfunc/last>.
779
780 =item Can't localize lexical variable %s
781
782 (F) You used local on a variable name that was previously declared as a
783 lexical variable using "my".  This is not allowed.  If you want to
784 localize a package variable of the same name, qualify it with the
785 package name.
786
787 =item Can't localize through a reference
788
789 (F) You said something like C<local $$ref>, which Perl can't currently
790 handle, because when it goes to restore the old value of whatever $ref
791 pointed to after the scope of the local() is finished, it can't be sure
792 that $ref will still be a reference.
793
794 =item Can't locate %s
795
796 (F) You said to C<do> (or C<require>, or C<use>) a file that couldn't be
797 found. Perl looks for the file in all the locations mentioned in @INC,
798 unless the file name included the full path to the file.  Perhaps you
799 need to set the PERL5LIB or PERL5OPT environment variable to say where
800 the extra library is, or maybe the script needs to add the library name
801 to @INC.  Or maybe you just misspelled the name of the file.  See
802 L<perlfunc/require> and L<lib>.
803
804 =item Can't locate auto/%s.al in @INC
805
806 (F) A function (or method) was called in a package which allows
807 autoload, but there is no function to autoload.  Most probable causes
808 are a misprint in a function/method name or a failure to C<AutoSplit>
809 the file, say, by doing C<make install>.
810
811 =item Can't locate object method "%s" via package "%s"
812
813 (F) You called a method correctly, and it correctly indicated a package
814 functioning as a class, but that package doesn't define that particular
815 method, nor does any of its base classes.  See L<perlobj>.
816
817 =item Can't locate package %s for @%s::ISA
818
819 (W syntax) The @ISA array contained the name of another package that
820 doesn't seem to exist.
821
822 =item Can't locate PerlIO%s
823
824 (F) You tried to use in open() a PerlIO layer that does not exist,
825 e.g. open(FH, ">:nosuchlayer", "somefile").
826
827 =item Can't make list assignment to \%ENV on this system
828
829 (F) List assignment to %ENV is not supported on some systems, notably
830 VMS.
831
832 =item Can't modify %s in %s
833
834 (F) You aren't allowed to assign to the item indicated, or otherwise try
835 to change it, such as with an auto-increment.
836
837 =item Can't modify nonexistent substring
838
839 (P) The internal routine that does assignment to a substr() was handed
840 a NULL.
841
842 =item Can't modify non-lvalue subroutine call
843
844 (F) Subroutines meant to be used in lvalue context should be declared as
845 such, see L<perlsub/"Lvalue subroutines">.
846
847 =item Can't msgrcv to read-only var
848
849 (F) The target of a msgrcv must be modifiable to be used as a receive
850 buffer.
851
852 =item Can't "next" outside a loop block
853
854 (F) A "next" statement was executed to reiterate the current block, but
855 there isn't a current block.  Note that an "if" or "else" block doesn't
856 count as a "loopish" block, as doesn't a block given to sort(), map() or
857 grep().  You can usually double the curlies to get the same effect
858 though, because the inner curlies will be considered a block that loops
859 once.  See L<perlfunc/next>.
860
861 =item Can't open %s: %s
862
863 (S inplace) The implicit opening of a file through use of the C<< <> >>
864 filehandle, either implicitly under the C<-n> or C<-p> command-line
865 switches, or explicitly, failed for the indicated reason.  Usually this
866 is because you don't have read permission for a file which you named on
867 the command line.
868
869 =item Can't open a reference
870
871 (W io) You tried to open a scalar reference for reading or writing,
872 using the 3-arg open() syntax :
873
874     open FH, '>', $ref;
875
876 but your version of perl is compiled without perlio, and this form of
877 open is not supported.
878
879 =item Can't open bidirectional pipe
880
881 (W pipe) You tried to say C<open(CMD, "|cmd|")>, which is not supported.
882 You can try any of several modules in the Perl library to do this, such
883 as IPC::Open2.  Alternately, direct the pipe's output to a file using
884 ">", and then read it in under a different file handle.
885
886 =item Can't open error file %s as stderr
887
888 (F) An error peculiar to VMS.  Perl does its own command line
889 redirection, and couldn't open the file specified after '2>' or '2>>' on
890 the command line for writing.
891
892 =item Can't open input file %s as stdin
893
894 (F) An error peculiar to VMS.  Perl does its own command line
895 redirection, and couldn't open the file specified after '<' on the
896 command line for reading.
897
898 =item Can't open output file %s as stdout
899
900 (F) An error peculiar to VMS.  Perl does its own command line
901 redirection, and couldn't open the file specified after '>' or '>>' on
902 the command line for writing.
903
904 =item Can't open output pipe (name: %s)
905
906 (P) An error peculiar to VMS.  Perl does its own command line
907 redirection, and couldn't open the pipe into which to send data destined
908 for stdout.
909
910 =item Can't open perl script%s
911
912 (F) The script you specified can't be opened for the indicated reason.
913
914 =item Can't provide tied hash usage; use keys(%hash) to test if empty
915
916 (F) When a hash is evaluated in scalar context, bucket usage is
917 returned if the hash is populated, and false is returned if the hash
918 is empty.  Bucket usage is not currently available for tied hashes.
919 To test if a hash is empty or populated, use keys(%hash) in scalar
920 context instead.
921
922 =item Can't read CRTL environ
923
924 (S) A warning peculiar to VMS.  Perl tried to read an element of %ENV
925 from the CRTL's internal environment array and discovered the array was
926 missing.  You need to figure out where your CRTL misplaced its environ
927 or define F<PERL_ENV_TABLES> (see L<perlvms>) so that environ is not
928 searched.
929
930 =item Can't redefine active sort subroutine %s
931
932 (F) Perl optimizes the internal handling of sort subroutines and keeps
933 pointers into them.  You tried to redefine one such sort subroutine when
934 it was currently active, which is not allowed.  If you really want to do
935 this, you should write C<sort { &func } @x> instead of C<sort func @x>.
936
937 =item Can't "redo" outside a loop block
938
939 (F) A "redo" statement was executed to restart the current block, but
940 there isn't a current block.  Note that an "if" or "else" block doesn't
941 count as a "loopish" block, as doesn't a block given to sort(), map()
942 or grep().  You can usually double the curlies to get the same effect
943 though, because the inner curlies will be considered a block that
944 loops once.  See L<perlfunc/redo>.
945
946 =item Can't remove %s: %s, skipping file
947
948 (S inplace) You requested an inplace edit without creating a backup
949 file.  Perl was unable to remove the original file to replace it with
950 the modified file.  The file was left unmodified.
951
952 =item Can't rename %s to %s: %s, skipping file
953
954 (S inplace) The rename done by the B<-i> switch failed for some reason,
955 probably because you don't have write permission to the directory.
956
957 =item Can't reopen input pipe (name: %s) in binary mode
958
959 (P) An error peculiar to VMS.  Perl thought stdin was a pipe, and tried
960 to reopen it to accept binary data.  Alas, it failed.
961
962 =item Can't resolve method `%s' overloading `%s' in package `%s'
963
964 (F|P) Error resolving overloading specified by a method name (as opposed
965 to a subroutine reference): no such method callable via the package. If
966 method name is C<???>, this is an internal error.
967
968 =item Can't reswap uid and euid
969
970 (P) The setreuid() call failed for some reason in the setuid emulator of
971 suidperl.
972
973 =item Can't return %s from lvalue subroutine
974
975 (F) Perl detected an attempt to return illegal lvalues (such as
976 temporary or readonly values) from a subroutine used as an lvalue.  This
977 is not allowed.
978
979 =item Can't return outside a subroutine
980
981 (F) The return statement was executed in mainline code, that is, where
982 there was no subroutine call to return out of.  See L<perlsub>.
983
984 =item Can't return %s to lvalue scalar context
985
986 (F) You tried to return a complete array or hash from an lvalue subroutine,
987 but you called the subroutine in a way that made Perl think you meant
988 to return only one value. You probably meant to write parentheses around
989 the call to the subroutine, which tell Perl that the call should be in
990 list context.
991
992 =item Can't stat script "%s"
993
994 (P) For some reason you can't fstat() the script even though you have it
995 open already.  Bizarre.
996
997 =item Can't swap uid and euid
998
999 (P) The setreuid() call failed for some reason in the setuid emulator of
1000 suidperl.
1001
1002 =item Can't take log of %g
1003
1004 (F) For ordinary real numbers, you can't take the logarithm of a
1005 negative number or zero. There's a Math::Complex package that comes
1006 standard with Perl, though, if you really want to do that for the
1007 negative numbers.
1008
1009 =item Can't take sqrt of %g
1010
1011 (F) For ordinary real numbers, you can't take the square root of a
1012 negative number.  There's a Math::Complex package that comes standard
1013 with Perl, though, if you really want to do that.
1014
1015 =item Can't undef active subroutine
1016
1017 (F) You can't undefine a routine that's currently running.  You can,
1018 however, redefine it while it's running, and you can even undef the
1019 redefined subroutine while the old routine is running.  Go figure.
1020
1021 =item Can't unshift
1022
1023 (F) You tried to unshift an "unreal" array that can't be unshifted, such
1024 as the main Perl stack.
1025
1026 =item Can't upgrade that kind of scalar
1027
1028 (P) The internal sv_upgrade routine adds "members" to an SV, making it
1029 into a more specialized kind of SV.  The top several SV types are so
1030 specialized, however, that they cannot be interconverted.  This message
1031 indicates that such a conversion was attempted.
1032
1033 =item Can't upgrade to undef
1034
1035 (P) The undefined SV is the bottom of the totem pole, in the scheme of
1036 upgradability.  Upgrading to undef indicates an error in the code
1037 calling sv_upgrade.
1038
1039 =item Can't use anonymous symbol table for method lookup
1040
1041 (F) The internal routine that does method lookup was handed a symbol
1042 table that doesn't have a name.  Symbol tables can become anonymous
1043 for example by undefining stashes: C<undef %Some::Package::>.
1044
1045 =item Can't use an undefined value as %s reference
1046
1047 (F) A value used as either a hard reference or a symbolic reference must
1048 be a defined value.  This helps to delurk some insidious errors.
1049
1050 =item Can't use bareword ("%s") as %s ref while "strict refs" in use
1051
1052 (F) Only hard references are allowed by "strict refs".  Symbolic
1053 references are disallowed.  See L<perlref>.
1054
1055 =item Can't use %! because Errno.pm is not available
1056
1057 (F) The first time the %! hash is used, perl automatically loads the
1058 Errno.pm module. The Errno module is expected to tie the %! hash to
1059 provide symbolic names for C<$!> errno values.
1060
1061 =item Can't use %s for loop variable
1062
1063 (F) Only a simple scalar variable may be used as a loop variable on a
1064 foreach.
1065
1066 =item Can't use global %s in "my"
1067
1068 (F) You tried to declare a magical variable as a lexical variable.  This
1069 is not allowed, because the magic can be tied to only one location
1070 (namely the global variable) and it would be incredibly confusing to
1071 have variables in your program that looked like magical variables but
1072 weren't.
1073
1074 =item Can't use "my %s" in sort comparison
1075
1076 (F) The global variables $a and $b are reserved for sort comparisons.
1077 You mentioned $a or $b in the same line as the <=> or cmp operator,
1078 and the variable had earlier been declared as a lexical variable.
1079 Either qualify the sort variable with the package name, or rename the
1080 lexical variable.
1081
1082 =item Can't use %s ref as %s ref
1083
1084 (F) You've mixed up your reference types.  You have to dereference a
1085 reference of the type needed.  You can use the ref() function to
1086 test the type of the reference, if need be.
1087
1088 =item Can't use string ("%s") as %s ref while "strict refs" in use
1089
1090 (F) Only hard references are allowed by "strict refs".  Symbolic
1091 references are disallowed.  See L<perlref>.
1092
1093 =item Can't use subscript on %s
1094
1095 (F) The compiler tried to interpret a bracketed expression as a
1096 subscript.  But to the left of the brackets was an expression that
1097 didn't look like an array reference, or anything else subscriptable.
1098
1099 =item Can't use \%c to mean $%c in expression
1100
1101 (W syntax) In an ordinary expression, backslash is a unary operator that
1102 creates a reference to its argument.  The use of backslash to indicate a
1103 backreference to a matched substring is valid only as part of a regular
1104 expression pattern.  Trying to do this in ordinary Perl code produces a
1105 value that prints out looking like SCALAR(0xdecaf).  Use the $1 form
1106 instead.
1107
1108 =item Can't weaken a nonreference
1109
1110 (F) You attempted to weaken something that was not a reference.  Only
1111 references can be weakened.
1112
1113 =item Can't x= to read-only value
1114
1115 (F) You tried to repeat a constant value (often the undefined value)
1116 with an assignment operator, which implies modifying the value itself.
1117 Perhaps you need to copy the value to a temporary, and repeat that.
1118
1119 =item Character in "C" format wrapped in pack
1120
1121 (W pack) You said
1122
1123     pack("C", $x)
1124
1125 where $x is either less than 0 or more than 255; the C<"C"> format is
1126 only for encoding native operating system characters (ASCII, EBCDIC,
1127 and so on) and not for Unicode characters, so Perl behaved as if you meant
1128
1129     pack("C", $x & 255)
1130
1131 If you actually want to pack Unicode codepoints, use the C<"U"> format
1132 instead.
1133
1134 =item Character in "c" format wrapped in pack
1135
1136 (W pack) You said
1137
1138     pack("c", $x)
1139
1140 where $x is either less than -128 or more than 127; the C<"c"> format
1141 is only for encoding native operating system characters (ASCII, EBCDIC,
1142 and so on) and not for Unicode characters, so Perl behaved as if you meant
1143
1144     pack("c", $x & 255);
1145
1146 If you actually want to pack Unicode codepoints, use the C<"U"> format
1147 instead.
1148
1149 =item close() on unopened filehandle %s
1150
1151 (W unopened) You tried to close a filehandle that was never opened.
1152
1153 =item Code missing after '/'
1154
1155 (F) You had a (sub-)template that ends with a '/'. There must be another
1156 template code following the slash. See L<perlfunc/pack>.
1157
1158 =item %s: Command not found
1159
1160 (A) You've accidentally run your script through B<csh> instead of Perl.
1161 Check the #! line, or manually feed your script into Perl yourself.
1162
1163 =item Compilation failed in require
1164
1165 (F) Perl could not compile a file specified in a C<require> statement.
1166 Perl uses this generic message when none of the errors that it
1167 encountered were severe enough to halt compilation immediately.
1168
1169 =item Complex regular subexpression recursion limit (%d) exceeded
1170
1171 (W regexp) The regular expression engine uses recursion in complex
1172 situations where back-tracking is required.  Recursion depth is limited
1173 to 32766, or perhaps less in architectures where the stack cannot grow
1174 arbitrarily.  ("Simple" and "medium" situations are handled without
1175 recursion and are not subject to a limit.)  Try shortening the string
1176 under examination; looping in Perl code (e.g. with C<while>) rather than
1177 in the regular expression engine; or rewriting the regular expression so
1178 that it is simpler or backtracks less.  (See L<perlfaq2> for information
1179 on I<Mastering Regular Expressions>.)
1180
1181 =item cond_broadcast() called on unlocked variable
1182
1183 (W threads) Within a thread-enabled program, you tried to call
1184 cond_broadcast() on a variable which wasn't locked. The cond_broadcast()
1185 function  is used to wake up another thread that is waiting in a
1186 cond_wait(). To ensure that the signal isn't sent before the other thread
1187 has a chance to enter the wait, it is usual for the signaling thread to
1188 first wait for a lock on variable. This lock attempt will only succeed
1189 after the other thread has entered cond_wait() and thus relinquished the
1190 lock.
1191
1192 =item cond_signal() called on unlocked variable
1193
1194 (W threads) Within a thread-enabled program, you tried to call
1195 cond_signal() on a variable which wasn't locked. The cond_signal()
1196 function  is used to wake up another thread that is waiting in a
1197 cond_wait(). To ensure that the signal isn't sent before the other thread
1198 has a chance to enter the wait, it is usual for the signaling thread to
1199 first wait for a lock on variable. This lock attempt will only succeed
1200 after the other thread has entered cond_wait() and thus relinquished the
1201 lock.
1202
1203 =item connect() on closed socket %s
1204
1205 (W closed) You tried to do a connect on a closed socket.  Did you forget
1206 to check the return value of your socket() call?  See
1207 L<perlfunc/connect>.
1208
1209 =item Constant(%s)%s: %s
1210
1211 (F) The parser found inconsistencies either while attempting to define
1212 an overloaded constant, or when trying to find the character name
1213 specified in the C<\N{...}> escape.  Perhaps you forgot to load the
1214 corresponding C<overload> or C<charnames> pragma?  See L<charnames> and
1215 L<overload>.
1216
1217 =item Constant is not %s reference
1218
1219 (F) A constant value (perhaps declared using the C<use constant> pragma)
1220 is being dereferenced, but it amounts to the wrong type of reference.
1221 The message indicates the type of reference that was expected. This
1222 usually indicates a syntax error in dereferencing the constant value.
1223 See L<perlsub/"Constant Functions"> and L<constant>.
1224
1225 =item Constant subroutine %s redefined
1226
1227 (S) You redefined a subroutine which had previously been
1228 eligible for inlining.  See L<perlsub/"Constant Functions"> for
1229 commentary and workarounds.
1230
1231 =item Constant subroutine %s undefined
1232
1233 (W misc) You undefined a subroutine which had previously been eligible
1234 for inlining.  See L<perlsub/"Constant Functions"> for commentary and
1235 workarounds.
1236
1237 =item Copy method did not return a reference
1238
1239 (F) The method which overloads "=" is buggy. See
1240 L<overload/Copy Constructor>.
1241
1242 =item CORE::%s is not a keyword
1243
1244 (F) The CORE:: namespace is reserved for Perl keywords.
1245
1246 =item corrupted regexp pointers
1247
1248 (P) The regular expression engine got confused by what the regular
1249 expression compiler gave it.
1250
1251 =item corrupted regexp program
1252
1253 (P) The regular expression engine got passed a regexp program without a
1254 valid magic number.
1255
1256 =item Corrupt malloc ptr 0x%lx at 0x%lx
1257
1258 (P) The malloc package that comes with Perl had an internal failure.
1259
1260 =item Count after length/code in unpack
1261
1262 (F) You had an unpack template indicating a counted-length string, but
1263 you have also specified an explicit size for the string.  See
1264 L<perlfunc/pack>.
1265
1266 =item Deep recursion on subroutine "%s"
1267
1268 (W recursion) This subroutine has called itself (directly or indirectly)
1269 100 times more than it has returned.  This probably indicates an
1270 infinite recursion, unless you're writing strange benchmark programs, in
1271 which case it indicates something else.
1272
1273 =item defined(@array) is deprecated
1274
1275 (D deprecated) defined() is not usually useful on arrays because it
1276 checks for an undefined I<scalar> value.  If you want to see if the
1277 array is empty, just use C<if (@array) { # not empty }> for example.
1278
1279 =item defined(%hash) is deprecated
1280
1281 (D deprecated) defined() is not usually useful on hashes because it
1282 checks for an undefined I<scalar> value.  If you want to see if the hash
1283 is empty, just use C<if (%hash) { # not empty }> for example.
1284
1285 =item %s defines neither package nor VERSION--version check failed
1286
1287 (F) You said something like "use Module 42" but in the Module file
1288 there are neither package declarations nor a C<$VERSION>.
1289
1290 =item Delimiter for here document is too long
1291
1292 (F) In a here document construct like C<<<FOO>, the label C<FOO> is too
1293 long for Perl to handle.  You have to be seriously twisted to write code
1294 that triggers this error.
1295
1296 =item Did not produce a valid header
1297
1298 See Server error.
1299
1300 =item %s did not return a true value
1301
1302 (F) A required (or used) file must return a true value to indicate that
1303 it compiled correctly and ran its initialization code correctly.  It's
1304 traditional to end such a file with a "1;", though any true value would
1305 do.  See L<perlfunc/require>.
1306
1307 =item (Did you mean &%s instead?)
1308
1309 (W) You probably referred to an imported subroutine &FOO as $FOO or some
1310 such.
1311
1312 =item (Did you mean "local" instead of "our"?)
1313
1314 (W misc) Remember that "our" does not localize the declared global
1315 variable.  You have declared it again in the same lexical scope, which
1316 seems superfluous.
1317
1318 =item (Did you mean $ or @ instead of %?)
1319
1320 (W) You probably said %hash{$key} when you meant $hash{$key} or
1321 @hash{@keys}.  On the other hand, maybe you just meant %hash and got
1322 carried away.
1323
1324 =item Died
1325
1326 (F) You passed die() an empty string (the equivalent of C<die "">) or
1327 you called it with no args and both C<$@> and C<$_> were empty.
1328
1329 =item Document contains no data
1330
1331 See Server error.
1332
1333 =item %s does not define %s::VERSION--version check failed
1334
1335 (F) You said something like "use Module 42" but the Module did not
1336 define a C<$VERSION.>
1337
1338 =item '/' does not take a repeat count
1339
1340 (F) You cannot put a repeat count of any kind right after the '/' code.
1341 See L<perlfunc/pack>.
1342
1343 =item Don't know how to handle magic of type '%s'
1344
1345 (P) The internal handling of magical variables has been cursed.
1346
1347 =item do_study: out of memory
1348
1349 (P) This should have been caught by safemalloc() instead.
1350
1351 =item (Do you need to predeclare %s?)
1352
1353 (S) This is an educated guess made in conjunction with the message "%s
1354 found where operator expected".  It often means a subroutine or module
1355 name is being referenced that hasn't been declared yet.  This may be
1356 because of ordering problems in your file, or because of a missing
1357 "sub", "package", "require", or "use" statement.  If you're referencing
1358 something that isn't defined yet, you don't actually have to define the
1359 subroutine or package before the current location.  You can use an empty
1360 "sub foo;" or "package FOO;" to enter a "forward" declaration.
1361
1362 =item dump() better written as CORE::dump()
1363
1364 (W misc) You used the obsolescent C<dump()> built-in function, without fully
1365 qualifying it as C<CORE::dump()>.  Maybe it's a typo.  See L<perlfunc/dump>.
1366
1367 =item Duplicate free() ignored
1368
1369 (S malloc) An internal routine called free() on something that had
1370 already been freed.
1371
1372 =item elseif should be elsif
1373
1374 (S) There is no keyword "elseif" in Perl because Larry thinks it's ugly.
1375 Your code will be interpreted as an attempt to call a method named
1376 "elseif" for the class returned by the following block.  This is
1377 unlikely to be what you want.
1378
1379 =item Empty %s
1380
1381 (F) C<\p> and C<\P> are used to introduce a named Unicode property, as
1382 described in L<perlunicode> and L<perlre>. You used C<\p> or C<\P> in
1383 a regular expression without specifying the property name.
1384
1385 =item entering effective %s failed
1386
1387 (F) While under the C<use filetest> pragma, switching the real and
1388 effective uids or gids failed.
1389
1390 =item Error converting file specification %s
1391
1392 (F) An error peculiar to VMS.  Because Perl may have to deal with file
1393 specifications in either VMS or Unix syntax, it converts them to a
1394 single form when it must operate on them directly.  Either you've passed
1395 an invalid file specification to Perl, or you've found a case the
1396 conversion routines don't handle.  Drat.
1397
1398 =item %s: Eval-group in insecure regular expression
1399
1400 (F) Perl detected tainted data when trying to compile a regular
1401 expression that contains the C<(?{ ... })> zero-width assertion, which
1402 is unsafe.  See L<perlre/(?{ code })>, and L<perlsec>.
1403
1404 =item %s: Eval-group not allowed at run time
1405
1406 (F) Perl tried to compile a regular expression containing the
1407 C<(?{ ... })> zero-width assertion at run time, as it would when the
1408 pattern contains interpolated values.  Since that is a security risk, it
1409 is not allowed.  If you insist, you may still do this by explicitly
1410 building the pattern from an interpolated string at run time and using
1411 that in an eval().  See L<perlre/(?{ code })>.
1412
1413 =item %s: Eval-group not allowed, use re 'eval'
1414
1415 (F) A regular expression contained the C<(?{ ... })> zero-width
1416 assertion, but that construct is only allowed when the C<use re 'eval'>
1417 pragma is in effect.  See L<perlre/(?{ code })>.
1418
1419 =item Excessively long <> operator
1420
1421 (F) The contents of a <> operator may not exceed the maximum size of a
1422 Perl identifier.  If you're just trying to glob a long list of
1423 filenames, try using the glob() operator, or put the filenames into a
1424 variable and glob that.
1425
1426 =item exec? I'm not *that* kind of operating system
1427
1428 (F) The C<exec> function is not implemented in MacPerl. See L<perlport>.
1429
1430 =item Execution of %s aborted due to compilation errors
1431
1432 (F) The final summary message when a Perl compilation fails.
1433
1434 =item Exiting eval via %s
1435
1436 (W exiting) You are exiting an eval by unconventional means, such as a
1437 goto, or a loop control statement.
1438
1439 =item Exiting format via %s
1440
1441 (W exiting) You are exiting a format by unconventional means, such as a
1442 goto, or a loop control statement.
1443
1444 =item Exiting pseudo-block via %s
1445
1446 (W exiting) You are exiting a rather special block construct (like a
1447 sort block or subroutine) by unconventional means, such as a goto, or a
1448 loop control statement.  See L<perlfunc/sort>.
1449
1450 =item Exiting subroutine via %s
1451
1452 (W exiting) You are exiting a subroutine by unconventional means, such
1453 as a goto, or a loop control statement.
1454
1455 =item Exiting substitution via %s
1456
1457 (W exiting) You are exiting a substitution by unconventional means, such
1458 as a return, a goto, or a loop control statement.
1459
1460 =item Explicit blessing to '' (assuming package main)
1461
1462 (W misc) You are blessing a reference to a zero length string.  This has
1463 the effect of blessing the reference into the package main.  This is
1464 usually not what you want.  Consider providing a default target package,
1465 e.g. bless($ref, $p || 'MyPackage');
1466
1467 =item %s: Expression syntax
1468
1469 (A) You've accidentally run your script through B<csh> instead of Perl.
1470 Check the #! line, or manually feed your script into Perl yourself.
1471
1472 =item %s failed--call queue aborted
1473
1474 (F) An untrapped exception was raised while executing a CHECK, INIT, or
1475 END subroutine.  Processing of the remainder of the queue of such
1476 routines has been prematurely ended.
1477
1478 =item False [] range "%s" in regex; marked by <-- HERE in m/%s/
1479
1480 (W regexp) A character class range must start and end at a literal
1481 character, not another character class like C<\d> or C<[:alpha:]>.  The "-"
1482 in your false range is interpreted as a literal "-".  Consider quoting the
1483 "-", "\-".  The <-- HERE shows in the regular expression about where the
1484 problem was discovered.  See L<perlre>.
1485
1486 =item Fatal VMS error at %s, line %d
1487
1488 (P) An error peculiar to VMS.  Something untoward happened in a VMS
1489 system service or RTL routine; Perl's exit status should provide more
1490 details.  The filename in "at %s" and the line number in "line %d" tell
1491 you which section of the Perl source code is distressed.
1492
1493 =item fcntl is not implemented
1494
1495 (F) Your machine apparently doesn't implement fcntl().  What is this, a
1496 PDP-11 or something?
1497
1498 =item Filehandle %s opened only for input
1499
1500 (W io) You tried to write on a read-only filehandle.  If you intended
1501 it to be a read-write filehandle, you needed to open it with "+<" or
1502 "+>" or "+>>" instead of with "<" or nothing.  If you intended only to
1503 write the file, use ">" or ">>".  See L<perlfunc/open>.
1504
1505 =item Filehandle %s opened only for output
1506
1507 (W io) You tried to read from a filehandle opened only for writing, If
1508 you intended it to be a read/write filehandle, you needed to open it
1509 with "+<" or "+>" or "+>>" instead of with "<" or nothing.  If you
1510 intended only to read from the file, use "<".  See L<perlfunc/open>.
1511 Another possibility is that you attempted to open filedescriptor 0
1512 (also known as STDIN) for output (maybe you closed STDIN earlier?).
1513
1514 =item Filehandle %s reopened as %s only for input
1515
1516 (W io) You opened for reading a filehandle that got the same filehandle id
1517 as STDOUT or STDERR. This occured because you closed STDOUT or STDERR
1518 previously.
1519
1520 =item Filehandle STDIN reopened as %s only for output
1521
1522 (W io) You opened for writing a filehandle that got the same filehandle id
1523 as STDIN. This occured because you closed STDIN previously.
1524
1525 =item Final $ should be \$ or $name
1526
1527 (F) You must now decide whether the final $ in a string was meant to be
1528 a literal dollar sign, or was meant to introduce a variable name that
1529 happens to be missing.  So you have to put either the backslash or the
1530 name.
1531
1532 =item flock() on closed filehandle %s
1533
1534 (W closed) The filehandle you're attempting to flock() got itself closed
1535 some time before now.  Check your control flow.  flock() operates on
1536 filehandles.  Are you attempting to call flock() on a dirhandle by the
1537 same name?
1538
1539 =item Format not terminated
1540
1541 (F) A format must be terminated by a line with a solitary dot.  Perl got
1542 to the end of your file without finding such a line.
1543
1544 =item Format %s redefined
1545
1546 (W redefine) You redefined a format.  To suppress this warning, say
1547
1548     {
1549         no warnings 'redefine';
1550         eval "format NAME =...";
1551     }
1552
1553 =item Found = in conditional, should be ==
1554
1555 (W syntax) You said
1556
1557     if ($foo = 123)
1558
1559 when you meant
1560
1561     if ($foo == 123)
1562
1563 (or something like that).
1564
1565 =item %s found where operator expected
1566
1567 (S) The Perl lexer knows whether to expect a term or an operator.  If it
1568 sees what it knows to be a term when it was expecting to see an
1569 operator, it gives you this warning.  Usually it indicates that an
1570 operator or delimiter was omitted, such as a semicolon.
1571
1572 =item gdbm store returned %d, errno %d, key "%s"
1573
1574 (S) A warning from the GDBM_File extension that a store failed.
1575
1576 =item gethostent not implemented
1577
1578 (F) Your C library apparently doesn't implement gethostent(), probably
1579 because if it did, it'd feel morally obligated to return every hostname
1580 on the Internet.
1581
1582 =item get%sname() on closed socket %s
1583
1584 (W closed) You tried to get a socket or peer socket name on a closed
1585 socket.  Did you forget to check the return value of your socket() call?
1586
1587 =item getpwnam returned invalid UIC %#o for user "%s"
1588
1589 (S) A warning peculiar to VMS.  The call to C<sys$getuai> underlying the
1590 C<getpwnam> operator returned an invalid UIC.
1591
1592 =item getsockopt() on closed socket %s
1593
1594 (W closed) You tried to get a socket option on a closed socket.  Did you
1595 forget to check the return value of your socket() call?  See
1596 L<perlfunc/getsockopt>.
1597
1598 =item Global symbol "%s" requires explicit package name
1599
1600 (F) You've said "use strict vars", which indicates that all variables
1601 must either be lexically scoped (using "my"), declared beforehand using
1602 "our", or explicitly qualified to say which package the global variable
1603 is in (using "::").
1604
1605 =item glob failed (%s)
1606
1607 (W glob) Something went wrong with the external program(s) used for
1608 C<glob> and C<< <*.c> >>.  Usually, this means that you supplied a
1609 C<glob> pattern that caused the external program to fail and exit with a
1610 nonzero status.  If the message indicates that the abnormal exit
1611 resulted in a coredump, this may also mean that your csh (C shell) is
1612 broken.  If so, you should change all of the csh-related variables in
1613 config.sh:  If you have tcsh, make the variables refer to it as if it
1614 were csh (e.g.  C<full_csh='/usr/bin/tcsh'>); otherwise, make them all
1615 empty (except that C<d_csh> should be C<'undef'>) so that Perl will
1616 think csh is missing.  In either case, after editing config.sh, run
1617 C<./Configure -S> and rebuild Perl.
1618
1619 =item Glob not terminated
1620
1621 (F) The lexer saw a left angle bracket in a place where it was expecting
1622 a term, so it's looking for the corresponding right angle bracket, and
1623 not finding it.  Chances are you left some needed parentheses out
1624 earlier in the line, and you really meant a "less than".
1625
1626 =item Got an error from DosAllocMem
1627
1628 (P) An error peculiar to OS/2.  Most probably you're using an obsolete
1629 version of Perl, and this should not happen anyway.
1630
1631 =item goto must have label
1632
1633 (F) Unlike with "next" or "last", you're not allowed to goto an
1634 unspecified destination.  See L<perlfunc/goto>.
1635
1636 =item ()-group starts with a count
1637
1638 (F) A ()-group started with a count.  A count is
1639 supposed to follow something: a template character or a ()-group.
1640  See L<perlfunc/pack>.
1641
1642 =item %s had compilation errors
1643
1644 (F) The final summary message when a C<perl -c> fails.
1645
1646 =item Had to create %s unexpectedly
1647
1648 (S internal) A routine asked for a symbol from a symbol table that ought
1649 to have existed already, but for some reason it didn't, and had to be
1650 created on an emergency basis to prevent a core dump.
1651
1652 =item Hash %%s missing the % in argument %d of %s()
1653
1654 (D deprecated) Really old Perl let you omit the % on hash names in some
1655 spots.  This is now heavily deprecated.
1656
1657 =item %s has too many errors
1658
1659 (F) The parser has given up trying to parse the program after 10 errors.
1660 Further error messages would likely be uninformative.
1661
1662 =item Hexadecimal number > 0xffffffff non-portable
1663
1664 (W portable) The hexadecimal number you specified is larger than 2**32-1
1665 (4294967295) and therefore non-portable between systems.  See
1666 L<perlport> for more on portability concerns.
1667
1668 =item Identifier too long
1669
1670 (F) Perl limits identifiers (names for variables, functions, etc.) to
1671 about 250 characters for simple names, and somewhat more for compound
1672 names (like C<$A::B>).  You've exceeded Perl's limits.  Future versions
1673 of Perl are likely to eliminate these arbitrary limitations.
1674
1675 =item Illegal binary digit %s
1676
1677 (F) You used a digit other than 0 or 1 in a binary number.
1678
1679 =item Illegal binary digit %s ignored
1680
1681 (W digit) You may have tried to use a digit other than 0 or 1 in a
1682 binary number.  Interpretation of the binary number stopped before the
1683 offending digit.
1684
1685 =item Illegal character %s (carriage return)
1686
1687 (F) Perl normally treats carriage returns in the program text as it
1688 would any other whitespace, which means you should never see this error
1689 when Perl was built using standard options.  For some reason, your
1690 version of Perl appears to have been built without this support.  Talk
1691 to your Perl administrator.
1692
1693 =item Illegal character in prototype for %s : %s
1694
1695 (W syntax) An illegal character was found in a prototype declaration.  Legal
1696 characters in prototypes are $, @, %, *, ;, [, ], &, and \.
1697
1698 =item Illegal declaration of anonymous subroutine
1699
1700 (F) When using the C<sub> keyword to construct an anonymous subroutine,
1701 you must always specify a block of code. See L<perlsub>.
1702
1703 =item Illegal division by zero
1704
1705 (F) You tried to divide a number by 0.  Either something was wrong in
1706 your logic, or you need to put a conditional in to guard against
1707 meaningless input.
1708
1709 =item Illegal hexadecimal digit %s ignored
1710
1711 (W digit) You may have tried to use a character other than 0 - 9 or
1712 A - F, a - f in a hexadecimal number.  Interpretation of the hexadecimal
1713 number stopped before the illegal character.
1714
1715 =item Illegal modulus zero
1716
1717 (F) You tried to divide a number by 0 to get the remainder.  Most
1718 numbers don't take to this kindly.
1719
1720 =item Illegal number of bits in vec
1721
1722 (F) The number of bits in vec() (the third argument) must be a power of
1723 two from 1 to 32 (or 64, if your platform supports that).
1724
1725 =item Illegal octal digit %s
1726
1727 (F) You used an 8 or 9 in an octal number.
1728
1729 =item Illegal octal digit %s ignored
1730
1731 (W digit) You may have tried to use an 8 or 9 in an octal number.
1732 Interpretation of the octal number stopped before the 8 or 9.
1733
1734 =item Illegal switch in PERL5OPT: %s
1735
1736 (X) The PERL5OPT environment variable may only be used to set the
1737 following switches: B<-[DIMUdmtw]>.
1738
1739 =item Ill-formed CRTL environ value "%s"
1740
1741 (W internal) A warning peculiar to VMS.  Perl tried to read the CRTL's
1742 internal environ array, and encountered an element without the C<=>
1743 delimiter used to separate keys from values.  The element is ignored.
1744
1745 =item Ill-formed message in prime_env_iter: |%s|
1746
1747 (W internal) A warning peculiar to VMS.  Perl tried to read a logical
1748 name or CLI symbol definition when preparing to iterate over %ENV, and
1749 didn't see the expected delimiter between key and value, so the line was
1750 ignored.
1751
1752 =item Impossible to activate assertion call
1753
1754 (W assertions) You're calling an assertion function in a block that is
1755 not under the control of the C<assertions> pragma.
1756
1757 =item (in cleanup) %s
1758
1759 (W misc) This prefix usually indicates that a DESTROY() method raised
1760 the indicated exception.  Since destructors are usually called by the
1761 system at arbitrary points during execution, and often a vast number of
1762 times, the warning is issued only once for any number of failures that
1763 would otherwise result in the same message being repeated.
1764
1765 Failure of user callbacks dispatched using the C<G_KEEPERR> flag could
1766 also result in this warning.  See L<perlcall/G_KEEPERR>.
1767
1768 =item In EBCDIC the v-string components cannot exceed 2147483647
1769
1770 (F) An error peculiar to EBCDIC.  Internally, v-strings are stored as
1771 Unicode code points, and encoded in EBCDIC as UTF-EBCDIC.  The UTF-EBCDIC
1772 encoding is limited to code points no larger than 2147483647 (0x7FFFFFFF).
1773
1774 =item Insecure dependency in %s
1775
1776 (F) You tried to do something that the tainting mechanism didn't like.
1777 The tainting mechanism is turned on when you're running setuid or
1778 setgid, or when you specify B<-T> to turn it on explicitly.  The
1779 tainting mechanism labels all data that's derived directly or indirectly
1780 from the user, who is considered to be unworthy of your trust.  If any
1781 such data is used in a "dangerous" operation, you get this error.  See
1782 L<perlsec> for more information.
1783
1784 =item Insecure directory in %s
1785
1786 (F) You can't use system(), exec(), or a piped open in a setuid or
1787 setgid script if C<$ENV{PATH}> contains a directory that is writable by
1788 the world.  See L<perlsec>.
1789
1790 =item Insecure $ENV{%s} while running %s
1791
1792 (F) You can't use system(), exec(), or a piped open in a setuid or
1793 setgid script if any of C<$ENV{PATH}>, C<$ENV{IFS}>, C<$ENV{CDPATH}>,
1794 C<$ENV{ENV}>, C<$ENV{BASH_ENV}> or C<$ENV{TERM}> are derived from data
1795 supplied (or potentially supplied) by the user.  The script must set
1796 the path to a known value, using trustworthy data.  See L<perlsec>.
1797
1798 =item Integer overflow in %s number
1799
1800 (W overflow) The hexadecimal, octal or binary number you have specified
1801 either as a literal or as an argument to hex() or oct() is too big for
1802 your architecture, and has been converted to a floating point number.
1803 On a 32-bit architecture the largest hexadecimal, octal or binary number
1804 representable without overflow is 0xFFFFFFFF, 037777777777, or
1805 0b11111111111111111111111111111111 respectively.  Note that Perl
1806 transparently promotes all numbers to a floating point representation
1807 internally--subject to loss of precision errors in subsequent
1808 operations.
1809
1810 =item Integer overflow in version
1811
1812 (F) Some portion of a version initialization is too large for the
1813 size of integers for your architecture.  This is not a warning
1814 because there is no rational reason for a version to try and use a
1815 element larger than typically 2**32.  This is usually caused by
1816 trying to use some odd mathematical operation as a version, like
1817 100/9.
1818
1819 =item Internal disaster in regex; marked by <-- HERE in m/%s/
1820
1821 (P) Something went badly wrong in the regular expression parser.
1822 The <-- HERE shows in the regular expression about where the problem was
1823 discovered.
1824
1825 =item Internal inconsistency in tracking vforks
1826
1827 (S) A warning peculiar to VMS.  Perl keeps track of the number of times
1828 you've called C<fork> and C<exec>, to determine whether the current call
1829 to C<exec> should affect the current script or a subprocess (see
1830 L<perlvms/"exec LIST">).  Somehow, this count has become scrambled, so
1831 Perl is making a guess and treating this C<exec> as a request to
1832 terminate the Perl script and execute the specified command.
1833
1834 =item Internal urp in regex; marked by <-- HERE in m/%s/
1835
1836 (P) Something went badly awry in the regular expression parser. The
1837 <-- HERE shows in the regular expression about where the problem was
1838 discovered.
1839
1840 =item %s (...) interpreted as function
1841
1842 (W syntax) You've run afoul of the rule that says that any list operator
1843 followed by parentheses turns into a function, with all the list
1844 operators arguments found inside the parentheses.  See
1845 L<perlop/Terms and List Operators (Leftward)>.
1846
1847 =item Invalid %s attribute: %s
1848
1849 The indicated attribute for a subroutine or variable was not recognized
1850 by Perl or by a user-supplied handler.  See L<attributes>.
1851
1852 =item Invalid %s attributes: %s
1853
1854 The indicated attributes for a subroutine or variable were not
1855 recognized by Perl or by a user-supplied handler.  See L<attributes>.
1856
1857 =item Invalid conversion in %s: "%s"
1858
1859 (W printf) Perl does not understand the given format conversion.  See
1860 L<perlfunc/sprintf>.
1861
1862 =item Invalid [] range "%s" in regex; marked by <-- HERE in m/%s/
1863
1864 (F) The range specified in a character class had a minimum character
1865 greater than the maximum character.  One possibility is that you forgot the
1866 C<{}> from your ending C<\x{}> - C<\x> without the curly braces can go only
1867 up to C<ff>.  The <-- HERE shows in the regular expression about where the
1868 problem was discovered.  See L<perlre>.
1869
1870 =item Invalid range "%s" in transliteration operator
1871
1872 (F) The range specified in the tr/// or y/// operator had a minimum
1873 character greater than the maximum character.  See L<perlop>.
1874
1875 =item Invalid separator character %s in attribute list
1876
1877 (F) Something other than a colon or whitespace was seen between the
1878 elements of an attribute list.  If the previous attribute had a
1879 parenthesised parameter list, perhaps that list was terminated too soon.
1880 See L<attributes>.
1881
1882 =item Invalid separator character %s in PerlIO layer specification %s
1883
1884 (W layer) When pushing layers onto the Perl I/O system, something other than a
1885 colon or whitespace was seen between the elements of a layer list.
1886 If the previous attribute had a parenthesised parameter list, perhaps that
1887 list was terminated too soon.
1888
1889 =item Invalid type '%s' in %s
1890
1891 (F) The given character is not a valid pack or unpack type.
1892 See L<perlfunc/pack>.
1893 (W) The given character is not a valid pack or unpack type but used to be
1894 silently ignored.
1895
1896 =item Invalid version format (multiple underscores)
1897
1898 (F) Versions may contain at most a single underscore, which signals
1899 that the version is a beta release.  See L<version> for the allowed
1900 version formats.
1901
1902 =item Invalid version format (underscores before decimal)
1903
1904 (F) Versions may not contain decimals after the optional underscore.
1905 See L<version> for the allowed version formats.
1906
1907 =item ioctl is not implemented
1908
1909 (F) Your machine apparently doesn't implement ioctl(), which is pretty
1910 strange for a machine that supports C.
1911
1912 =item ioctl() on unopened %s
1913
1914 (W unopened) You tried ioctl() on a filehandle that was never opened.
1915 Check you control flow and number of arguments.
1916
1917 =item IO layers (like "%s") unavailable
1918
1919 (F) Your Perl has not been configured to have PerlIO, and therefore
1920 you cannot use IO layers.  To have PerlIO Perl must be configured
1921 with 'useperlio'.
1922
1923 =item IO::Socket::atmark not implemented on this architecture
1924
1925 (F) Your machine doesn't implement the sockatmark() functionality,
1926 neither as a system call or an ioctl call (SIOCATMARK).
1927
1928 =item $* is no longer supported
1929
1930 (D deprecated) The special variable C<$*>, deprecated in older perls, has
1931 been removed as of 5.9.0 and is no longer supported. You should use the
1932 C<//m> and C<//s> regexp modifiers instead.
1933
1934 =item `%s' is not a code reference
1935
1936 (W overload) The second (fourth, sixth, ...) argument of overload::constant
1937 needs to be a code reference. Either an anonymous subroutine, or a reference
1938 to a subroutine.
1939
1940 =item `%s' is not an overloadable type
1941
1942 (W overload) You tried to overload a constant type the overload package is
1943 unaware of.
1944
1945 =item junk on end of regexp
1946
1947 (P) The regular expression parser is confused.
1948
1949 =item Label not found for "last %s"
1950
1951 (F) You named a loop to break out of, but you're not currently in a loop
1952 of that name, not even if you count where you were called from.  See
1953 L<perlfunc/last>.
1954
1955 =item Label not found for "next %s"
1956
1957 (F) You named a loop to continue, but you're not currently in a loop of
1958 that name, not even if you count where you were called from.  See
1959 L<perlfunc/last>.
1960
1961 =item Label not found for "redo %s"
1962
1963 (F) You named a loop to restart, but you're not currently in a loop of
1964 that name, not even if you count where you were called from.  See
1965 L<perlfunc/last>.
1966
1967 =item leaving effective %s failed
1968
1969 (F) While under the C<use filetest> pragma, switching the real and
1970 effective uids or gids failed.
1971
1972 =item length/code after end of string in unpack
1973
1974 (F) While unpacking, the string buffer was alread used up when an unpack
1975 length/code combination tried to obtain more data. This results in
1976 an undefined value for the length. See L<perlfunc/pack>.
1977
1978 =item listen() on closed socket %s
1979
1980 (W closed) You tried to do a listen on a closed socket.  Did you forget
1981 to check the return value of your socket() call?  See
1982 L<perlfunc/listen>.
1983
1984 =item Lookbehind longer than %d not implemented in regex; marked by <-- HERE in m/%s/
1985
1986 (F) There is currently a limit on the length of string which lookbehind can
1987 handle. This restriction may be eased in a future release. The <-- HERE
1988 shows in the regular expression about where the problem was discovered.
1989
1990 =item lstat() on filehandle %s
1991
1992 (W io) You tried to do an lstat on a filehandle.  What did you mean
1993 by that?  lstat() makes sense only on filenames.  (Perl did a fstat()
1994 instead on the filehandle.)
1995
1996 =item Lvalue subs returning %s not implemented yet
1997
1998 (F) Due to limitations in the current implementation, array and hash
1999 values cannot be returned in subroutines used in lvalue context.  See
2000 L<perlsub/"Lvalue subroutines">.
2001
2002 =item Malformed integer in [] in  pack
2003
2004 (F) Between the  brackets enclosing a numeric repeat count only digits
2005 are permitted.  See L<perlfunc/pack>.
2006
2007 =item Malformed integer in [] in unpack
2008
2009 (F) Between the  brackets enclosing a numeric repeat count only digits
2010 are permitted.  See L<perlfunc/pack>.
2011
2012 =item Malformed PERLLIB_PREFIX
2013
2014 (F) An error peculiar to OS/2.  PERLLIB_PREFIX should be of the form
2015
2016     prefix1;prefix2
2017
2018 or
2019     prefix1 prefix2
2020
2021 with nonempty prefix1 and prefix2.  If C<prefix1> is indeed a prefix of
2022 a builtin library search path, prefix2 is substituted.  The error may
2023 appear if components are not found, or are too long.  See
2024 "PERLLIB_PREFIX" in L<perlos2>.
2025
2026 =item Malformed prototype for %s: %s
2027
2028 (F) You tried to use a function with a malformed prototype.  The
2029 syntax of function prototypes is given a brief compile-time check for
2030 obvious errors like invalid characters.  A more rigorous check is run
2031 when the function is called.
2032
2033 =item Malformed UTF-8 character (%s)
2034
2035 Perl detected something that didn't comply with UTF-8 encoding rules.
2036
2037 One possible cause is that you read in data that you thought to be in
2038 UTF-8 but it wasn't (it was for example legacy 8-bit data).  Another
2039 possibility is careless use of utf8::upgrade().
2040
2041 =item Malformed UTF-16 surrogate
2042
2043 Perl thought it was reading UTF-16 encoded character data but while
2044 doing it Perl met a malformed Unicode surrogate.
2045
2046 =item %s matches null string many times in regex; marked by <-- HERE in m/%s/
2047
2048 (W regexp) The pattern you've specified would be an infinite loop if the
2049 regular expression engine didn't specifically check for that.  The <-- HERE
2050 shows in the regular expression about where the problem was discovered.
2051 See L<perlre>.
2052
2053 =item "%s" may clash with future reserved word
2054
2055 (W) This warning may be due to running a perl5 script through a perl4
2056 interpreter, especially if the word that is being warned about is
2057 "use" or "my".
2058
2059 =item % may not be used in pack
2060
2061 (F) You can't pack a string by supplying a checksum, because the
2062 checksumming process loses information, and you can't go the other way.
2063 See L<perlfunc/unpack>.
2064
2065 =item Method for operation %s not found in package %s during blessing
2066
2067 (F) An attempt was made to specify an entry in an overloading table that
2068 doesn't resolve to a valid subroutine.  See L<overload>.
2069
2070 =item Method %s not permitted
2071
2072 See Server error.
2073
2074 =item Might be a runaway multi-line %s string starting on line %d
2075
2076 (S) An advisory indicating that the previous error may have been caused
2077 by a missing delimiter on a string or pattern, because it eventually
2078 ended earlier on the current line.
2079
2080 =item Misplaced _ in number
2081
2082 (W syntax) An underscore (underbar) in a numeric constant did not
2083 separate two digits.
2084
2085 =item Missing %sbrace%s on \N{}
2086
2087 (F) Wrong syntax of character name literal C<\N{charname}> within
2088 double-quotish context.
2089
2090 =item Missing comma after first argument to %s function
2091
2092 (F) While certain functions allow you to specify a filehandle or an
2093 "indirect object" before the argument list, this ain't one of them.
2094
2095 =item Missing command in piped open
2096
2097 (W pipe) You used the C<open(FH, "| command")> or
2098 C<open(FH, "command |")> construction, but the command was missing or
2099 blank.
2100
2101 =item Missing control char name in \c
2102
2103 (F) A double-quoted string ended with "\c", without the required control
2104 character name.
2105
2106 =item Missing name in "my sub"
2107
2108 (F) The reserved syntax for lexically scoped subroutines requires that
2109 they have a name with which they can be found.
2110
2111 =item Missing $ on loop variable
2112
2113 (F) Apparently you've been programming in B<csh> too much.  Variables
2114 are always mentioned with the $ in Perl, unlike in the shells, where it
2115 can vary from one line to the next.
2116
2117 =item (Missing operator before %s?)
2118
2119 (S) This is an educated guess made in conjunction with the message "%s
2120 found where operator expected".  Often the missing operator is a comma.
2121
2122 =item Missing right brace on %s
2123
2124 (F) Missing right brace in C<\p{...}> or C<\P{...}>.
2125
2126 =item Missing right curly or square bracket
2127
2128 (F) The lexer counted more opening curly or square brackets than closing
2129 ones.  As a general rule, you'll find it's missing near the place you
2130 were last editing.
2131
2132 =item (Missing semicolon on previous line?)
2133
2134 (S) This is an educated guess made in conjunction with the message "%s
2135 found where operator expected".  Don't automatically put a semicolon on
2136 the previous line just because you saw this message.
2137
2138 =item Modification of a read-only value attempted
2139
2140 (F) You tried, directly or indirectly, to change the value of a
2141 constant.  You didn't, of course, try "2 = 1", because the compiler
2142 catches that.  But an easy way to do the same thing is:
2143
2144     sub mod { $_[0] = 1 }
2145     mod(2);
2146
2147 Another way is to assign to a substr() that's off the end of the string.
2148
2149 Yet another way is to assign to a C<foreach> loop I<VAR> when I<VAR>
2150 is aliased to a constant in the look I<LIST>:
2151
2152         $x = 1;
2153         foreach my $n ($x, 2) {
2154             $n *= 2; # modifies the $x, but fails on attempt to modify the 2
2155         }
2156
2157 =item Modification of non-creatable array value attempted, %s
2158
2159 (F) You tried to make an array value spring into existence, and the
2160 subscript was probably negative, even counting from end of the array
2161 backwards.
2162
2163 =item Modification of non-creatable hash value attempted, %s
2164
2165 (P) You tried to make a hash value spring into existence, and it
2166 couldn't be created for some peculiar reason.
2167
2168 =item Module name must be constant
2169
2170 (F) Only a bare module name is allowed as the first argument to a "use".
2171
2172 =item Module name required with -%c option
2173
2174 (F) The C<-M> or C<-m> options say that Perl should load some module, but
2175 you omitted the name of the module.  Consult L<perlrun> for full details
2176 about C<-M> and C<-m>.
2177
2178 =item More than one argument to open
2179
2180 (F) The C<open> function has been asked to open multiple files. This
2181 can happen if you are trying to open a pipe to a command that takes a
2182 list of arguments, but have forgotten to specify a piped open mode.
2183 See L<perlfunc/open> for details.
2184
2185 =item msg%s not implemented
2186
2187 (F) You don't have System V message IPC on your system.
2188
2189 =item Multidimensional syntax %s not supported
2190
2191 (W syntax) Multidimensional arrays aren't written like C<$foo[1,2,3]>.
2192 They're written like C<$foo[1][2][3]>, as in C.
2193
2194 =item '/' must be followed by 'a*', 'A*' or 'Z*'
2195
2196 (F) You had a pack template indicating a counted-length string,
2197 Currently the only things that can have their length counted are a*, A*
2198 or Z*.  See L<perlfunc/pack>.
2199
2200 =item '/' must follow a numeric type in unpack
2201
2202 (F) You had an unpack template that contained a '/', but this did not
2203 follow some unpack specification producing a numeric value.
2204 See L<perlfunc/pack>.
2205
2206 =item "my sub" not yet implemented
2207
2208 (F) Lexically scoped subroutines are not yet implemented.  Don't try
2209 that yet.
2210
2211 =item "my" variable %s can't be in a package
2212
2213 (F) Lexically scoped variables aren't in a package, so it doesn't make
2214 sense to try to declare one with a package qualifier on the front.  Use
2215 local() if you want to localize a package variable.
2216
2217 =item Name "%s::%s" used only once: possible typo
2218
2219 (W once) Typographical errors often show up as unique variable names.
2220 If you had a good reason for having a unique name, then just mention it
2221 again somehow to suppress the message.  The C<our> declaration is
2222 provided for this purpose.
2223
2224 NOTE: This warning detects symbols that have been used only once so $c, @c,
2225 %c, *c, &c, sub c{}, c(), and c (the filehandle or format) are considered
2226 the same; if a program uses $c only once but also uses any of the others it
2227 will not trigger this warning.
2228
2229 =item Negative '/' count in unpack
2230
2231 (F) The length count obtained from a length/code unpack operation was
2232 negative.  See L<perlfunc/pack>.
2233
2234 =item Negative length
2235
2236 (F) You tried to do a read/write/send/recv operation with a buffer
2237 length that is less than 0.  This is difficult to imagine.
2238
2239 =item Negative offset to vec in lvalue context
2240
2241 (F) When C<vec> is called in an lvalue context, the second argument must be
2242 greater than or equal to zero.
2243
2244 =item Nested quantifiers in regex; marked by <-- HERE in m/%s/
2245
2246 (F) You can't quantify a quantifier without intervening parentheses. So
2247 things like ** or +* or ?* are illegal. The <-- HERE shows in the regular
2248 expression about where the problem was discovered.
2249
2250 Note that the minimal matching quantifiers, C<*?>, C<+?>, and
2251 C<??> appear to be nested quantifiers, but aren't.  See L<perlre>.
2252
2253 =item %s never introduced
2254
2255 (S internal) The symbol in question was declared but somehow went out of
2256 scope before it could possibly have been used.
2257
2258 =item Newline in left-justified string for %s
2259
2260 (W printf) There is a newline in a string to be left justified by 
2261 C<printf> or C<sprintf>.
2262
2263 The padding spaces will appear after the newline, which is probably not
2264 what you wanted.  Usually you should remove the newline from the string 
2265 and put formatting characters in the C<sprintf> format.
2266
2267 =item No %s allowed while running setuid
2268
2269 (F) Certain operations are deemed to be too insecure for a setuid or
2270 setgid script to even be allowed to attempt.  Generally speaking there
2271 will be another way to do what you want that is, if not secure, at least
2272 securable.  See L<perlsec>.
2273
2274 =item No comma allowed after %s
2275
2276 (F) A list operator that has a filehandle or "indirect object" is not
2277 allowed to have a comma between that and the following arguments.
2278 Otherwise it'd be just another one of the arguments.
2279
2280 One possible cause for this is that you expected to have imported a
2281 constant to your name space with B<use> or B<import> while no such
2282 importing took place, it may for example be that your operating system
2283 does not support that particular constant. Hopefully you did use an
2284 explicit import list for the constants you expect to see, please see
2285 L<perlfunc/use> and L<perlfunc/import>. While an explicit import list
2286 would probably have caught this error earlier it naturally does not
2287 remedy the fact that your operating system still does not support that
2288 constant. Maybe you have a typo in the constants of the symbol import
2289 list of B<use> or B<import> or in the constant name at the line where
2290 this error was triggered?
2291
2292 =item No command into which to pipe on command line
2293
2294 (F) An error peculiar to VMS.  Perl handles its own command line
2295 redirection, and found a '|' at the end of the command line, so it
2296 doesn't know where you want to pipe the output from this command.
2297
2298 =item No DB::DB routine defined
2299
2300 (F) The currently executing code was compiled with the B<-d> switch, but
2301 for some reason the perl5db.pl file (or some facsimile thereof) didn't
2302 define a routine to be called at the beginning of each statement.  Which
2303 is odd, because the file should have been required automatically, and
2304 should have blown up the require if it didn't parse right.
2305
2306 =item No dbm on this machine
2307
2308 (P) This is counted as an internal error, because every machine should
2309 supply dbm nowadays, because Perl comes with SDBM.  See L<SDBM_File>.
2310
2311 =item No DBsub routine
2312
2313 (F) The currently executing code was compiled with the B<-d> switch,
2314 but for some reason the perl5db.pl file (or some facsimile thereof)
2315 didn't define a DB::sub routine to be called at the beginning of each
2316 ordinary subroutine call.
2317
2318 =item No B<-e> allowed in setuid scripts
2319
2320 (F) A setuid script can't be specified by the user.
2321
2322 =item No error file after 2> or 2>> on command line
2323
2324 (F) An error peculiar to VMS.  Perl handles its own command line
2325 redirection, and found a '2>' or a '2>>' on the command line, but can't
2326 find the name of the file to which to write data destined for stderr.
2327
2328 =item No group ending character '%c' found in template
2329
2330 (F) A pack or unpack template has an opening '(' or '[' without its
2331 matching counterpart. See L<perlfunc/pack>.
2332
2333 =item No input file after < on command line
2334
2335 (F) An error peculiar to VMS.  Perl handles its own command line
2336 redirection, and found a '<' on the command line, but can't find the
2337 name of the file from which to read data for stdin.
2338
2339 =item No #! line
2340
2341 (F) The setuid emulator requires that scripts have a well-formed #! line
2342 even on machines that don't support the #! construct.
2343
2344 =item "no" not allowed in expression
2345
2346 (F) The "no" keyword is recognized and executed at compile time, and
2347 returns no useful value.  See L<perlmod>.
2348
2349 =item No output file after > on command line
2350
2351 (F) An error peculiar to VMS.  Perl handles its own command line
2352 redirection, and found a lone '>' at the end of the command line, so it
2353 doesn't know where you wanted to redirect stdout.
2354
2355 =item No output file after > or >> on command line
2356
2357 (F) An error peculiar to VMS.  Perl handles its own command line
2358 redirection, and found a '>' or a '>>' on the command line, but can't
2359 find the name of the file to which to write data destined for stdout.
2360
2361 =item No package name allowed for variable %s in "our"
2362
2363 (F) Fully qualified variable names are not allowed in "our"
2364 declarations, because that doesn't make much sense under existing
2365 semantics.  Such syntax is reserved for future extensions.
2366
2367 =item No Perl script found in input
2368
2369 (F) You called C<perl -x>, but no line was found in the file beginning
2370 with #! and containing the word "perl".
2371
2372 =item No setregid available
2373
2374 (F) Configure didn't find anything resembling the setregid() call for
2375 your system.
2376
2377 =item No setreuid available
2378
2379 (F) Configure didn't find anything resembling the setreuid() call for
2380 your system.
2381
2382 =item No space allowed after -%c
2383
2384 (F) The argument to the indicated command line switch must follow
2385 immediately after the switch, without intervening spaces.
2386
2387 =item No %s specified for -%c
2388
2389 (F) The indicated command line switch needs a mandatory argument, but
2390 you haven't specified one.
2391
2392 =item No such class %s
2393
2394 (F) You provided a class qualifier in a "my" or "our" declaration, but
2395 this class doesn't exist at this point in your program.
2396
2397 =item No such pipe open
2398
2399 (P) An error peculiar to VMS.  The internal routine my_pclose() tried to
2400 close a pipe which hadn't been opened.  This should have been caught
2401 earlier as an attempt to close an unopened filehandle.
2402
2403 =item No such signal: SIG%s
2404
2405 (W signal) You specified a signal name as a subscript to %SIG that was
2406 not recognized.  Say C<kill -l> in your shell to see the valid signal
2407 names on your system.
2408
2409 =item Not a CODE reference
2410
2411 (F) Perl was trying to evaluate a reference to a code value (that is, a
2412 subroutine), but found a reference to something else instead.  You can
2413 use the ref() function to find out what kind of ref it really was.  See
2414 also L<perlref>.
2415
2416 =item Not a format reference
2417
2418 (F) I'm not sure how you managed to generate a reference to an anonymous
2419 format, but this indicates you did, and that it didn't exist.
2420
2421 =item Not a GLOB reference
2422
2423 (F) Perl was trying to evaluate a reference to a "typeglob" (that is, a
2424 symbol table entry that looks like C<*foo>), but found a reference to
2425 something else instead.  You can use the ref() function to find out what
2426 kind of ref it really was.  See L<perlref>.
2427
2428 =item Not a HASH reference
2429
2430 (F) Perl was trying to evaluate a reference to a hash value, but found a
2431 reference to something else instead.  You can use the ref() function to
2432 find out what kind of ref it really was.  See L<perlref>.
2433
2434 =item Not an ARRAY reference
2435
2436 (F) Perl was trying to evaluate a reference to an array value, but found
2437 a reference to something else instead.  You can use the ref() function
2438 to find out what kind of ref it really was.  See L<perlref>.
2439
2440 =item Not a perl script
2441
2442 (F) The setuid emulator requires that scripts have a well-formed #! line
2443 even on machines that don't support the #! construct.  The line must
2444 mention perl.
2445
2446 =item Not a SCALAR reference
2447
2448 (F) Perl was trying to evaluate a reference to a scalar value, but found
2449 a reference to something else instead.  You can use the ref() function
2450 to find out what kind of ref it really was.  See L<perlref>.
2451
2452 =item Not a subroutine reference
2453
2454 (F) Perl was trying to evaluate a reference to a code value (that is, a
2455 subroutine), but found a reference to something else instead.  You can
2456 use the ref() function to find out what kind of ref it really was.  See
2457 also L<perlref>.
2458
2459 =item Not a subroutine reference in overload table
2460
2461 (F) An attempt was made to specify an entry in an overloading table that
2462 doesn't somehow point to a valid subroutine.  See L<overload>.
2463
2464 =item Not enough arguments for %s
2465
2466 (F) The function requires more arguments than you specified.
2467
2468 =item Not enough format arguments
2469
2470 (W syntax) A format specified more picture fields than the next line
2471 supplied.  See L<perlform>.
2472
2473 =item %s: not found
2474
2475 (A) You've accidentally run your script through the Bourne shell instead
2476 of Perl.  Check the #! line, or manually feed your script into Perl
2477 yourself.
2478
2479 =item no UTC offset information; assuming local time is UTC
2480
2481 (S) A warning peculiar to VMS.  Perl was unable to find the local
2482 timezone offset, so it's assuming that local system time is equivalent
2483 to UTC.  If it's not, define the logical name
2484 F<SYS$TIMEZONE_DIFFERENTIAL> to translate to the number of seconds which
2485 need to be added to UTC to get local time.
2486
2487 =item Null filename used
2488
2489 (F) You can't require the null filename, especially because on many
2490 machines that means the current directory!  See L<perlfunc/require>.
2491
2492 =item NULL OP IN RUN
2493
2494 (P debugging) Some internal routine called run() with a null opcode
2495 pointer.
2496
2497 =item Null picture in formline
2498
2499 (F) The first argument to formline must be a valid format picture
2500 specification.  It was found to be empty, which probably means you
2501 supplied it an uninitialized value.  See L<perlform>.
2502
2503 =item Null realloc
2504
2505 (P) An attempt was made to realloc NULL.
2506
2507 =item NULL regexp argument
2508
2509 (P) The internal pattern matching routines blew it big time.
2510
2511 =item NULL regexp parameter
2512
2513 (P) The internal pattern matching routines are out of their gourd.
2514
2515 =item Number too long
2516
2517 (F) Perl limits the representation of decimal numbers in programs to
2518 about 250 characters.  You've exceeded that length.  Future
2519 versions of Perl are likely to eliminate this arbitrary limitation.  In
2520 the meantime, try using scientific notation (e.g. "1e6" instead of
2521 "1_000_000").
2522
2523 =item Octal number in vector unsupported
2524
2525 (F) Numbers with a leading C<0> are not currently allowed in vectors.
2526 The octal number interpretation of such numbers may be supported in a
2527 future version.
2528
2529 =item Octal number > 037777777777 non-portable
2530
2531 (W portable) The octal number you specified is larger than 2**32-1
2532 (4294967295) and therefore non-portable between systems.  See
2533 L<perlport> for more on portability concerns.
2534
2535 See also L<perlport> for writing portable code.
2536
2537 =item Odd number of arguments for overload::constant
2538
2539 (W overload) The call to overload::constant contained an odd number of
2540 arguments. The arguments should come in pairs.
2541
2542 =item Odd number of elements in anonymous hash
2543
2544 (W misc) You specified an odd number of elements to initialize a hash,
2545 which is odd, because hashes come in key/value pairs.
2546
2547 =item Odd number of elements in hash assignment
2548
2549 (W misc) You specified an odd number of elements to initialize a hash,
2550 which is odd, because hashes come in key/value pairs.
2551
2552 =item Offset outside string
2553
2554 (F) You tried to do a read/write/send/recv operation with an offset
2555 pointing outside the buffer.  This is difficult to imagine.  The sole
2556 exception to this is that C<sysread()>ing past the buffer will extend
2557 the buffer and zero pad the new area.
2558
2559 =item %s() on unopened %s
2560
2561 (W unopened) An I/O operation was attempted on a filehandle that was
2562 never initialized.  You need to do an open(), a sysopen(), or a socket()
2563 call, or call a constructor from the FileHandle package.
2564
2565 =item -%s on unopened filehandle %s
2566
2567 (W unopened) You tried to invoke a file test operator on a filehandle
2568 that isn't open.  Check your control flow.  See also L<perlfunc/-X>.
2569
2570 =item oops: oopsAV
2571
2572 (S internal) An internal warning that the grammar is screwed up.
2573
2574 =item oops: oopsHV
2575
2576 (S internal) An internal warning that the grammar is screwed up.
2577
2578 =item Operation `%s': no method found, %s
2579
2580 (F) An attempt was made to perform an overloaded operation for which no
2581 handler was defined.  While some handlers can be autogenerated in terms
2582 of other handlers, there is no default handler for any operation, unless
2583 C<fallback> overloading key is specified to be true.  See L<overload>.
2584
2585 =item Operator or semicolon missing before %s
2586
2587 (S ambiguous) You used a variable or subroutine call where the parser
2588 was expecting an operator.  The parser has assumed you really meant to
2589 use an operator, but this is highly likely to be incorrect.  For
2590 example, if you say "*foo *foo" it will be interpreted as if you said
2591 "*foo * 'foo'".
2592
2593 =item "our" variable %s redeclared
2594
2595 (W misc) You seem to have already declared the same global once before
2596 in the current lexical scope.
2597
2598 =item Out of memory!
2599
2600 (X) The malloc() function returned 0, indicating there was insufficient
2601 remaining memory (or virtual memory) to satisfy the request.  Perl has
2602 no option but to exit immediately.
2603
2604 At least in Unix you may be able to get past this by increasing your
2605 process datasize limits: in csh/tcsh use C<limit> and
2606 C<limit datasize n> (where C<n> is the number of kilobytes) to check
2607 the current limits and change them, and in ksh/bash/zsh use C<ulimit -a>
2608 and C<ulimit -d n>, respectively.
2609
2610 =item Out of memory during "large" request for %s
2611
2612 (F) The malloc() function returned 0, indicating there was insufficient
2613 remaining memory (or virtual memory) to satisfy the request. However,
2614 the request was judged large enough (compile-time default is 64K), so a
2615 possibility to shut down by trapping this error is granted.
2616
2617 =item Out of memory during request for %s
2618
2619 (X|F) The malloc() function returned 0, indicating there was
2620 insufficient remaining memory (or virtual memory) to satisfy the
2621 request.
2622
2623 The request was judged to be small, so the possibility to trap it
2624 depends on the way perl was compiled.  By default it is not trappable.
2625 However, if compiled for this, Perl may use the contents of C<$^M> as an
2626 emergency pool after die()ing with this message.  In this case the error
2627 is trappable I<once>, and the error message will include the line and file
2628 where the failed request happened.
2629
2630 =item Out of memory during ridiculously large request
2631
2632 (F) You can't allocate more than 2^31+"small amount" bytes.  This error
2633 is most likely to be caused by a typo in the Perl program. e.g.,
2634 C<$arr[time]> instead of C<$arr[$time]>.
2635
2636 =item Out of memory for yacc stack
2637
2638 (F) The yacc parser wanted to grow its stack so it could continue
2639 parsing, but realloc() wouldn't give it more memory, virtual or
2640 otherwise.
2641
2642 =item '@' outside of string in unpack
2643
2644 (F) You had a template that specified an absolute position outside
2645 the string being unpacked.  See L<perlfunc/pack>.
2646
2647 =item %s package attribute may clash with future reserved word: %s
2648
2649 (W reserved) A lowercase attribute name was used that had a
2650 package-specific handler.  That name might have a meaning to Perl itself
2651 some day, even though it doesn't yet.  Perhaps you should use a
2652 mixed-case attribute name, instead.  See L<attributes>.
2653
2654 =item pack/unpack repeat count overflow
2655
2656 (F) You can't specify a repeat count so large that it overflows your
2657 signed integers.  See L<perlfunc/pack>.
2658
2659 =item page overflow
2660
2661 (W io) A single call to write() produced more lines than can fit on a
2662 page.  See L<perlform>.
2663
2664 =item panic: %s
2665
2666 (P) An internal error.
2667
2668 =item panic: ck_grep
2669
2670 (P) Failed an internal consistency check trying to compile a grep.
2671
2672 =item panic: ck_split
2673
2674 (P) Failed an internal consistency check trying to compile a split.
2675
2676 =item panic: corrupt saved stack index
2677
2678 (P) The savestack was requested to restore more localized values than
2679 there are in the savestack.
2680
2681 =item panic: del_backref
2682
2683 (P) Failed an internal consistency check while trying to reset a weak
2684 reference.
2685
2686 =item panic: Devel::DProf inconsistent subroutine return
2687
2688 (P) Devel::DProf called a subroutine that exited using goto(LABEL),
2689 last(LABEL) or next(LABEL). Leaving that way a subroutine called from
2690 an XSUB will lead very probably to a crash of the interpreter. This is
2691 a bug that will hopefully one day get fixed.
2692
2693 =item panic: die %s
2694
2695 (P) We popped the context stack to an eval context, and then discovered
2696 it wasn't an eval context.
2697
2698 =item panic: do_subst
2699
2700 (P) The internal pp_subst() routine was called with invalid operational
2701 data.
2702
2703 =item panic: do_trans_%s
2704
2705 (P) The internal do_trans routines were called with invalid operational
2706 data.
2707
2708 =item panic: frexp
2709
2710 (P) The library function frexp() failed, making printf("%f") impossible.
2711
2712 =item panic: goto
2713
2714 (P) We popped the context stack to a context with the specified label,
2715 and then discovered it wasn't a context we know how to do a goto in.
2716
2717 =item panic: INTERPCASEMOD
2718
2719 (P) The lexer got into a bad state at a case modifier.
2720
2721 =item panic: INTERPCONCAT
2722
2723 (P) The lexer got into a bad state parsing a string with brackets.
2724
2725 =item panic: kid popen errno read
2726
2727 (F) forked child returned an incomprehensible message about its errno.
2728
2729 =item panic: last
2730
2731 (P) We popped the context stack to a block context, and then discovered
2732 it wasn't a block context.
2733
2734 =item panic: leave_scope clearsv
2735
2736 (P) A writable lexical variable became read-only somehow within the
2737 scope.
2738
2739 =item panic: leave_scope inconsistency
2740
2741 (P) The savestack probably got out of sync.  At least, there was an
2742 invalid enum on the top of it.
2743
2744 =item panic: magic_killbackrefs
2745
2746 (P) Failed an internal consistency check while trying to reset all weak
2747 references to an object.
2748
2749 =item panic: malloc
2750
2751 (P) Something requested a negative number of bytes of malloc.
2752
2753 =item panic: mapstart
2754
2755 (P) The compiler is screwed up with respect to the map() function.
2756
2757 =item panic: null array
2758
2759 (P) One of the internal array routines was passed a null AV pointer.
2760
2761 =item panic: pad_alloc
2762
2763 (P) The compiler got confused about which scratch pad it was allocating
2764 and freeing temporaries and lexicals from.
2765
2766 =item panic: pad_free curpad
2767
2768 (P) The compiler got confused about which scratch pad it was allocating
2769 and freeing temporaries and lexicals from.
2770
2771 =item panic: pad_free po
2772
2773 (P) An invalid scratch pad offset was detected internally.
2774
2775 =item panic: pad_reset curpad
2776
2777 (P) The compiler got confused about which scratch pad it was allocating
2778 and freeing temporaries and lexicals from.
2779
2780 =item panic: pad_sv po
2781
2782 (P) An invalid scratch pad offset was detected internally.
2783
2784 =item panic: pad_swipe curpad
2785
2786 (P) The compiler got confused about which scratch pad it was allocating
2787 and freeing temporaries and lexicals from.
2788
2789 =item panic: pad_swipe po
2790
2791 (P) An invalid scratch pad offset was detected internally.
2792
2793 =item panic: pp_iter
2794
2795 (P) The foreach iterator got called in a non-loop context frame.
2796
2797 =item panic: pp_match%s
2798
2799 (P) The internal pp_match() routine was called with invalid operational
2800 data.
2801
2802 =item panic: pp_split
2803
2804 (P) Something terrible went wrong in setting up for the split.
2805
2806 =item panic: realloc
2807
2808 (P) Something requested a negative number of bytes of realloc.
2809
2810 =item panic: restartop
2811
2812 (P) Some internal routine requested a goto (or something like it), and
2813 didn't supply the destination.
2814
2815 =item panic: return
2816
2817 (P) We popped the context stack to a subroutine or eval context, and
2818 then discovered it wasn't a subroutine or eval context.
2819
2820 =item panic: scan_num
2821
2822 (P) scan_num() got called on something that wasn't a number.
2823
2824 =item panic: sv_insert
2825
2826 (P) The sv_insert() routine was told to remove more string than there
2827 was string.
2828
2829 =item panic: top_env
2830
2831 (P) The compiler attempted to do a goto, or something weird like that.
2832
2833 =item panic: utf16_to_utf8: odd bytelen
2834
2835 (P) Something tried to call utf16_to_utf8 with an odd (as opposed
2836 to even) byte length.
2837
2838 =item panic: yylex
2839
2840 (P) The lexer got into a bad state while processing a case modifier.
2841
2842 =item Parentheses missing around "%s" list
2843
2844 (W parenthesis) You said something like
2845
2846     my $foo, $bar = @_;
2847
2848 when you meant
2849
2850     my ($foo, $bar) = @_;
2851
2852 Remember that "my", "our", and "local" bind tighter than comma.
2853
2854 =item C<-p> destination: %s
2855
2856 (F) An error occurred during the implicit output invoked by the C<-p>
2857 command-line switch.  (This output goes to STDOUT unless you've
2858 redirected it with select().)
2859
2860 =item (perhaps you forgot to load "%s"?)
2861
2862 (F) This is an educated guess made in conjunction with the message
2863 "Can't locate object method \"%s\" via package \"%s\"".  It often means
2864 that a method requires a package that has not been loaded.
2865
2866 =item Perl %s required--this is only version %s, stopped
2867
2868 (F) The module in question uses features of a version of Perl more
2869 recent than the currently running version.  How long has it been since
2870 you upgraded, anyway?  See L<perlfunc/require>.
2871
2872 =item PERL_SH_DIR too long
2873
2874 (F) An error peculiar to OS/2. PERL_SH_DIR is the directory to find the
2875 C<sh>-shell in.  See "PERL_SH_DIR" in L<perlos2>.
2876
2877 =item PERL_SIGNALS illegal: "%s"
2878
2879 See L<perlrun/PERL_SIGNALS> for legal values.
2880
2881 =item perl: warning: Setting locale failed.
2882
2883 (S) The whole warning message will look something like:
2884
2885         perl: warning: Setting locale failed.
2886         perl: warning: Please check that your locale settings:
2887                 LC_ALL = "En_US",
2888                 LANG = (unset)
2889             are supported and installed on your system.
2890         perl: warning: Falling back to the standard locale ("C").
2891
2892 Exactly what were the failed locale settings varies.  In the above the
2893 settings were that the LC_ALL was "En_US" and the LANG had no value.
2894 This error means that Perl detected that you and/or your operating
2895 system supplier and/or system administrator have set up the so-called
2896 locale system but Perl could not use those settings.  This was not
2897 dead serious, fortunately: there is a "default locale" called "C" that
2898 Perl can and will use, the script will be run.  Before you really fix
2899 the problem, however, you will get the same error message each time
2900 you run Perl.  How to really fix the problem can be found in
2901 L<perllocale> section B<LOCALE PROBLEMS>.
2902
2903 =item Permission denied
2904
2905 (F) The setuid emulator in suidperl decided you were up to no good.
2906
2907 =item pid %x not a child
2908
2909 (W exec) A warning peculiar to VMS.  Waitpid() was asked to wait for a
2910 process which isn't a subprocess of the current process.  While this is
2911 fine from VMS' perspective, it's probably not what you intended.
2912
2913 =item 'P' must have an explicit size in unpack
2914
2915 (F) The unpack format P must have an explicit size, not "*".
2916
2917 =item B<-P> not allowed for setuid/setgid script
2918
2919 (F) The script would have to be opened by the C preprocessor by name,
2920 which provides a race condition that breaks security.
2921
2922 =item POSIX class [:%s:] unknown in regex; marked by <-- HERE in m/%s/
2923
2924 (F) The class in the character class [: :] syntax is unknown.  The <-- HERE
2925 shows in the regular expression about where the problem was discovered.
2926 Note that the POSIX character classes do B<not> have the C<is> prefix
2927 the corresponding C interfaces have: in other words, it's C<[[:print:]]>,
2928 not C<isprint>.  See L<perlre>.
2929
2930 =item POSIX getpgrp can't take an argument
2931
2932 (F) Your system has POSIX getpgrp(), which takes no argument, unlike
2933 the BSD version, which takes a pid.
2934
2935 =item POSIX syntax [%s] belongs inside character classes in regex; marked by <-- HERE in m/%s/
2936
2937 (W regexp) The character class constructs [: :], [= =], and [. .]  go
2938 I<inside> character classes, the [] are part of the construct, for example:
2939 /[012[:alpha:]345]/.  Note that [= =] and [. .] are not currently
2940 implemented; they are simply placeholders for future extensions and will
2941 cause fatal errors.  The <-- HERE shows in the regular expression about
2942 where the problem was discovered.  See L<perlre>.
2943
2944 =item POSIX syntax [. .] is reserved for future extensions in regex; marked by <-- HERE in m/%s/
2945
2946 (F regexp) Within regular expression character classes ([]) the syntax
2947 beginning with "[." and ending with ".]" is reserved for future extensions.
2948 If you need to represent those character sequences inside a regular
2949 expression character class, just quote the square brackets with the
2950 backslash: "\[." and ".\]".  The <-- HERE shows in the regular expression
2951 about where the problem was discovered.  See L<perlre>.
2952
2953 =item POSIX syntax [= =] is reserved for future extensions in regex; marked by <-- HERE in m/%s/
2954
2955 (F) Within regular expression character classes ([]) the syntax beginning
2956 with "[=" and ending with "=]" is reserved for future extensions.  If you
2957 need to represent those character sequences inside a regular expression
2958 character class, just quote the square brackets with the backslash: "\[="
2959 and "=\]".  The <-- HERE shows in the regular expression about where the
2960 problem was discovered.  See L<perlre>.
2961
2962 =item Possible attempt to put comments in qw() list
2963
2964 (W qw) qw() lists contain items separated by whitespace; as with literal
2965 strings, comment characters are not ignored, but are instead treated as
2966 literal data.  (You may have used different delimiters than the
2967 parentheses shown here; braces are also frequently used.)
2968
2969 You probably wrote something like this:
2970
2971     @list = qw(
2972         a # a comment
2973         b # another comment
2974     );
2975
2976 when you should have written this:
2977
2978     @list = qw(
2979         a
2980         b
2981     );
2982
2983 If you really want comments, build your list the
2984 old-fashioned way, with quotes and commas:
2985
2986     @list = (
2987         'a',    # a comment
2988         'b',    # another comment
2989     );
2990
2991 =item Possible attempt to separate words with commas
2992
2993 (W qw) qw() lists contain items separated by whitespace; therefore
2994 commas aren't needed to separate the items.  (You may have used
2995 different delimiters than the parentheses shown here; braces are also
2996 frequently used.)
2997
2998 You probably wrote something like this:
2999
3000     qw! a, b, c !;
3001
3002 which puts literal commas into some of the list items.  Write it without
3003 commas if you don't want them to appear in your data:
3004
3005     qw! a b c !;
3006
3007 =item Possible memory corruption: %s overflowed 3rd argument
3008
3009 (F) An ioctl() or fcntl() returned more than Perl was bargaining for.
3010 Perl guesses a reasonable buffer size, but puts a sentinel byte at the
3011 end of the buffer just in case.  This sentinel byte got clobbered, and
3012 Perl assumes that memory is now corrupted.  See L<perlfunc/ioctl>.
3013
3014 =item Possible precedence problem on bitwise %c operator
3015
3016 (W precedence) Your program uses a bitwise logical operator in conjunction
3017 with a numeric comparison operator, like this :
3018
3019     if ($x & $y == 0) { ... }
3020
3021 This expression is actually equivalent to C<$x & ($y == 0)>, due to the
3022 higher precedence of C<==>. This is probably not what you want. (If you
3023 really meant to write this, disable the warning, or, better, put the
3024 parentheses explicitly and write C<$x & ($y == 0)>).
3025
3026 =item Possible unintended interpolation of %s in string
3027
3028 (W ambiguous) You said something like `@foo' in a double-quoted string
3029 but there was no array C<@foo> in scope at the time. If you wanted a
3030 literal @foo, then write it as \@foo; otherwise find out what happened
3031 to the array you apparently lost track of.
3032
3033 =item Possible Y2K bug: %s
3034
3035 (W y2k) You are concatenating the number 19 with another number, which
3036 could be a potential Year 2000 problem.
3037
3038 =item pragma "attrs" is deprecated, use "sub NAME : ATTRS" instead
3039
3040 (D deprecated) You have written something like this:
3041
3042     sub doit
3043     {
3044         use attrs qw(locked);
3045     }
3046
3047 You should use the new declaration syntax instead.
3048
3049     sub doit : locked
3050     {
3051         ...
3052
3053 The C<use attrs> pragma is now obsolete, and is only provided for
3054 backward-compatibility. See L<perlsub/"Subroutine Attributes">.
3055
3056 =item Precedence problem: open %s should be open(%s)
3057
3058 (S precedence) The old irregular construct
3059
3060     open FOO || die;
3061
3062 is now misinterpreted as
3063
3064     open(FOO || die);
3065
3066 because of the strict regularization of Perl 5's grammar into unary and
3067 list operators.  (The old open was a little of both.)  You must put
3068 parentheses around the filehandle, or use the new "or" operator instead
3069 of "||".
3070
3071 =item Premature end of script headers
3072
3073 See Server error.
3074
3075 =item printf() on closed filehandle %s
3076
3077 (W closed) The filehandle you're writing to got itself closed sometime
3078 before now.  Check your control flow.
3079
3080 =item print() on closed filehandle %s
3081
3082 (W closed) The filehandle you're printing on got itself closed sometime
3083 before now.  Check your control flow.
3084
3085 =item Process terminated by SIG%s
3086
3087 (W) This is a standard message issued by OS/2 applications, while *nix
3088 applications die in silence.  It is considered a feature of the OS/2
3089 port.  One can easily disable this by appropriate sighandlers, see
3090 L<perlipc/"Signals">.  See also "Process terminated by SIGTERM/SIGINT"
3091 in L<perlos2>.
3092
3093 =item Prototype mismatch: %s vs %s
3094
3095 (S prototype) The subroutine being declared or defined had previously been
3096 declared or defined with a different function prototype.
3097
3098 =item Prototype not terminated
3099
3100 (F) You've omitted the closing parenthesis in a function prototype
3101 definition.
3102
3103 =item Quantifier follows nothing in regex; marked by <-- HERE in m/%s/
3104
3105 (F) You started a regular expression with a quantifier. Backslash it if you
3106 meant it literally. The <-- HERE shows in the regular expression about
3107 where the problem was discovered. See L<perlre>.
3108
3109 =item Quantifier in {,} bigger than %d in regex; marked by <-- HERE in m/%s/
3110
3111 (F) There is currently a limit to the size of the min and max values of the
3112 {min,max} construct. The <-- HERE shows in the regular expression about where
3113 the problem was discovered. See L<perlre>.
3114
3115 =item Quantifier unexpected on zero-length expression; marked by <-- HERE in m/%s/
3116
3117 (W regexp) You applied a regular expression quantifier in a place where
3118 it makes no sense, such as on a zero-width assertion.  Try putting the
3119 quantifier inside the assertion instead.  For example, the way to match
3120 "abc" provided that it is followed by three repetitions of "xyz" is
3121 C</abc(?=(?:xyz){3})/>, not C</abc(?=xyz){3}/>.
3122
3123 The <-- HERE shows in the regular expression about where the problem was
3124 discovered.
3125
3126 =item Range iterator outside integer range
3127
3128 (F) One (or both) of the numeric arguments to the range operator ".."
3129 are outside the range which can be represented by integers internally.
3130 One possible workaround is to force Perl to use magical string increment
3131 by prepending "0" to your numbers.
3132
3133 =item readline() on closed filehandle %s
3134
3135 (W closed) The filehandle you're reading from got itself closed sometime
3136 before now.  Check your control flow.
3137
3138 =item read() on closed filehandle %s
3139
3140 (W closed) You tried to read from a closed filehandle.
3141
3142 =item read() on unopened filehandle %s
3143
3144 (W unopened) You tried to read from a filehandle that was never opened.
3145
3146 =item Reallocation too large: %lx
3147
3148 (F) You can't allocate more than 64K on an MS-DOS machine.
3149
3150 =item realloc() of freed memory ignored
3151
3152 (S malloc) An internal routine called realloc() on something that had
3153 already been freed.
3154
3155 =item Recompile perl with B<-D>DEBUGGING to use B<-D> switch
3156
3157 (F debugging) You can't use the B<-D> option unless the code to produce
3158 the desired output is compiled into Perl, which entails some overhead,
3159 which is why it's currently left out of your copy.
3160
3161 =item Recursive inheritance detected in package '%s'
3162
3163 (F) More than 100 levels of inheritance were used.  Probably indicates
3164 an unintended loop in your inheritance hierarchy.
3165
3166 =item Recursive inheritance detected while looking for method %s
3167
3168 (F) More than 100 levels of inheritance were encountered while invoking
3169 a method.  Probably indicates an unintended loop in your inheritance
3170 hierarchy.
3171
3172 =item Reference found where even-sized list expected
3173
3174 (W misc) You gave a single reference where Perl was expecting a list
3175 with an even number of elements (for assignment to a hash). This usually
3176 means that you used the anon hash constructor when you meant to use
3177 parens. In any case, a hash requires key/value B<pairs>.
3178
3179     %hash = { one => 1, two => 2, };    # WRONG
3180     %hash = [ qw/ an anon array / ];    # WRONG
3181     %hash = ( one => 1, two => 2, );    # right
3182     %hash = qw( one 1 two 2 );                  # also fine
3183
3184 =item Reference is already weak
3185
3186 (W misc) You have attempted to weaken a reference that is already weak.
3187 Doing so has no effect.
3188
3189 =item Reference miscount in sv_replace()
3190
3191 (W internal) The internal sv_replace() function was handed a new SV with
3192 a reference count of other than 1.
3193
3194 =item Reference to nonexistent group in regex; marked by <-- HERE in m/%s/
3195
3196 (F) You used something like C<\7> in your regular expression, but there are
3197 not at least seven sets of capturing parentheses in the expression. If you
3198 wanted to have the character with value 7 inserted into the regular expression,
3199 prepend a zero to make the number at least two digits: C<\07>
3200
3201 The <-- HERE shows in the regular expression about where the problem was
3202 discovered.
3203
3204 =item regexp memory corruption
3205
3206 (P) The regular expression engine got confused by what the regular
3207 expression compiler gave it.
3208
3209 =item Regexp out of space
3210
3211 (P) A "can't happen" error, because safemalloc() should have caught it
3212 earlier.
3213
3214 =item Reversed %s= operator
3215
3216 (W syntax) You wrote your assignment operator backwards.  The = must
3217 always comes last, to avoid ambiguity with subsequent unary operators.
3218
3219 =item Runaway format
3220
3221 (F) Your format contained the ~~ repeat-until-blank sequence, but it
3222 produced 200 lines at once, and the 200th line looked exactly like the
3223 199th line.  Apparently you didn't arrange for the arguments to exhaust
3224 themselves, either by using ^ instead of @ (for scalar variables), or by
3225 shifting or popping (for array variables).  See L<perlform>.
3226
3227 =item Scalars leaked: %d
3228
3229 (P) Something went wrong in Perl's internal bookkeeping of scalars:
3230 not all scalar variables were deallocated by the time Perl exited.
3231 What this usually indicates is a memory leak, which is of course bad,
3232 especially if the Perl program is intended to be long-running.
3233
3234 =item Scalar value @%s[%s] better written as $%s[%s]
3235
3236 (W syntax) You've used an array slice (indicated by @) to select a
3237 single element of an array.  Generally it's better to ask for a scalar
3238 value (indicated by $).  The difference is that C<$foo[&bar]> always
3239 behaves like a scalar, both when assigning to it and when evaluating its
3240 argument, while C<@foo[&bar]> behaves like a list when you assign to it,
3241 and provides a list context to its subscript, which can do weird things
3242 if you're expecting only one subscript.
3243
3244 On the other hand, if you were actually hoping to treat the array
3245 element as a list, you need to look into how references work, because
3246 Perl will not magically convert between scalars and lists for you.  See
3247 L<perlref>.
3248
3249 =item Scalar value @%s{%s} better written as $%s{%s}
3250
3251 (W syntax) You've used a hash slice (indicated by @) to select a single
3252 element of a hash.  Generally it's better to ask for a scalar value
3253 (indicated by $).  The difference is that C<$foo{&bar}> always behaves
3254 like a scalar, both when assigning to it and when evaluating its
3255 argument, while C<@foo{&bar}> behaves like a list when you assign to it,
3256 and provides a list context to its subscript, which can do weird things
3257 if you're expecting only one subscript.
3258
3259 On the other hand, if you were actually hoping to treat the hash element
3260 as a list, you need to look into how references work, because Perl will
3261 not magically convert between scalars and lists for you.  See
3262 L<perlref>.
3263
3264 =item Script is not setuid/setgid in suidperl
3265
3266 (F) Oddly, the suidperl program was invoked on a script without a setuid
3267 or setgid bit set.  This doesn't make much sense.
3268
3269 =item Search pattern not terminated
3270
3271 (F) The lexer couldn't find the final delimiter of a // or m{}
3272 construct.  Remember that bracketing delimiters count nesting level.
3273 Missing the leading C<$> from a variable C<$m> may cause this error.
3274
3275 Note that since Perl 5.9.0 a // can also be the I<defined-or>
3276 construct, not just the empty search pattern.  Therefore code written
3277 in Perl 5.9.0 or later that uses the // as the I<defined-or> can be
3278 misparsed by pre-5.9.0 Perls as a non-terminated search pattern.
3279
3280 =item %sseek() on unopened filehandle
3281
3282 (W unopened) You tried to use the seek() or sysseek() function on a
3283 filehandle that was either never opened or has since been closed.
3284
3285 =item select not implemented
3286
3287 (F) This machine doesn't implement the select() system call.
3288
3289 =item Self-ties of arrays and hashes are not supported
3290
3291 (F) Self-ties are of arrays and hashes are not supported in
3292 the current implementation.
3293
3294 =item Semicolon seems to be missing
3295
3296 (W semicolon) A nearby syntax error was probably caused by a missing
3297 semicolon, or possibly some other missing operator, such as a comma.
3298
3299 =item semi-panic: attempt to dup freed string
3300
3301 (S internal) The internal newSVsv() routine was called to duplicate a
3302 scalar that had previously been marked as free.
3303
3304 =item sem%s not implemented
3305
3306 (F) You don't have System V semaphore IPC on your system.
3307
3308 =item send() on closed socket %s
3309
3310 (W closed) The socket you're sending to got itself closed sometime
3311 before now.  Check your control flow.
3312
3313 =item Sequence (? incomplete in regex; marked by <-- HERE in m/%s/
3314
3315 (F) A regular expression ended with an incomplete extension (?. The <-- HERE
3316 shows in the regular expression about where the problem was discovered. See
3317 L<perlre>.
3318
3319 =item Sequence (?%s...) not implemented in regex; marked by <-- HERE in m/%s/
3320
3321 (F) A proposed regular expression extension has the character reserved but
3322 has not yet been written. The <-- HERE shows in the regular expression about
3323 where the problem was discovered. See L<perlre>.
3324
3325 =item Sequence (?%s...) not recognized in regex; marked by <-- HERE in m/%s/
3326
3327 (F) You used a regular expression extension that doesn't make sense.  The
3328 <-- HERE shows in the regular expression about where the problem was
3329 discovered.  See L<perlre>.
3330
3331 =item Sequence (?#... not terminated in regex; marked by <-- HERE in m/%s/
3332
3333 (F) A regular expression comment must be terminated by a closing
3334 parenthesis.  Embedded parentheses aren't allowed.  The <-- HERE shows in
3335 the regular expression about where the problem was discovered. See
3336 L<perlre>.
3337
3338 =item Sequence (?{...}) not terminated or not {}-balanced in regex; marked by <-- HERE in m/%s/
3339
3340 (F) If the contents of a (?{...}) clause contains braces, they must balance
3341 for Perl to properly detect the end of the clause. The <-- HERE shows in
3342 the regular expression about where the problem was discovered. See
3343 L<perlre>.
3344
3345 =item 500 Server error
3346
3347 See Server error.
3348
3349 =item Server error
3350
3351 This is the error message generally seen in a browser window when trying
3352 to run a CGI program (including SSI) over the web. The actual error text
3353 varies widely from server to server. The most frequently-seen variants
3354 are "500 Server error", "Method (something) not permitted", "Document
3355 contains no data", "Premature end of script headers", and "Did not
3356 produce a valid header".
3357
3358 B<This is a CGI error, not a Perl error>.
3359
3360 You need to make sure your script is executable, is accessible by the
3361 user CGI is running the script under (which is probably not the user
3362 account you tested it under), does not rely on any environment variables
3363 (like PATH) from the user it isn't running under, and isn't in a
3364 location where the CGI server can't find it, basically, more or less.
3365 Please see the following for more information:
3366
3367         http://www.perl.org/CGI_MetaFAQ.html
3368         http://www.htmlhelp.org/faq/cgifaq.html
3369         http://www.w3.org/Security/Faq/
3370
3371 You should also look at L<perlfaq9>.
3372
3373 =item setegid() not implemented
3374
3375 (F) You tried to assign to C<$)>, and your operating system doesn't
3376 support the setegid() system call (or equivalent), or at least Configure
3377 didn't think so.
3378
3379 =item seteuid() not implemented
3380
3381 (F) You tried to assign to C<< $> >>, and your operating system doesn't
3382 support the seteuid() system call (or equivalent), or at least Configure
3383 didn't think so.
3384
3385 =item setpgrp can't take arguments
3386
3387 (F) Your system has the setpgrp() from BSD 4.2, which takes no
3388 arguments, unlike POSIX setpgid(), which takes a process ID and process
3389 group ID.
3390
3391 =item setrgid() not implemented
3392
3393 (F) You tried to assign to C<$(>, and your operating system doesn't
3394 support the setrgid() system call (or equivalent), or at least Configure
3395 didn't think so.
3396
3397 =item setruid() not implemented
3398
3399 (F) You tried to assign to C<$<>, and your operating system doesn't
3400 support the setruid() system call (or equivalent), or at least Configure
3401 didn't think so.
3402
3403 =item setsockopt() on closed socket %s
3404
3405 (W closed) You tried to set a socket option on a closed socket.  Did you
3406 forget to check the return value of your socket() call?  See
3407 L<perlfunc/setsockopt>.
3408
3409 =item Setuid/gid script is writable by world
3410
3411 (F) The setuid emulator won't run a script that is writable by the
3412 world, because the world might have written on it already.
3413
3414 =item shm%s not implemented
3415
3416 (F) You don't have System V shared memory IPC on your system.
3417
3418 =item <> should be quotes
3419
3420 (F) You wrote C<< require <file> >> when you should have written
3421 C<require 'file'>.
3422
3423 =item /%s/ should probably be written as "%s"
3424
3425 (W syntax) You have used a pattern where Perl expected to find a string,
3426 as in the first argument to C<join>.  Perl will treat the true or false
3427 result of matching the pattern against $_ as the string, which is
3428 probably not what you had in mind.
3429
3430 =item shutdown() on closed socket %s
3431
3432 (W closed) You tried to do a shutdown on a closed socket.  Seems a bit
3433 superfluous.
3434
3435 =item SIG%s handler "%s" not defined
3436
3437 (W signal) The signal handler named in %SIG doesn't, in fact, exist.
3438 Perhaps you put it into the wrong package?
3439
3440 =item sort is now a reserved word
3441
3442 (F) An ancient error message that almost nobody ever runs into anymore.
3443 But before sort was a keyword, people sometimes used it as a filehandle.
3444
3445 =item Sort subroutine didn't return a numeric value
3446
3447 (F) A sort comparison routine must return a number.  You probably blew
3448 it by not using C<< <=> >> or C<cmp>, or by not using them correctly.
3449 See L<perlfunc/sort>.
3450
3451 =item Sort subroutine didn't return single value
3452
3453 (F) A sort comparison subroutine may not return a list value with more
3454 or less than one element.  See L<perlfunc/sort>.
3455
3456 =item splice() offset past end of array
3457
3458 (W misc) You attempted to specify an offset that was past the end of
3459 the array passed to splice(). Splicing will instead commence at the end
3460 of the array, rather than past it. If this isn't what you want, try
3461 explicitly pre-extending the array by assigning $#array = $offset. See
3462 L<perlfunc/splice>.
3463
3464 =item Split loop
3465
3466 (P) The split was looping infinitely.  (Obviously, a split shouldn't
3467 iterate more times than there are characters of input, which is what
3468 happened.) See L<perlfunc/split>.
3469
3470 =item Statement unlikely to be reached
3471
3472 (W exec) You did an exec() with some statement after it other than a
3473 die().  This is almost always an error, because exec() never returns
3474 unless there was a failure.  You probably wanted to use system()
3475 instead, which does return.  To suppress this warning, put the exec() in
3476 a block by itself.
3477
3478 =item stat() on unopened filehandle %s
3479
3480 (W unopened) You tried to use the stat() function on a filehandle that
3481 was either never opened or has since been closed.
3482
3483 =item Stub found while resolving method `%s' overloading %s
3484
3485 (P) Overloading resolution over @ISA tree may be broken by importation
3486 stubs.  Stubs should never be implicitly created, but explicit calls to
3487 C<can> may break this.
3488
3489 =item Subroutine %s redefined
3490
3491 (W redefine) You redefined a subroutine.  To suppress this warning, say
3492
3493     {
3494         no warnings 'redefine';
3495         eval "sub name { ... }";
3496     }
3497
3498 =item Substitution loop
3499
3500 (P) The substitution was looping infinitely.  (Obviously, a substitution
3501 shouldn't iterate more times than there are characters of input, which
3502 is what happened.)  See the discussion of substitution in
3503 L<perlop/"Quote and Quote-like Operators">.
3504
3505 =item Substitution pattern not terminated
3506
3507 (F) The lexer couldn't find the interior delimiter of an s/// or s{}{}
3508 construct.  Remember that bracketing delimiters count nesting level.
3509 Missing the leading C<$> from variable C<$s> may cause this error.
3510
3511 =item Substitution replacement not terminated
3512
3513 (F) The lexer couldn't find the final delimiter of an s/// or s{}{}
3514 construct.  Remember that bracketing delimiters count nesting level.
3515 Missing the leading C<$> from variable C<$s> may cause this error.
3516
3517 =item substr outside of string
3518
3519 (W substr),(F) You tried to reference a substr() that pointed outside of
3520 a string.  That is, the absolute value of the offset was larger than the
3521 length of the string.  See L<perlfunc/substr>.  This warning is fatal if
3522 substr is used in an lvalue context (as the left hand side of an
3523 assignment or as a subroutine argument for example).
3524
3525 =item suidperl is no longer needed since %s
3526
3527 (F) Your Perl was compiled with B<-D>SETUID_SCRIPTS_ARE_SECURE_NOW, but
3528 a version of the setuid emulator somehow got run anyway.
3529
3530 =item Switch (?(condition)... contains too many branches in regex; marked by <-- HERE in m/%s/
3531
3532 (F) A (?(condition)if-clause|else-clause) construct can have at most two
3533 branches (the if-clause and the else-clause). If you want one or both to
3534 contain alternation, such as using C<this|that|other>, enclose it in
3535 clustering parentheses:
3536
3537     (?(condition)(?:this|that|other)|else-clause)
3538
3539 The <-- HERE shows in the regular expression about where the problem was
3540 discovered. See L<perlre>.
3541
3542 =item Switch condition not recognized in regex; marked by <-- HERE in m/%s/
3543
3544 (F) If the argument to the (?(...)if-clause|else-clause) construct is a
3545 number, it can be only a number. The <-- HERE shows in the regular expression
3546 about where the problem was discovered. See L<perlre>.
3547
3548 =item switching effective %s is not implemented
3549
3550 (F) While under the C<use filetest> pragma, we cannot switch the real
3551 and effective uids or gids.
3552
3553 =item %s syntax
3554
3555 (F) The final summary message when a C<perl -c> succeeds.
3556
3557 =item syntax error
3558
3559 (F) Probably means you had a syntax error.  Common reasons include:
3560
3561     A keyword is misspelled.
3562     A semicolon is missing.
3563     A comma is missing.
3564     An opening or closing parenthesis is missing.
3565     An opening or closing brace is missing.
3566     A closing quote is missing.
3567
3568 Often there will be another error message associated with the syntax
3569 error giving more information.  (Sometimes it helps to turn on B<-w>.)
3570 The error message itself often tells you where it was in the line when
3571 it decided to give up.  Sometimes the actual error is several tokens
3572 before this, because Perl is good at understanding random input.
3573 Occasionally the line number may be misleading, and once in a blue moon
3574 the only way to figure out what's triggering the error is to call
3575 C<perl -c> repeatedly, chopping away half the program each time to see
3576 if the error went away.  Sort of the cybernetic version of S<20
3577 questions>.
3578
3579 =item syntax error at line %d: `%s' unexpected
3580
3581 (A) You've accidentally run your script through the Bourne shell instead
3582 of Perl.  Check the #! line, or manually feed your script into Perl
3583 yourself.
3584
3585 =item syntax error in file %s at line %d, next 2 tokens "%s"
3586
3587 (F) This error is likely to occur if you run a perl5 script through
3588 a perl4 interpreter, especially if the next 2 tokens are "use strict"
3589 or "my $var" or "our $var".
3590
3591 =item sysread() on closed filehandle %s
3592
3593 (W closed) You tried to read from a closed filehandle.
3594
3595 =item sysread() on unopened filehandle %s
3596
3597 (W unopened) You tried to read from a filehandle that was never opened.
3598
3599 =item System V %s is not implemented on this machine
3600
3601 (F) You tried to do something with a function beginning with "sem",
3602 "shm", or "msg" but that System V IPC is not implemented in your
3603 machine.  In some machines the functionality can exist but be
3604 unconfigured.  Consult your system support.
3605
3606 =item syswrite() on closed filehandle %s
3607
3608 (W closed) The filehandle you're writing to got itself closed sometime
3609 before now.  Check your control flow.
3610
3611 =item C<-T> and C<-B> not implemented on filehandles
3612
3613 (F) Perl can't peek at the stdio buffer of filehandles when it doesn't
3614 know about your kind of stdio.  You'll have to use a filename instead.
3615
3616 =item Target of goto is too deeply nested
3617
3618 (F) You tried to use C<goto> to reach a label that was too deeply nested
3619 for Perl to reach.  Perl is doing you a favor by refusing.
3620
3621 =item tell() on unopened filehandle
3622
3623 (W unopened) You tried to use the tell() function on a filehandle that
3624 was either never opened or has since been closed.
3625
3626 =item That use of $[ is unsupported
3627
3628 (F) Assignment to C<$[> is now strictly circumscribed, and interpreted
3629 as a compiler directive.  You may say only one of
3630
3631     $[ = 0;
3632     $[ = 1;
3633     ...
3634     local $[ = 0;
3635     local $[ = 1;
3636     ...
3637
3638 This is to prevent the problem of one module changing the array base out
3639 from under another module inadvertently.  See L<perlvar/$[>.
3640
3641 =item The crypt() function is unimplemented due to excessive paranoia
3642
3643 (F) Configure couldn't find the crypt() function on your machine,
3644 probably because your vendor didn't supply it, probably because they
3645 think the U.S. Government thinks it's a secret, or at least that they
3646 will continue to pretend that it is.  And if you quote me on that, I
3647 will deny it.
3648
3649 =item The %s function is unimplemented
3650
3651 The function indicated isn't implemented on this architecture, according
3652 to the probings of Configure.
3653
3654 =item The stat preceding %s wasn't an lstat
3655
3656 (F) It makes no sense to test the current stat buffer for symbolic
3657 linkhood if the last stat that wrote to the stat buffer already went
3658 past the symlink to get to the real file.  Use an actual filename
3659 instead.
3660
3661 =item This Perl can't reset CRTL environ elements (%s)
3662
3663 =item This Perl can't set CRTL environ elements (%s=%s)
3664
3665 (W internal) Warnings peculiar to VMS.  You tried to change or delete an
3666 element of the CRTL's internal environ array, but your copy of Perl
3667 wasn't built with a CRTL that contained the setenv() function.  You'll
3668 need to rebuild Perl with a CRTL that does, or redefine
3669 F<PERL_ENV_TABLES> (see L<perlvms>) so that the environ array isn't the
3670 target of the change to
3671 %ENV which produced the warning.
3672
3673 =item thread failed to start: %s
3674
3675 (F) The entry point function of threads->create() failed for some reason.
3676
3677 =item Tied variable freed while still in use
3678
3679 (F) An access method for a tied variable (e.g. FETCH) did something to
3680 free the variable.  Since continuing the current operation is likely
3681 to result in a coredump, Perl is bailing out instead.
3682
3683 =item times not implemented
3684
3685 (F) Your version of the C library apparently doesn't do times().  I
3686 suspect you're not running on Unix.
3687
3688 =item To%s: illegal mapping '%s'
3689
3690 (F) You tried to define a customized To-mapping for lc(), lcfirst,
3691 uc(), or ucfirst() (or their string-inlined versions), but you
3692 specified an illegal mapping.
3693 See L<perlunicode/"User-Defined Character Properties">.
3694
3695 =item Too deeply nested ()-groups
3696
3697 (F) Your template contains ()-groups with a ridiculously deep nesting level. 
3698
3699 =item Too few args to syscall
3700
3701 (F) There has to be at least one argument to syscall() to specify the
3702 system call to call, silly dilly.
3703
3704 =item Too late for "-%s" option
3705
3706 (X) The #! line (or local equivalent) in a Perl script contains the
3707 B<-M> or B<-m> option.  This is an error because B<-M> and B<-m> options
3708 are not intended for use inside scripts.  Use the C<use> pragma instead.
3709
3710 =item Too late for "B<-T>" option
3711
3712 (X) The #! line (or local equivalent) in a Perl script contains the
3713 B<-T> option, but Perl was not invoked with B<-T> in its command line.
3714 This is an error because, by the time Perl discovers a B<-T> in a
3715 script, it's too late to properly taint everything from the environment.
3716 So Perl gives up.
3717
3718 If the Perl script is being executed as a command using the #!
3719 mechanism (or its local equivalent), this error can usually be fixed by
3720 editing the #! line so that the B<-T> option is a part of Perl's first
3721 argument: e.g. change C<perl -n -T> to C<perl -T -n>.
3722
3723 If the Perl script is being executed as C<perl scriptname>, then the
3724 B<-T> option must appear on the command line: C<perl -T scriptname>.
3725
3726 =item Too late to run %s block
3727
3728 (W void) A CHECK or INIT block is being defined during run time proper,
3729 when the opportunity to run them has already passed.  Perhaps you are
3730 loading a file with C<require> or C<do> when you should be using C<use>
3731 instead.  Or perhaps you should put the C<require> or C<do> inside a
3732 BEGIN block.
3733
3734 =item Too many args to syscall
3735
3736 (F) Perl supports a maximum of only 14 args to syscall().
3737
3738 =item Too many arguments for %s
3739
3740 (F) The function requires fewer arguments than you specified.
3741
3742 =item Too many )'s
3743
3744 (A) You've accidentally run your script through B<csh> instead of Perl.
3745 Check the #! line, or manually feed your script into Perl yourself.
3746
3747 =item Too many ('s
3748
3749 (A) You've accidentally run your script through B<csh> instead of Perl.
3750 Check the #! line, or manually feed your script into Perl yourself.
3751
3752 =item Trailing \ in regex m/%s/
3753
3754 (F) The regular expression ends with an unbackslashed backslash.
3755 Backslash it.   See L<perlre>.
3756
3757 =item Transliteration pattern not terminated
3758
3759 (F) The lexer couldn't find the interior delimiter of a tr/// or tr[][]
3760 or y/// or y[][] construct.  Missing the leading C<$> from variables
3761 C<$tr> or C<$y> may cause this error.
3762
3763 =item Transliteration replacement not terminated
3764
3765 (F) The lexer couldn't find the final delimiter of a tr/// or tr[][]
3766 construct.
3767
3768 =item '%s' trapped by operation mask
3769
3770 (F) You tried to use an operator from a Safe compartment in which it's
3771 disallowed. See L<Safe>.
3772
3773 =item truncate not implemented
3774
3775 (F) Your machine doesn't implement a file truncation mechanism that
3776 Configure knows about.
3777
3778 =item Type of arg %d to %s must be %s (not %s)
3779
3780 (F) This function requires the argument in that position to be of a
3781 certain type.  Arrays must be @NAME or C<@{EXPR}>.  Hashes must be
3782 %NAME or C<%{EXPR}>.  No implicit dereferencing is allowed--use the
3783 {EXPR} forms as an explicit dereference.  See L<perlref>.
3784
3785 =item umask not implemented
3786
3787 (F) Your machine doesn't implement the umask function and you tried to
3788 use it to restrict permissions for yourself (EXPR & 0700).
3789
3790 =item Unable to create sub named "%s"
3791
3792 (F) You attempted to create or access a subroutine with an illegal name.
3793
3794 =item Unbalanced context: %d more PUSHes than POPs
3795
3796 (W internal) The exit code detected an internal inconsistency in how
3797 many execution contexts were entered and left.
3798
3799 =item Unbalanced saves: %d more saves than restores
3800
3801 (W internal) The exit code detected an internal inconsistency in how
3802 many values were temporarily localized.
3803
3804 =item Unbalanced scopes: %d more ENTERs than LEAVEs
3805
3806 (W internal) The exit code detected an internal inconsistency in how
3807 many blocks were entered and left.
3808
3809 =item Unbalanced tmps: %d more allocs than frees
3810
3811 (W internal) The exit code detected an internal inconsistency in how
3812 many mortal scalars were allocated and freed.
3813
3814 =item Undefined format "%s" called
3815
3816 (F) The format indicated doesn't seem to exist.  Perhaps it's really in
3817 another package?  See L<perlform>.
3818
3819 =item Undefined sort subroutine "%s" called
3820
3821 (F) The sort comparison routine specified doesn't seem to exist.
3822 Perhaps it's in a different package?  See L<perlfunc/sort>.
3823
3824 =item Undefined subroutine &%s called
3825
3826 (F) The subroutine indicated hasn't been defined, or if it was, it has
3827 since been undefined.
3828
3829 =item Undefined subroutine called
3830
3831 (F) The anonymous subroutine you're trying to call hasn't been defined,
3832 or if it was, it has since been undefined.
3833
3834 =item Undefined subroutine in sort
3835
3836 (F) The sort comparison routine specified is declared but doesn't seem
3837 to have been defined yet.  See L<perlfunc/sort>.
3838
3839 =item Undefined top format "%s" called
3840
3841 (F) The format indicated doesn't seem to exist.  Perhaps it's really in
3842 another package?  See L<perlform>.
3843
3844 =item Undefined value assigned to typeglob
3845
3846 (W misc) An undefined value was assigned to a typeglob, a la
3847 C<*foo = undef>.  This does nothing.  It's possible that you really mean
3848 C<undef *foo>.
3849
3850 =item %s: Undefined variable
3851
3852 (A) You've accidentally run your script through B<csh> instead of Perl.
3853 Check the #! line, or manually feed your script into Perl yourself.
3854
3855 =item unexec of %s into %s failed!
3856
3857 (F) The unexec() routine failed for some reason.  See your local FSF
3858 representative, who probably put it there in the first place.
3859
3860 =item Unicode character %s is illegal
3861
3862 (W utf8) Certain Unicode characters have been designated off-limits by
3863 the Unicode standard and should not be generated.  If you really know
3864 what you are doing you can turn off this warning by C<no warnings 'utf8';>.
3865
3866 =item Unknown BYTEORDER
3867
3868 (F) There are no byte-swapping functions for a machine with this byte
3869 order.
3870
3871 =item Unknown open() mode '%s'
3872
3873 (F) The second argument of 3-argument open() is not among the list
3874 of valid modes: C<< < >>, C<< > >>, C<<< >> >>>, C<< +< >>,
3875 C<< +> >>, C<<< +>> >>>, C<-|>, C<|->, C<< <& >>, C<< >& >>.
3876
3877 =item Unknown PerlIO layer "%s"
3878
3879 (W layer) An attempt was made to push an unknown layer onto the Perl I/O
3880 system.  (Layers take care of transforming data between external and
3881 internal representations.)  Note that some layers, such as C<mmap>,
3882 are not supported in all environments.  If your program didn't
3883 explicitly request the failing operation, it may be the result of the
3884 value of the environment variable PERLIO.
3885
3886 =item Unknown process %x sent message to prime_env_iter: %s
3887
3888 (P) An error peculiar to VMS.  Perl was reading values for %ENV before
3889 iterating over it, and someone else stuck a message in the stream of
3890 data Perl expected.  Someone's very confused, or perhaps trying to
3891 subvert Perl's population of %ENV for nefarious purposes.
3892
3893 =item Unknown "re" subpragma '%s' (known ones are: %s)
3894
3895 You tried to use an unknown subpragma of the "re" pragma.
3896
3897 =item Unknown switch condition (?(%.2s in regex; marked by <-- HERE in m/%s/
3898
3899 (F) The condition part of a (?(condition)if-clause|else-clause) construct
3900 is not known. The condition may be lookahead or lookbehind (the condition
3901 is true if the lookahead or lookbehind is true), a (?{...})  construct (the
3902 condition is true if the code evaluates to a true value), or a number (the
3903 condition is true if the set of capturing parentheses named by the number
3904 matched).
3905
3906 The <-- HERE shows in the regular expression about where the problem was
3907 discovered.  See L<perlre>.
3908
3909 =item Unknown Unicode option letter '%c'
3910
3911 You specified an unknown Unicode option.  See L<perlrun> documentation
3912 of the C<-C> switch for the list of known options.
3913
3914 =item Unknown Unicode option value %x
3915
3916 You specified an unknown Unicode option.  See L<perlrun> documentation
3917 of the C<-C> switch for the list of known options.
3918
3919 =item Unknown warnings category '%s'
3920
3921 (F) An error issued by the C<warnings> pragma. You specified a warnings
3922 category that is unknown to perl at this point.
3923
3924 Note that if you want to enable a warnings category registered by a module
3925 (e.g. C<use warnings 'File::Find'>), you must have imported this module
3926 first.
3927
3928 =item unmatched [ in regex; marked by <-- HERE in m/%s/
3929
3930 (F) The brackets around a character class must match. If you wish to
3931 include a closing bracket in a character class, backslash it or put it
3932 first. The <-- HERE shows in the regular expression about where the problem
3933 was discovered. See L<perlre>.
3934
3935 =item unmatched ( in regex; marked by <-- HERE in m/%s/
3936
3937 (F) Unbackslashed parentheses must always be balanced in regular
3938 expressions. If you're a vi user, the % key is valuable for finding the
3939 matching parenthesis. The <-- HERE shows in the regular expression about
3940 where the problem was discovered. See L<perlre>.
3941
3942 =item Unmatched right %s bracket
3943
3944 (F) The lexer counted more closing curly or square brackets than opening
3945 ones, so you're probably missing a matching opening bracket.  As a
3946 general rule, you'll find the missing one (so to speak) near the place
3947 you were last editing.
3948
3949 =item Unquoted string "%s" may clash with future reserved word
3950
3951 (W reserved) You used a bareword that might someday be claimed as a
3952 reserved word.  It's best to put such a word in quotes, or capitalize it
3953 somehow, or insert an underbar into it.  You might also declare it as a
3954 subroutine.
3955
3956 =item Unrecognized character %s
3957
3958 (F) The Perl parser has no idea what to do with the specified character
3959 in your Perl script (or eval).  Perhaps you tried to run a compressed
3960 script, a binary program, or a directory as a Perl program.
3961
3962 =item /%s/: Unrecognized escape \\%c in character class passed through
3963
3964 (W regexp) You used a backslash-character combination which is not
3965 recognized by Perl inside character classes.  The character was
3966 understood literally.
3967
3968 =item Unrecognized escape \\%c passed through
3969
3970 (W misc) You used a backslash-character combination which is not
3971 recognized by Perl.
3972
3973 =item Unrecognized escape \\%c passed through in regex; marked by <-- HERE in m/%s/
3974
3975 (W regexp) You used a backslash-character combination which is not
3976 recognized by Perl. This combination appears in an interpolated variable or
3977 a C<'>-delimited regular expression. The character was understood
3978 literally. The <-- HERE shows in the regular expression about where the
3979 escape was discovered.
3980
3981 =item Unrecognized signal name "%s"
3982
3983 (F) You specified a signal name to the kill() function that was not
3984 recognized.  Say C<kill -l> in your shell to see the valid signal names
3985 on your system.
3986
3987 =item Unrecognized switch: -%s  (-h will show valid options)
3988
3989 (F) You specified an illegal option to Perl.  Don't do that.  (If you
3990 think you didn't do that, check the #! line to see if it's supplying the
3991 bad switch on your behalf.)
3992
3993 =item Unsuccessful %s on filename containing newline
3994
3995 (W newline) A file operation was attempted on a filename, and that
3996 operation failed, PROBABLY because the filename contained a newline,
3997 PROBABLY because you forgot to chomp() it off.  See L<perlfunc/chomp>.
3998
3999 =item Unsupported directory function "%s" called
4000
4001 (F) Your machine doesn't support opendir() and readdir().
4002
4003 =item Unsupported function %s
4004
4005 (F) This machine doesn't implement the indicated function, apparently.
4006 At least, Configure doesn't think so.
4007
4008 =item Unsupported function fork
4009
4010 (F) Your version of executable does not support forking.
4011
4012 Note that under some systems, like OS/2, there may be different flavors
4013 of Perl executables, some of which may support fork, some not. Try
4014 changing the name you call Perl by to C<perl_>, C<perl__>, and so on.
4015
4016 =item Unsupported script encoding
4017
4018 (F) Your program file begins with a Unicode Byte Order Mark (BOM) which
4019 declares it to be in a Unicode encoding that Perl cannot yet read.
4020
4021 =item Unsupported socket function "%s" called
4022
4023 (F) Your machine doesn't support the Berkeley socket mechanism, or at
4024 least that's what Configure thought.
4025
4026 =item Unterminated attribute list
4027
4028 (F) The lexer found something other than a simple identifier at the
4029 start of an attribute, and it wasn't a semicolon or the start of a
4030 block.  Perhaps you terminated the parameter list of the previous
4031 attribute too soon.  See L<attributes>.
4032
4033 =item Unterminated attribute parameter in attribute list
4034
4035 (F) The lexer saw an opening (left) parenthesis character while parsing
4036 an attribute list, but the matching closing (right) parenthesis
4037 character was not found.  You may need to add (or remove) a backslash
4038 character to get your parentheses to balance.  See L<attributes>.
4039
4040 =item Unterminated compressed integer
4041
4042 (F) An argument to unpack("w",...) was incompatible with the BER
4043 compressed integer format and could not be converted to an integer.
4044 See L<perlfunc/pack>.
4045
4046 =item Unterminated <> operator
4047
4048 (F) The lexer saw a left angle bracket in a place where it was expecting
4049 a term, so it's looking for the corresponding right angle bracket, and
4050 not finding it.  Chances are you left some needed parentheses out
4051 earlier in the line, and you really meant a "less than".
4052
4053 =item untie attempted while %d inner references still exist
4054
4055 (W untie) A copy of the object returned from C<tie> (or C<tied>) was
4056 still valid when C<untie> was called.
4057
4058 =item Usage: POSIX::%s(%s)
4059
4060 (F) You called a POSIX function with incorrect arguments.
4061 See L<POSIX/FUNCTIONS> for more information.
4062
4063 =item Usage: Win32::%s(%s)
4064
4065 (F) You called a Win32 function with incorrect arguments.
4066 See L<Win32> for more information.
4067
4068 =item Useless (?-%s) - don't use /%s modifier in regex; marked by <-- HERE in m/%s/
4069
4070 (W regexp) You have used an internal modifier such as (?-o) that has no
4071 meaning unless removed from the entire regexp:
4072
4073     if ($string =~ /(?-o)$pattern/o) { ... }
4074
4075 must be written as
4076
4077     if ($string =~ /$pattern/) { ... }
4078
4079 The <-- HERE shows in the regular expression about
4080 where the problem was discovered. See L<perlre>.
4081
4082 =item Useless localization of %s
4083
4084 (W syntax) The localization of lvalues such as C<local($x=10)> is
4085 legal, but in fact the local() currently has no effect. This may change at
4086 some point in the future, but in the meantime such code is discouraged.
4087
4088 =item Useless (?%s) - use /%s modifier in regex; marked by <-- HERE in m/%s/
4089
4090 (W regexp) You have used an internal modifier such as (?o) that has no
4091 meaning unless applied to the entire regexp:
4092
4093     if ($string =~ /(?o)$pattern/) { ... }
4094
4095 must be written as
4096
4097     if ($string =~ /$pattern/o) { ... }
4098
4099 The <-- HERE shows in the regular expression about
4100 where the problem was discovered. See L<perlre>.
4101
4102 =item Useless use of %s in void context
4103
4104 (W void) You did something without a side effect in a context that does
4105 nothing with the return value, such as a statement that doesn't return a
4106 value from a block, or the left side of a scalar comma operator.  Very
4107 often this points not to stupidity on your part, but a failure of Perl
4108 to parse your program the way you thought it would.  For example, you'd
4109 get this if you mixed up your C precedence with Python precedence and
4110 said
4111
4112     $one, $two = 1, 2;
4113
4114 when you meant to say
4115
4116     ($one, $two) = (1, 2);
4117
4118 Another common error is to use ordinary parentheses to construct a list
4119 reference when you should be using square or curly brackets, for
4120 example, if you say
4121
4122     $array = (1,2);
4123
4124 when you should have said
4125
4126     $array = [1,2];
4127
4128 The square brackets explicitly turn a list value into a scalar value,
4129 while parentheses do not.  So when a parenthesized list is evaluated in
4130 a scalar context, the comma is treated like C's comma operator, which
4131 throws away the left argument, which is not what you want.  See
4132 L<perlref> for more on this.
4133
4134 This warning will not be issued for numerical constants equal to 0 or 1
4135 since they are often used in statements like
4136
4137     1 while sub_with_side_effects() ;
4138
4139 String constants that would normally evaluate to 0 or 1 are warned
4140 about.
4141
4142 =item Useless use of "re" pragma
4143
4144 (W) You did C<use re;> without any arguments.   That isn't very useful.
4145
4146 =item Useless use of sort in scalar context
4147
4148 (W void) You used sort in scalar context, as in :
4149
4150     my $x = sort @y;
4151
4152 This is not very useful, and perl currently optimizes this away.
4153
4154 =item Useless use of %s with no values
4155
4156 (W syntax) You used the push() or unshift() function with no arguments
4157 apart from the array, like C<push(@x)> or C<unshift(@foo)>. That won't
4158 usually have any effect on the array, so is completely useless. It's
4159 possible in principle that push(@tied_array) could have some effect
4160 if the array is tied to a class which implements a PUSH method. If so,
4161 you can write it as C<push(@tied_array,())> to avoid this warning.
4162
4163 =item "use" not allowed in expression
4164
4165 (F) The "use" keyword is recognized and executed at compile time, and
4166 returns no useful value.  See L<perlmod>.
4167
4168 =item Use of bare << to mean <<"" is deprecated
4169
4170 (D deprecated) You are now encouraged to use the explicitly quoted form
4171 if you wish to use an empty line as the terminator of the here-document.
4172
4173 =item Use of chdir('') or chdir(undef) as chdir() deprecated
4174
4175 (D deprecated) chdir() with no arguments is documented to change to
4176 $ENV{HOME} or $ENV{LOGDIR}.  chdir(undef) and chdir('') share this
4177 behavior, but that has been deprecated.  In future versions they
4178 will simply fail.
4179
4180 Be careful to check that what you pass to chdir() is defined and not
4181 blank, else you might find yourself in your home directory.
4182
4183 =item Use of /c modifier is meaningless in s///
4184
4185 (W regexp) You used the /c modifier in a substitution.  The /c
4186 modifier is not presently meaningful in substitutions.
4187
4188 =item Use of /c modifier is meaningless without /g
4189
4190 (W regexp) You used the /c modifier with a regex operand, but didn't
4191 use the /g modifier.  Currently, /c is meaningful only when /g is
4192 used.  (This may change in the future.)
4193
4194 =item Use of freed value in iteration
4195
4196 (F) Perhaps you modified the iterated array within the loop?
4197 This error is typically caused by code like the following:
4198
4199     @a = (3,4);
4200     @a = () for (1,2,@a);
4201
4202 You are not supposed to modify arrays while they are being iterated over.
4203 For speed and efficiency reasons, Perl internally does not do full
4204 reference-counting of iterated items, hence deleting such an item in the
4205 middle of an iteration causes Perl to see a freed value.
4206
4207 =item Use of *glob{FILEHANDLE} is deprecated
4208
4209 (D deprecated) You are now encouraged to use the shorter *glob{IO} form
4210 to access the filehandle slot within a typeglob.
4211
4212 =item Use of /g modifier is meaningless in split
4213
4214 (W regexp) You used the /g modifier on the pattern for a C<split>
4215 operator.  Since C<split> always tries to match the pattern
4216 repeatedly, the C</g> has no effect.
4217
4218 =item Use of implicit split to @_ is deprecated
4219
4220 (D deprecated) It makes a lot of work for the compiler when you clobber
4221 a subroutine's argument list, so it's better if you assign the results
4222 of a split() explicitly to an array (or list).
4223
4224 =item Use of inherited AUTOLOAD for non-method %s() is deprecated
4225
4226 (D deprecated) As an (ahem) accidental feature, C<AUTOLOAD> subroutines
4227 are looked up as methods (using the C<@ISA> hierarchy) even when the
4228 subroutines to be autoloaded were called as plain functions (e.g.
4229 C<Foo::bar()>), not as methods (e.g. C<< Foo->bar() >> or C<<
4230 $obj->bar() >>).
4231
4232 This bug will be rectified in future by using method lookup only for
4233 methods' C<AUTOLOAD>s.  However, there is a significant base of existing
4234 code that may be using the old behavior.  So, as an interim step, Perl
4235 currently issues an optional warning when non-methods use inherited
4236 C<AUTOLOAD>s.
4237
4238 The simple rule is:  Inheritance will not work when autoloading
4239 non-methods.  The simple fix for old code is:  In any module that used
4240 to depend on inheriting C<AUTOLOAD> for non-methods from a base class
4241 named C<BaseClass>, execute C<*AUTOLOAD = \&BaseClass::AUTOLOAD> during
4242 startup.
4243
4244 In code that currently says C<use AutoLoader; @ISA = qw(AutoLoader);>
4245 you should remove AutoLoader from @ISA and change C<use AutoLoader;> to
4246 C<use AutoLoader 'AUTOLOAD';>.
4247
4248 =item Use of %s in printf format not supported
4249
4250 (F) You attempted to use a feature of printf that is accessible from
4251 only C.  This usually means there's a better way to do it in Perl.
4252
4253 =item Use of $# is deprecated
4254
4255 (D deprecated) This was an ill-advised attempt to emulate a poorly
4256 defined B<awk> feature.  Use an explicit printf() or sprintf() instead.
4257
4258 =item Use of %s is deprecated
4259
4260 (D deprecated) The construct indicated is no longer recommended for use,
4261 generally because there's a better way to do it, and also because the
4262 old way has bad side effects.
4263
4264 =item Use of -l on filehandle %s
4265
4266 (W io) A filehandle represents an opened file, and when you opened the file
4267 it already went past any symlink you are presumably trying to look for.
4268 The operation returned C<undef>.  Use a filename instead.
4269
4270 =item Use of "package" with no arguments is deprecated
4271
4272 (D deprecated) You used the C<package> keyword without specifying a package
4273 name. So no namespace is current at all. Using this can cause many
4274 otherwise reasonable constructs to fail in baffling ways. C<use strict;>
4275 instead.
4276
4277 =item Use of reference "%s" as array index
4278
4279 (W misc) You tried to use a reference as an array index; this probably
4280 isn't what you mean, because references in numerical context tend
4281 to be huge numbers, and so usually indicates programmer error.
4282
4283 If you really do mean it, explicitly numify your reference, like so:
4284 C<$array[0+$ref]>.  This warning is not given for overloaded objects,
4285 either, because you can overload the numification and stringification
4286 operators and then you assumedly know what you are doing.
4287
4288 =item Use of reserved word "%s" is deprecated
4289
4290 (D deprecated) The indicated bareword is a reserved word.  Future
4291 versions of perl may use it as a keyword, so you're better off either
4292 explicitly quoting the word in a manner appropriate for its context of
4293 use, or using a different name altogether.  The warning can be
4294 suppressed for subroutine names by either adding a C<&> prefix, or using
4295 a package qualifier, e.g. C<&our()>, or C<Foo::our()>.
4296
4297 =item Use of tainted arguments in %s is deprecated
4298
4299 (W taint, deprecated) You have supplied C<system()> or C<exec()> with multiple
4300 arguments and at least one of them is tainted.  This used to be allowed
4301 but will become a fatal error in a future version of perl.  Untaint your
4302 arguments.  See L<perlsec>.
4303
4304 =item Use of uninitialized value%s
4305
4306 (W uninitialized) An undefined value was used as if it were already
4307 defined.  It was interpreted as a "" or a 0, but maybe it was a mistake.
4308 To suppress this warning assign a defined value to your variables.
4309
4310 To help you figure out what was undefined, perl tells you what operation
4311 you used the undefined value in.  Note, however, that perl optimizes your
4312 program and the operation displayed in the warning may not necessarily
4313 appear literally in your program.  For example, C<"that $foo"> is
4314 usually optimized into C<"that " . $foo>, and the warning will refer to
4315 the C<concatenation (.)> operator, even though there is no C<.> in your
4316 program.
4317
4318 =item Using a hash as a reference is deprecated
4319
4320 (D deprecated) You tried to use a hash as a reference, as in
4321 C<< %foo->{"bar"} >> or C<< %$ref->{"hello"} >>.  Versions of perl <= 5.6.1
4322 used to allow this syntax, but shouldn't have. It is now deprecated, and will
4323 be removed in a future version.
4324
4325 =item Using an array as a reference is deprecated
4326
4327 (D deprecated) You tried to use an array as a reference, as in
4328 C<< @foo->[23] >> or C<< @$ref->[99] >>.  Versions of perl <= 5.6.1 used to
4329 allow this syntax, but shouldn't have. It is now deprecated, and will be
4330 removed in a future version.
4331
4332 =item UTF-16 surrogate %s
4333
4334 (W utf8) You tried to generate half of an UTF-16 surrogate by
4335 requesting a Unicode character between the code points 0xD800 and
4336 0xDFFF (inclusive).  That range is reserved exclusively for the use of
4337 UTF-16 encoding (by having two 16-bit UCS-2 characters); but Perl
4338 encodes its characters in UTF-8, so what you got is a very illegal
4339 character.  If you really know what you are doing you can turn off
4340 this warning by C<no warnings 'utf8';>.
4341
4342 =item Value of %s can be "0"; test with defined()
4343
4344 (W misc) In a conditional expression, you used <HANDLE>, <*> (glob),
4345 C<each()>, or C<readdir()> as a boolean value.  Each of these constructs
4346 can return a value of "0"; that would make the conditional expression
4347 false, which is probably not what you intended.  When using these
4348 constructs in conditional expressions, test their values with the
4349 C<defined> operator.
4350
4351 =item Value of CLI symbol "%s" too long
4352
4353 (W misc) A warning peculiar to VMS.  Perl tried to read the value of an
4354 %ENV element from a CLI symbol table, and found a resultant string
4355 longer than 1024 characters.  The return value has been truncated to
4356 1024 characters.
4357
4358 =item Variable "%s" is not available
4359
4360 (W closure) During compilation, an inner named subroutine or eval is
4361 attempting to capture an outer lexical that is not currently available.
4362 This can be happen for one of two reasons. First, the outer lexical may be
4363 declared in an outer anonymous subroutine that has not yet been created.
4364 (Remember that named subs are created at compile time, while anonymous
4365 subs are created at run-time. For example,
4366
4367     sub { my $a; sub f { $a } }
4368
4369 At the time that f is created, it can't capture the current value of $a,
4370 since the anonymous subroutine hasn't been created yet. Conversely,
4371 the following won't give a warning since the anonymous subroutine has by
4372 now been created and is live:
4373
4374     sub { my $a; eval 'sub f { $a }' }->();
4375
4376 The second situation is caused by an eval accessing a variable that has
4377 gone out of scope, for example,
4378
4379     sub f {
4380         my $a;
4381         sub { eval '$a' }
4382     }
4383     f()->();
4384
4385 Here, when the '$a' in the eval is being compiled, f() is not currently being
4386 executed, so its $a is not available for capture.
4387
4388 =item Variable "%s" is not imported%s
4389
4390 (F) While "use strict" in effect, you referred to a global variable that
4391 you apparently thought was imported from another module, because
4392 something else of the same name (usually a subroutine) is exported by
4393 that module.  It usually means you put the wrong funny character on the
4394 front of your variable.
4395
4396 =item Variable length lookbehind not implemented in regex; marked by <-- HERE in m/%s/
4397
4398 (F) Lookbehind is allowed only for subexpressions whose length is fixed and
4399 known at compile time. The <-- HERE shows in the regular expression about
4400 where the problem was discovered. See L<perlre>.
4401
4402 =item "%s" variable %s masks earlier declaration in same %s
4403
4404 (W misc) A "my" or "our" variable has been redeclared in the current
4405 scope or statement, effectively eliminating all access to the previous
4406 instance.  This is almost always a typographical error.  Note that the
4407 earlier variable will still exist until the end of the scope or until
4408 all closure referents to it are destroyed.
4409
4410 =item Variable syntax
4411
4412 (A) You've accidentally run your script through B<csh> instead
4413 of Perl.  Check the #! line, or manually feed your script into
4414 Perl yourself.
4415
4416 =item Variable "%s" will not stay shared
4417
4418 (W closure) An inner (nested) I<named> subroutine is referencing a
4419 lexical variable defined in an outer named subroutine.
4420
4421 When the inner subroutine is called, it will see the value of
4422 the outer subroutine's variable as it was before and during the *first*
4423 call to the outer subroutine; in this case, after the first call to the
4424 outer subroutine is complete, the inner and outer subroutines will no
4425 longer share a common value for the variable.  In other words, the
4426 variable will no longer be shared.
4427
4428 This problem can usually be solved by making the inner subroutine
4429 anonymous, using the C<sub {}> syntax.  When inner anonymous subs that
4430 reference variables in outer subroutines are created, they
4431 are automatically rebound to the current values of such variables.
4432
4433 =item Version number must be a constant number
4434
4435 (P) The attempt to translate a C<use Module n.n LIST> statement into
4436 its equivalent C<BEGIN> block found an internal inconsistency with
4437 the version number.
4438
4439 =item v-string in use/require is non-portable
4440
4441 (W portable) The use of v-strings is non-portable to older, pre-5.6, Perls.
4442 If you want your scripts to be backward portable, use the floating
4443 point version number: for example, instead of C<use 5.6.1> say
4444 C<use 5.006_001>.  This of course won't help: the older Perls
4445 won't suddenly start understanding newer features, but at least
4446 they will show a sensible error message indicating the required
4447 minimum version.
4448
4449 =item Warning: something's wrong
4450
4451 (W) You passed warn() an empty string (the equivalent of C<warn "">) or
4452 you called it with no args and C<$_> was empty.
4453
4454 =item Warning: unable to close filehandle %s properly
4455
4456 (S) The implicit close() done by an open() got an error indication on
4457 the close().  This usually indicates your file system ran out of disk
4458 space.
4459
4460 =item Warning: Use of "%s" without parentheses is ambiguous
4461
4462 (S ambiguous) You wrote a unary operator followed by something that
4463 looks like a binary operator that could also have been interpreted as a
4464 term or unary operator.  For instance, if you know that the rand
4465 function has a default argument of 1.0, and you write
4466
4467     rand + 5;
4468
4469 you may THINK you wrote the same thing as
4470
4471     rand() + 5;
4472
4473 but in actual fact, you got
4474
4475     rand(+5);
4476
4477 So put in parentheses to say what you really mean.
4478
4479 =item Wide character in %s
4480
4481 (W utf8) Perl met a wide character (>255) when it wasn't expecting
4482 one.  This warning is by default on for I/O (like print).  The easiest
4483 way to quiet this warning is simply to add the C<:utf8> layer to the
4484 output, e.g. C<binmode STDOUT, ':utf8'>.  Another way to turn off the
4485 warning is to add C<no warnings 'utf8';> but that is often closer to
4486 cheating.  In general, you are supposed to explicitly mark the
4487 filehandle with an encoding, see L<open> and L<perlfunc/binmode>.
4488
4489 =item Within []-length '%c' not allowed
4490
4491 (F) The count in the (un)pack template may be replaced by C<[TEMPLATE]> only if
4492 C<TEMPLATE> always matches the same amount of packed bytes that can be
4493 determined from the template alone. This is not possible if it contains an
4494 of the codes @, /, U, u, w or a *-length. Redesign the template.
4495
4496 =item write() on closed filehandle %s
4497
4498 (W closed) The filehandle you're writing to got itself closed sometime
4499 before now.  Check your control flow.
4500
4501 =item %s "\x%s" does not map to Unicode
4502
4503 When reading in different encodings Perl tries to map everything
4504 into Unicode characters.  The bytes you read in are not legal in
4505 this encoding, for example
4506
4507     utf8 "\xE4" does not map to Unicode
4508
4509 if you try to read in the a-diaereses Latin-1 as UTF-8.
4510
4511 =item 'X' outside of string
4512
4513 (F) You had a (un)pack template that specified a relative position before
4514 the beginning of the string being (un)packed.  See L<perlfunc/pack>.
4515
4516 =item 'x' outside of string in unpack
4517
4518 (F) You had a pack template that specified a relative position after
4519 the end of the string being unpacked.  See L<perlfunc/pack>.
4520
4521 =item Xsub "%s" called in sort
4522
4523 (F) The use of an external subroutine as a sort comparison is not yet
4524 supported.
4525
4526 =item Xsub called in sort
4527
4528 (F) The use of an external subroutine as a sort comparison is not yet
4529 supported.
4530
4531 =item YOU HAVEN'T DISABLED SET-ID SCRIPTS IN THE KERNEL YET!
4532
4533 (F) And you probably never will, because you probably don't have the
4534 sources to your kernel, and your vendor probably doesn't give a rip
4535 about what you want.  Your best bet is to put a setuid C wrapper around
4536 your script.
4537
4538 =item You need to quote "%s"
4539
4540 (W syntax) You assigned a bareword as a signal handler name.
4541 Unfortunately, you already have a subroutine of that name declared,
4542 which means that Perl 5 will try to call the subroutine when the
4543 assignment is executed, which is probably not what you want.  (If it IS
4544 what you want, put an & in front.)
4545
4546 =item Your random numbers are not that random
4547
4548 (F) When trying to initialise the random seed for hashes, Perl could
4549 not get any randomness out of your system.  This usually indicates
4550 Something Very Wrong.
4551
4552 =back
4553
4554 =cut