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