This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
clear magic flags in sv_clear
[perl5.git] / pod / perldiag.pod
CommitLineData
a0d0e21e
LW
1=head1 NAME
2
3perldiag - various Perl diagnostics
4
5=head1 DESCRIPTION
6
7These messages are classified as follows (listed in increasing order of
8desperation):
9
10 (W) A warning (optional).
d1d15184 11 (D) A deprecation (enabled by default).
00eb3f2b 12 (S) A severe warning (enabled by default).
a0d0e21e
LW
13 (F) A fatal error (trappable).
14 (P) An internal error you should never see (trappable).
54310121 15 (X) A very fatal error (nontrappable).
cb1a09d0 16 (A) An alien error message (not generated by Perl).
a0d0e21e 17
75b44862 18The majority of messages from the first three classifications above
64977eb6 19(W, D & S) can be controlled using the C<warnings> pragma.
e476b1b5
GS
20
21If a message can be controlled by the C<warnings> pragma, its warning
22category is included with the classification letter in the description
23below.
24
25Optional warnings are enabled by using the C<warnings> pragma or the B<-w>
fa816bf3 26and B<-W> switches. Warnings may be captured by setting C<$SIG{__WARN__}>
e476b1b5
GS
27to a reference to a routine that will be called on each warning instead
28of printing it. See L<perlvar>.
29
b7eceb5b 30Severe warnings are always enabled, unless they are explicitly disabled
e476b1b5 31with the C<warnings> pragma or the B<-X> switch.
4438c4b7 32
748a9306 33Trappable errors may be trapped using the eval operator. See
4438c4b7
JH
34L<perlfunc/eval>. In almost all cases, warnings may be selectively
35disabled or promoted to fatal errors using the C<warnings> pragma.
36See L<warnings>.
a0d0e21e 37
6df41af2
GS
38The messages are in alphabetical order, without regard to upper or
39lower-case. Some of these messages are generic. Spots that vary are
40denoted with a %s or other printf-style escape. These escapes are
41ignored by the alphabetical order, as are all characters other than
42letters. To look up your message, just ignore anything that is not a
43letter.
a0d0e21e
LW
44
45=over 4
46
6df41af2 47=item accept() on closed socket %s
33633739 48
be771a83
GS
49(W closed) You tried to do an accept on a closed socket. Did you forget
50to check the return value of your socket() call? See
51L<perlfunc/accept>.
33633739 52
de42a5a9 53=item Allocation too large: %x
a0d0e21e 54
6df41af2 55(X) You can't allocate more than 64K on an MS-DOS machine.
a0d0e21e 56
1109a392 57=item '%c' allowed only after types %s
ef54e1a4 58
1109a392
MHM
59(F) The modifiers '!', '<' and '>' are allowed in pack() or unpack() only
60after certain types. See L<perlfunc/pack>.
ef54e1a4 61
6df41af2 62=item Ambiguous call resolved as CORE::%s(), qualify as such or use &
43192e07 63
75b44862 64(W ambiguous) A subroutine you have declared has the same name as a Perl
be771a83
GS
65keyword, and you have used the name without qualification for calling
66one or the other. Perl decided to call the builtin because the
67subroutine is not imported.
43192e07 68
6df41af2
GS
69To force interpretation as a subroutine call, either put an ampersand
70before the subroutine name, or qualify the name with its package.
71Alternatively, you can import the subroutine (or pretend that it's
72imported with the C<use subs> pragma).
43192e07 73
6df41af2 74To silently interpret it as the Perl operator, use the C<CORE::> prefix
496a33f5 75on the operator (e.g. C<CORE::log($x)>) or declare the subroutine
be771a83
GS
76to be an object method (see L<perlsub/"Subroutine Attributes"> or
77L<attributes>).
43192e07 78
c2e66d9e
GS
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
82all. To include a C<-> character in a transliteration, put it either
83first or last. (In the past, C<tr/a-z-0//> was synonymous with
84C<tr/a-y//>, which was probably not what you would have expected.)
85
6df41af2 86=item Ambiguous use of %s resolved as %s
43192e07 87
6df41af2
GS
88(W ambiguous)(S) You said something that may not be interpreted the way
89you thought. Normally it's pretty easy to disambiguate it by supplying
90a missing quote, operator, parenthesis pair or declaration.
a0d0e21e 91
d8225693
JM
92=item Ambiguous use of %c resolved as operator %c
93
94(W ambiguous) C<%>, C<&>, and C<*> are both infix operators (modulus,
3303f755
FC
95bitwise and, and multiplication) I<and> initial special characters
96(denoting hashes, subroutines and typeglobs), and you said something
97like C<*foo * foo> that might be interpreted as either of them. We
98assumed you meant the infix operator, but please try to make it more
99clear -- in the example given, you might write C<*foo * foo()> if you
100really meant to multiply a glob by the result of calling a function.
d8225693 101
1ef43bca
JM
102=item Ambiguous use of %c{%s} resolved to %c%s
103
104(W ambiguous) You wrote something like C<@{foo}>, which might be
105asking for the variable C<@foo>, or it might be calling a function
106named foo, and dereferencing it as an array reference. If you wanted
1cecf2c0 107the variable, you can just write C<@foo>. If you wanted to call the
1ef43bca
JM
108function, write C<@{foo()}> ... or you could just not have a variable
109and a function with the same name, and save yourself a lot of trouble.
110
e850844c
FC
111=item Ambiguous use of %c{%s[...]} resolved to %c%s[...]
112
113=item Ambiguous use of %c{%s{...}} resolved to %c%s{...}
4da60377 114
fa816bf3
FC
115(W ambiguous) You wrote something like C<${foo[2]}> (where foo represents
116the name of a Perl keyword), which might be looking for element number
1172 of the array named C<@foo>, in which case please write C<$foo[2]>, or you
118might have meant to pass an anonymous arrayref to the function named
119foo, and then do a scalar deref on the value it returns. If you meant
120that, write C<${foo([2])}>.
ccaaf480
FC
121
122In regular expressions, the C<${foo[2]}> syntax is sometimes necessary
123to disambiguate between array subscripts and character classes.
fa816bf3
FC
124C</$length[2345]/>, for instance, will be interpreted as C<$length> followed
125by the character class C<[2345]>. If an array subscript is what you
126want, you can avoid the warning by changing C</${length[2345]}/> to the
127unsightly C</${\$length[2345]}/>, by renaming your array to something
128that does not coincide with a built-in keyword, or by simply turning
129off warnings with C<no warnings 'ambiguous';>.
4da60377 130
bdac9d71 131=item Ambiguous use of -%s resolved as -&%s()
397d0f13
JM
132
133(W ambiguous) You wrote something like C<-foo>, which might be the
a7f6e211
FC
134string C<"-foo">, or a call to the function C<foo>, negated. If you meant
135the string, just write C<"-foo">. If you meant the function call,
397d0f13
JM
136write C<-foo()>.
137
79ef86ee 138=item Ambiguous use of 's//le...' resolved as 's// le...'; Rewrite as 's//el' if you meant 'use locale rules and evaluate rhs as an expression'. In Perl 5.18, it will be resolved the other way
94b03d7d 139
fa816bf3 140(W deprecated, ambiguous) You wrote a pattern match with substitution
79ef86ee 141immediately followed by "le". In Perl 5.16 and earlier, this is
94b03d7d
KW
142resolved as meaning to take the result of the substitution, and see if
143it is stringwise less-than-or-equal-to what follows in the expression.
144Having the "le" immediately following a pattern is deprecated behavior,
79ef86ee 145so in Perl 5.18, this expression will be resolved as meaning to do the
94b03d7d 146pattern match using the rules of the current locale, and evaluate the
79ef86ee
KW
147rhs as an expression when doing the substitution. In 5.14, and 5.16 if
148you want the latter interpretation, you can simply write "el" instead.
149But note that the C</l> modifier should not be used explicitly anyway;
150you should use C<use locale> instead. See L<perllocale>.
94b03d7d 151
6df41af2 152=item '|' and '<' may not both be specified on command line
a0d0e21e 153
be771a83
GS
154(F) An error peculiar to VMS. Perl does its own command line
155redirection, and found that STDIN was a pipe, and that you also tried to
156redirect STDIN using '<'. Only one STDIN stream to a customer, please.
c9f97d15 157
6df41af2 158=item '|' and '>' may not both be specified on command line
1028017a 159
be771a83
GS
160(F) An error peculiar to VMS. Perl does its own command line
161redirection, and thinks you tried to redirect stdout both to a file and
162into a pipe to another command. You need to choose one or the other,
163though nothing's stopping you from piping into a program or Perl script
164which 'splits' output into two streams, such as
1028017a 165
6df41af2
GS
166 open(OUT,">$ARGV[0]") or die "Can't write to $ARGV[0]: $!";
167 while (<STDIN>) {
168 print;
169 print OUT;
170 }
171 close OUT;
c9f97d15 172
6df41af2 173=item Applying %s to %s will act on scalar(%s)
eb6e2d6f 174
496a33f5
SC
175(W misc) The pattern match (C<//>), substitution (C<s///>), and
176transliteration (C<tr///>) operators work on scalar values. If you apply
be771a83 177one of them to an array or a hash, it will convert the array or hash to
ac036724 178a scalar value (the length of an array, or the population info of a
179hash) and then work on that scalar value. This is probably not what
be771a83
GS
180you meant to do. See L<perlfunc/grep> and L<perlfunc/map> for
181alternatives.
eb6e2d6f 182
6df41af2 183=item Arg too short for msgsnd
76cd736e 184
6df41af2 185(F) msgsnd() requires a string at least as long as sizeof(long).
76cd736e 186
b0fdf69e 187=item %s argument is not a HASH or ARRAY element or a subroutine
a0d0e21e 188
cc1c2e42
FC
189(F) The argument to exists() must be a hash or array element or a
190subroutine with an ampersand, such as:
a0d0e21e
LW
191
192 $foo{$bar}
cb4f522a 193 $ref->{"susie"}[12]
cc1c2e42 194 &do_something
a0d0e21e 195
8ea97a1e 196=item %s argument is not a HASH or ARRAY element or slice
5f05dabc 197
06e52bfa
FC
198(F) The argument to delete() must be either a hash or array element,
199such as:
5f05dabc 200
201 $foo{$bar}
cb4f522a 202 $ref->{"susie"}[12]
5f05dabc 203
8ea97a1e 204or a hash or array slice, such as:
5f05dabc 205
6df41af2
GS
206 @foo[$bar, $baz, $xyzzy]
207 @{$ref->[12]}{"susie", "queue"}
5315574d 208
6df41af2 209=item %s argument is not a subroutine name
a0d0e21e 210
6df41af2 211(F) The argument to exists() for C<exists &sub> must be a subroutine
be771a83
GS
212name, and not a subroutine call. C<exists &sub()> will generate this
213error.
a0d0e21e 214
f86702cc 215=item Argument "%s" isn't numeric%s
a0d0e21e 216
be771a83
GS
217(W numeric) The indicated string was fed as an argument to an operator
218that expected a numeric value instead. If you're fortunate the message
219will identify which operator was so unfortunate.
a0d0e21e 220
b4581f09
JH
221=item Argument list not closed for PerlIO layer "%s"
222
a534ac11
FC
223(W layer) When pushing a layer with arguments onto the Perl I/O
224system you forgot the ) that closes the argument list. (Layers
225take care of transforming data between external and internal
226representations.) Perl stopped parsing the layer list at this
227point and did not attempt to push this layer. If your program
228didn't explicitly request the failing operation, it may be the
229result of the value of the environment variable PERLIO.
b4581f09 230
a0d0e21e
LW
231=item Array @%s missing the @ in argument %d of %s()
232
75b44862
GS
233(D deprecated) Really old Perl let you omit the @ on array names in some
234spots. This is now heavily deprecated.
a0d0e21e
LW
235
236=item assertion botched: %s
237
21b5e840 238(X) The malloc package that comes with Perl had an internal failure.
a0d0e21e
LW
239
240=item Assertion failed: file "%s"
241
21b5e840 242(X) A general assertion failed. The file in question must be examined.
a0d0e21e 243
82122228
FC
244=item Assigning non-zero to $[ is no longer possible
245
7d345e3d
FC
246(F) When the "array_base" feature is disabled (e.g., under C<use v5.16;>)
247the special variable C<$[>, which is deprecated, is now a fixed zero value.
82122228 248
a0d0e21e
LW
249=item Assignment to both a list and a scalar
250
251(F) If you assign to a conditional operator, the 2nd and 3rd arguments
252must either both be scalars or both be lists. Otherwise Perl won't
253know which context to supply to the right side.
254
96ebfdd7
RK
255=item A thread exited while %d threads were running
256
b92a77e8
FC
257(W threads)(S) When using threaded Perl, a thread (not necessarily
258the main thread) exited while there were still other threads running.
111a855e
FC
259Usually it's a good idea first to collect the return values of the
260created threads by joining them, and only then to exit from the main
96ebfdd7
RK
261thread. See L<threads>.
262
2393f1b9 263=item Attempt to access disallowed key '%s' in a restricted hash
1b1f1335 264
49293501 265(F) The failing code has attempted to get or set a key which is not in
2393f1b9 266the current set of allowed keys of a restricted hash.
49293501 267
81689caa
HS
268=item Attempt to bless into a reference
269
270(F) The CLASSNAME argument to the bless() operator is expected to be
57dedab9 271the name of the package to bless the resulting object into. You've
81689caa
HS
272supplied instead a reference to something: perhaps you wrote
273
274 bless $self, $proto;
275
276when you intended
277
278 bless $self, ref($proto) || $proto;
279
280If you actually want to bless into the stringified version
281of the reference supplied, you need to stringify it yourself, for
282example by:
283
284 bless $self, "$proto";
285
a730510a
FC
286=item Attempt to clear deleted array
287
288(S debugging) An array was assigned to when it was being freed.
289Freed values are not supposed to be visible to Perl code. This
290can also happen if XS code calls C<av_clear> from a custom magic
291callback on the array.
292
96ebfdd7
RK
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
296which 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
301declared readonly from a restricted hash.
302
de42a5a9 303=item Attempt to free non-arena SV: 0x%x
a0d0e21e 304
f84fe999 305(S internal) All SV objects are supposed to be allocated from arenas
be771a83
GS
306that will be garbage collected on exit. An SV was discovered to be
307outside any of those arenas.
a0d0e21e 308
12578ffb 309=item Attempt to free nonexistent shared string '%s'%s
bbce6d69 310
f84fe999 311(S internal) Perl maintains a reference-counted internal table of
be771a83
GS
312strings to optimize the storage and access of hash keys and other
313strings. This indicates someone tried to decrement the reference count
314of a string that can no longer be found in the table.
bbce6d69 315
7d5b40b4 316=item Attempt to free temp prematurely: SV 0x%x
a0d0e21e 317
f84fe999 318(S debugging) Mortalized values are supposed to be freed by the
be771a83
GS
319free_tmps() routine. This indicates that something else is freeing the
320SV before the free_tmps() routine gets a chance, which means that the
321free_tmps() routine will be freeing an unreferenced scalar when it does
322try to free it.
a0d0e21e
LW
323
324=item Attempt to free unreferenced glob pointers
325
f84fe999 326(S internal) The reference counts got screwed up on symbol aliases.
a0d0e21e 327
7d5b40b4 328=item Attempt to free unreferenced scalar: SV 0x%x
a0d0e21e 329
be771a83
GS
330(W internal) Perl went to decrement the reference count of a scalar to
331see if it would go to 0, and discovered that it had already gone to 0
332earlier, and should have been freed, and in fact, probably was freed.
333This could indicate that SvREFCNT_dec() was called too many times, or
334that SvREFCNT_inc() was called too few times, or that the SV was
335mortalized when it shouldn't have been, or that memory has been
336corrupted.
a0d0e21e 337
dcdda58d
GS
338=item Attempt to join self
339
340(F) You tried to join a thread from within itself, which is an
be771a83
GS
341impossible task. You may be joining the wrong thread, or you may need
342to move the join() to some other thread.
dcdda58d 343
84902520
TB
344=item Attempt to pack pointer to temporary value
345
be771a83
GS
346(W pack) You tried to pass a temporary value (like the result of a
347function, or a computed expression) to the "p" pack() template. This
348means the result contains a pointer to a location that could become
349invalid anytime, even before the end of the current statement. Use
350literals or global values as arguments to the "p" pack() template to
351avoid this warning.
84902520 352
087b5369
RD
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
356compile once already. Perl will not try to compile this file again
357unless you delete its entry from %INC. See L<perlfunc/require> and
358L<perlvar/%INC>.
359
1b20cd17
NC
360=item Attempt to set length of freed array
361
362(W) You tried to set the length of an array which has been freed. You
363can do this by storing a reference to the scalar representing the last index
fa816bf3 364of an array and later assigning through that reference. For example
1b20cd17
NC
365
366 $r = do {my @a; \$#a};
367 $$r = 503
368
b7a902f4 369=item Attempt to use reference as lvalue in substr
370
be771a83
GS
371(W substr) You supplied a reference as the first argument to substr()
372used as an lvalue, which is pretty strange. Perhaps you forgot to
373dereference it first. See L<perlfunc/substr>.
b7a902f4 374
c32124fe
NC
375=item Attribute "locked" is deprecated
376
57dedab9
FC
377(D deprecated) You have used the attributes pragma to modify the
378"locked" attribute on a code reference. The :locked attribute is
379obsolete, has had no effect since 5005 threads were removed, and
380will be removed in a future release of Perl 5.
c32124fe 381
f1a3ce43
NC
382=item Attribute "unique" is deprecated
383
57dedab9
FC
384(D deprecated) You have used the attributes pragma to modify
385the "unique" attribute on an array, hash or scalar reference.
386The :unique attribute has had no effect since Perl 5.8.8, and
387will be removed in a future release of Perl 5.
f1a3ce43 388
ccce04a4
FC
389=item av_reify called on tied array
390
391(S debugging) This indicates that something went wrong and Perl got I<very>
392confused about C<@_> or C<@DB::args> being tied.
393
de42a5a9 394=item Bad arg length for %s, is %u, should be %d
a0d0e21e 395
be771a83
GS
396(F) You passed a buffer of the wrong size to one of msgctl(), semctl()
397or shmctl(). In C parlance, the correct sizes are, respectively,
5f05dabc 398S<sizeof(struct msqid_ds *)>, S<sizeof(struct semid_ds *)>, and
a0d0e21e
LW
399S<sizeof(struct shmid_ds *)>.
400
7a95317d
GS
401=item Bad evalled substitution pattern
402
496a33f5 403(F) You've used the C</e> switch to evaluate the replacement for a
7a95317d
GS
404substitution, but perl found a syntax error in the code to evaluate,
405most likely an unexpected right brace '}'.
406
a0d0e21e
LW
407=item Bad filehandle: %s
408
be771a83
GS
409(F) A symbol was passed to something wanting a filehandle, but the
410symbol has no filehandle associated with it. Perhaps you didn't do an
411open(), or did it in another package.
a0d0e21e
LW
412
413=item Bad free() ignored
414
be771a83 415(S malloc) An internal routine called free() on something that had never
fa816bf3 416been malloc()ed in the first place. Mandatory, but can be disabled by
9ea8bc6d 417setting environment variable C<PERL_BADFREE> to 0.
33c8a3fe 418
9ea8bc6d 419This message can be seen quite often with DB_File on systems with "hard"
6903afa2 420dynamic linking, like C<AIX> and C<OS/2>. It is a bug of C<Berkeley DB>
be771a83 421which is left unnoticed if C<DB> uses I<forgiving> system malloc().
a0d0e21e 422
aa689395 423=item Bad hash
424
425(P) One of the internal hash routines was passed a null HV pointer.
426
6df41af2
GS
427=item Badly placed ()'s
428
429(A) You've accidentally run your script through B<csh> instead
430of Perl. Check the #! line, or manually feed your script into
431Perl yourself.
432
a7cb8dae 433=item Bad name after %s
a0d0e21e 434
be771a83
GS
435(F) You started to name a symbol by using a package prefix, and then
436didn't finish the symbol. In particular, you can't interpolate outside
437of quotes, so
a0d0e21e
LW
438
439 $var = 'myvar';
440 $sym = mypack::$var;
441
442is not the same as
443
444 $var = 'myvar';
445 $sym = "mypack::$var";
446
88e1f1a2
JV
447=item Bad plugin affecting keyword '%s'
448
449(F) An extension using the keyword plugin mechanism violated the
450plugin API.
451
4ad56ec9
IZ
452=item Bad realloc() ignored
453
6903afa2
FC
454(S malloc) An internal routine called realloc() on something that
455had never been malloc()ed in the first place. Mandatory, but can
456be disabled by setting the environment variable C<PERL_BADFREE> to 1.
4ad56ec9 457
a0d0e21e
LW
458=item Bad symbol for array
459
460(P) An internal request asked to add an array entry to something that
461wasn't a symbol table entry.
462
4df3f177
SP
463=item Bad symbol for dirhandle
464
465(P) An internal request asked to add a dirhandle entry to something
466that wasn't a symbol table entry.
467
a0d0e21e
LW
468=item Bad symbol for filehandle
469
be771a83
GS
470(P) An internal request asked to add a filehandle entry to something
471that wasn't a symbol table entry.
a0d0e21e
LW
472
473=item Bad symbol for hash
474
475(P) An internal request asked to add a hash entry to something that
476wasn't a symbol table entry.
477
34d09196
GS
478=item Bareword found in conditional
479
be771a83
GS
480(W bareword) The compiler found a bareword where it expected a
481conditional, which often indicates that an || or && was parsed as part
482of the last argument of the previous construct, for example:
34d09196
GS
483
484 open FOO || die;
485
be771a83
GS
486It may also indicate a misspelled constant that has been interpreted as
487a bareword:
34d09196
GS
488
489 use constant TYPO => 1;
490 if (TYOP) { print "foo" }
491
492The C<strict> pragma is useful in avoiding such errors.
493
6df41af2
GS
494=item Bareword "%s" not allowed while "strict subs" in use
495
496(F) With "strict subs" in use, a bareword is only allowed as a
be771a83
GS
497subroutine identifier, in curly brackets or to the left of the "=>"
498symbol. Perhaps you need to predeclare a subroutine?
6df41af2
GS
499
500=item Bareword "%s" refers to nonexistent package
501
be771a83
GS
502(W bareword) You used a qualified bareword of the form C<Foo::>, but the
503compiler saw no other uses of that namespace before that point. Perhaps
504you need to predeclare a package?
6df41af2 505
a0d0e21e
LW
506=item BEGIN failed--compilation aborted
507
be771a83
GS
508(F) An untrapped exception was raised while executing a BEGIN
509subroutine. Compilation stops immediately and the interpreter is
510exited.
a0d0e21e 511
68dc0745 512=item BEGIN not safe after errors--compilation aborted
513
514(F) Perl found a C<BEGIN {}> subroutine (or a C<use> directive, which
be771a83
GS
515implies a C<BEGIN {}>) after one or more compilation errors had already
516occurred. Since the intended environment for the C<BEGIN {}> could not
517be guaranteed (due to the errors), and since subsequent code likely
518depends on its correct operation, Perl just gave up.
68dc0745 519
6df41af2
GS
520=item \1 better written as $1
521
be771a83
GS
522(W syntax) Outside of patterns, backreferences live on as variables.
523The use of backslashes is grandfathered on the right-hand side of a
524substitution, but stylistically it's better to use the variable form
525because other Perl programmers will expect it, and it works better if
526there are more than 9 backreferences.
6df41af2 527
252aa082
JH
528=item Binary number > 0b11111111111111111111111111111111 non-portable
529
e476b1b5 530(W portable) The binary number you specified is larger than 2**32-1
9e24b6e2
JH
531(4294967295) and therefore non-portable between systems. See
532L<perlport> for more on portability concerns.
252aa082 533
69282e91 534=item bind() on closed socket %s
a0d0e21e 535
be771a83
GS
536(W closed) You tried to do a bind on a closed socket. Did you forget to
537check the return value of your socket() call? See L<perlfunc/bind>.
a0d0e21e 538
c289d2f7
JH
539=item binmode() on closed filehandle %s
540
541(W unopened) You tried binmode() on a filehandle that was never opened.
4dcecea4 542Check your control flow and number of arguments.
c289d2f7 543
f866a7cd
FC
544=item "\b{" is deprecated; use "\b\{" instead
545
546=item "\B{" is deprecated; use "\B\{" instead
547
548(W deprecated, regexp) Use of an unescaped "{" immediately following a
549C<\b> or C<\B> is now deprecated so as to reserve its use for Perl
550itself in a future release.
551
c5a0f51a
JH
552=item Bit vector size > 32 non-portable
553
e476b1b5 554(W portable) Using bit vector sizes larger than 32 is non-portable.
c5a0f51a 555
043c750c 556=item Bizarre copy of %s
4633a7c4 557
be771a83 558(P) Perl detected an attempt to copy an internal value that is not
4dcecea4 559copiable.
4633a7c4 560
f675dbe5
CB
561=item Buffer overflow in prime_env_iter: %s
562
be771a83
GS
563(W internal) A warning peculiar to VMS. While Perl was preparing to
564iterate over %ENV, it encountered a logical name or symbol definition
565which was too long, so it was truncated to the string shown.
f675dbe5 566
7fcfef4d
FC
567=item Bizarre SvTYPE [%d]
568
569(P) When starting a new thread or return values from a thread, Perl
570encountered an invalid data type.
571
a0d0e21e
LW
572=item Callback called exit
573
4929bf7b 574(F) A subroutine invoked from an external package via call_sv()
a0d0e21e
LW
575exited by calling exit.
576
6df41af2 577=item %s() called too early to check prototype
f675dbe5 578
be771a83
GS
579(W prototype) You've called a function that has a prototype before the
580parser saw a definition or declaration for it, and Perl could not check
581that the call conforms to the prototype. You need to either add an
582early prototype declaration for the subroutine in question, or move the
583subroutine definition ahead of the call to get proper prototype
584checking. Alternatively, if you are certain that you're calling the
585function correctly, you may put an ampersand before the name to avoid
586the warning. See L<perlsub>.
f675dbe5 587
49704364 588=item Cannot compress integer in pack
0258719b
NC
589
590(F) An argument to pack("w",...) was too large to compress. The BER
591compressed integer format can only be used with positive integers, and you
592attempted to compress Infinity or a very large number (> 1e308).
593See L<perlfunc/pack>.
594
49704364 595=item Cannot compress negative numbers in pack
0258719b
NC
596
597(F) An argument to pack("w",...) was negative. The BER compressed integer
598format can only be used with positive integers. See L<perlfunc/pack>.
599
5c1f4d79
NC
600=item Cannot convert a reference to %s to typeglob
601
6903afa2
FC
602(F) You manipulated Perl's symbol table directly, stored a reference
603in it, then tried to access that symbol via conventional Perl syntax.
604The access triggers Perl to autovivify that typeglob, but it there is
605no legal conversion from that type of reference to a typeglob.
5c1f4d79 606
4040665a 607=item Cannot copy to %s
ba2fdce6
NC
608
609(P) Perl detected an attempt to copy a value to an internal type that cannot
4dcecea4 610be directly assigned to.
ba2fdce6 611
b5d97229
RGS
612=item Cannot find encoding "%s"
613
614(S io) You tried to apply an encoding that did not exist to a filehandle,
615either with open() or binmode().
616
7355df7e
FC
617=item Cannot set tied @DB::args
618
619(F) C<caller> tried to set C<@DB::args>, but found it tied. Tying C<@DB::args>
620is not supported. (Before this error was added, it used to crash.)
621
ce65bc73
FC
622=item Cannot tie unreifiable array
623
624(P) You somehow managed to call C<tie> on an array that does not
625keep a reference count on its arguments and cannot be made to
626do so. Such arrays are not even supposed to be accessible to
627Perl code, but are only used internally.
628
96ebfdd7
RK
629=item Can only compress unsigned integers in pack
630
631(F) An argument to pack("w",...) was not an integer. The BER compressed
632integer format can only be used with positive integers, and you attempted
633to compress something else. See L<perlfunc/pack>.
634
a0d0e21e
LW
635=item Can't bless non-reference value
636
637(F) Only hard references may be blessed. This is how Perl "enforces"
638encapsulation of objects. See L<perlobj>.
639
dc57907a
RGS
640=item Can't "break" in a loop topicalizer
641
0d863452 642(F) You called C<break>, but you're in a C<foreach> block rather than
6903afa2 643a C<given> block. You probably meant to use C<next> or C<last>.
0d863452
RH
644
645=item Can't "break" outside a given block
dc57907a 646
0d863452
RH
647(F) You called C<break>, but you're not inside a C<given> block.
648
6df41af2
GS
649=item Can't call method "%s" on an undefined value
650
651(F) You used the syntax of a method call, but the slot filled by the
be771a83
GS
652object reference or package name contains an undefined value. Something
653like this will reproduce the error:
6df41af2
GS
654
655 $BADREF = undef;
656 process $BADREF 1,2,3;
657 $BADREF->process(1,2,3);
658
a0d0e21e
LW
659=item Can't call method "%s" on unblessed reference
660
54310121 661(F) A method call must know in what package it's supposed to run. It
be771a83
GS
662ordinarily finds this out from the object reference you supply, but you
663didn't supply an object reference in this case. A reference isn't an
664object reference until it has been blessed. See L<perlobj>.
a0d0e21e
LW
665
666=item Can't call method "%s" without a package or object reference
667
668(F) You used the syntax of a method call, but the slot filled by the
be771a83
GS
669object reference or package name contains an expression that returns a
670defined value which is neither an object reference nor a package name.
72b5445b
GS
671Something like this will reproduce the error:
672
673 $BADREF = 42;
674 process $BADREF 1,2,3;
675 $BADREF->process(1,2,3);
676
a0d0e21e
LW
677=item Can't chdir to %s
678
679(F) You called C<perl -x/foo/bar>, but C</foo/bar> is not a directory
680that you can chdir to, possibly because it doesn't exist.
681
0545a864 682=item Can't check filesystem of script "%s" for nosuid
104d25b7 683
be771a83
GS
684(P) For some reason you can't check the filesystem of the script for
685nosuid.
104d25b7 686
22e74366 687=item Can't coerce %s to %s in %s
a0d0e21e
LW
688
689(F) Certain types of SVs, in particular real symbol table entries
55497cff 690(typeglobs), can't be forced to stop being what they are. So you can't
a0d0e21e
LW
691say things like:
692
693 *foo += 1;
694
695You CAN say
696
697 $foo = *foo;
698 $foo += 1;
699
700but then $foo no longer contains a glob.
701
0d863452 702=item Can't "continue" outside a when block
dc57907a 703
0d863452
RH
704(F) You called C<continue>, but you're not inside a C<when>
705or C<default> block.
706
a0d0e21e
LW
707=item Can't create pipe mailbox
708
be771a83
GS
709(P) An error peculiar to VMS. The process is suffering from exhausted
710quotas or other plumbing problems.
a0d0e21e 711
eb64745e
GS
712=item Can't declare %s in "%s"
713
30c282f6
NC
714(F) Only scalar, array, and hash variables may be declared as "my", "our" or
715"state" variables. They must have ordinary identifiers as names.
a0d0e21e 716
fc7debfb
FC
717=item Can't "default" outside a topicalizer
718
719(F) You have used a C<default> block that is neither inside a
720C<foreach> loop nor a C<given> block. (Note that this error is
721issued on exit from the C<default> block, so you won't get the
722error if you use an explicit C<continue>.)
723
6df41af2
GS
724=item Can't do inplace edit: %s is not a regular file
725
be771a83
GS
726(S inplace) You tried to use the B<-i> switch on a special file, such as
727a file in /dev, or a FIFO. The file was ignored.
6df41af2 728
a0d0e21e
LW
729=item Can't do inplace edit on %s: %s
730
be771a83
GS
731(S inplace) The creation of the new file failed for the indicated
732reason.
a0d0e21e 733
54310121 734=item Can't do inplace edit without backup
a0d0e21e 735
be771a83
GS
736(F) You're on a system such as MS-DOS that gets confused if you try
737reading from a deleted (but still opened) file. You have to say
738C<-i.bak>, or some such.
a0d0e21e 739
10f9c03d 740=item Can't do inplace edit: %s would not be unique
a0d0e21e 741
e476b1b5 742(S inplace) Your filesystem does not support filenames longer than 14
10f9c03d
CK
743characters and Perl was unable to create a unique filename during
744inplace editing with the B<-i> switch. The file was ignored.
a0d0e21e 745
7253e4e3 746=item Can't do {n,m} with n > m in regex; marked by <-- HERE in m/%s/
a0d0e21e 747
6903afa2
FC
748(F) Minima must be less than or equal to maxima. If you really
749want your regexp to match something 0 times, just put {0}. The
750<-- HERE shows in the regular expression about where the problem
751was discovered. See L<perlre>.
a0d0e21e 752
a0d0e21e
LW
753=item Can't do waitpid with flags
754
be771a83
GS
755(F) This machine doesn't have either waitpid() or wait4(), so only
756waitpid() without flags is emulated.
a0d0e21e 757
a0d0e21e
LW
758=item Can't emulate -%s on #! line
759
be771a83
GS
760(F) The #! line specifies a switch that doesn't make sense at this
761point. For example, it'd be kind of silly to put a B<-x> on the #!
762line.
a0d0e21e 763
1109a392
MHM
764=item Can't %s %s-endian %ss on this platform
765
766(F) Your platform's byte-order is neither big-endian nor little-endian,
767or it has a very strange pointer size. Packing and unpacking big- or
768little-endian floating point values and pointers may not be possible.
769See L<perlfunc/pack>.
770
a0d0e21e
LW
771=item Can't exec "%s": %s
772
d1be9408 773(W exec) A system(), exec(), or piped open call could not execute the
be771a83
GS
774named program for the indicated reason. Typical reasons include: the
775permissions were wrong on the file, the file wasn't found in
776C<$ENV{PATH}>, the executable in question was compiled for another
777architecture, or the #! line in a script points to an interpreter that
778can't be run for similar reasons. (Or maybe your system doesn't support
779#! at all.)
a0d0e21e
LW
780
781=item Can't exec %s
782
be771a83
GS
783(F) Perl was trying to execute the indicated program for you because
784that's what the #! line said. If that's not what you wanted, you may
785need to mention "perl" on the #! line somewhere.
a0d0e21e
LW
786
787=item Can't execute %s
788
be771a83
GS
789(F) You used the B<-S> switch, but the copies of the script to execute
790found in the PATH did not have correct permissions.
2a92aaa0 791
6df41af2 792=item Can't find an opnumber for "%s"
2a92aaa0 793
be771a83
GS
794(F) A string of a form C<CORE::word> was given to prototype(), but there
795is no builtin with the name C<word>.
6df41af2 796
56ca2fc0
JH
797=item Can't find %s character property "%s"
798
799(F) You used C<\p{}> or C<\P{}> but the character property by that name
6903afa2 800could not be found. Maybe you misspelled the name of the property?
e1b711da
KW
801See L<perluniprops/Properties accessible through \p{} and \P{}>
802for a complete list of available properties.
56ca2fc0 803
6df41af2
GS
804=item Can't find label %s
805
be771a83
GS
806(F) You said to goto a label that isn't mentioned anywhere that it's
807possible for us to go to. See L<perlfunc/goto>.
2a92aaa0
GS
808
809=item Can't find %s on PATH
810
be771a83
GS
811(F) You used the B<-S> switch, but the script to execute could not be
812found in the PATH.
a0d0e21e 813
6df41af2 814=item Can't find %s on PATH, '.' not in PATH
a0d0e21e 815
be771a83
GS
816(F) You used the B<-S> switch, but the script to execute could not be
817found in the PATH, or at least not with the correct permissions. The
818script exists in the current directory, but PATH prohibits running it.
a0d0e21e
LW
819
820=item Can't find string terminator %s anywhere before EOF
821
be771a83
GS
822(F) Perl strings can stretch over multiple lines. This message means
823that the closing delimiter was omitted. Because bracketed quotes count
824nesting levels, the following is missing its final parenthesis:
a0d0e21e 825
fb73857a 826 print q(The character '(' starts a side comment.);
827
97b3d10f 828If you're getting this error from a here-document, you may have
b6b8cb97
FC
829included unseen whitespace before or after your closing tag or there
830may not be a linebreak after it. A good programmer's editor will have
831a way to help you find these characters (or lack of characters). See
832L<perlop> for the full details on here-documents.
a0d0e21e 833
660a4616
TS
834=item Can't find Unicode property definition "%s"
835
5f8ad6b6
FC
836(F) You may have tried to use C<\p> which means a Unicode
837property (for example C<\p{Lu}> matches all uppercase
fa816bf3 838letters). If you did mean to use a Unicode property, see
e1b711da 839L<perluniprops/Properties accessible through \p{} and \P{}>
6903afa2 840for a complete list of available properties. If you didn't
fa816bf3
FC
841mean to use a Unicode property, escape the C<\p>, either by
842C<\\p> (just the C<\p>) or by C<\Q\p> (the rest of the string, or
5f8ad6b6 843until C<\E>).
660a4616 844
b3647a36 845=item Can't fork: %s
a0d0e21e 846
be771a83
GS
847(F) A fatal error occurred while trying to fork while opening a
848pipeline.
a0d0e21e 849
b3647a36
SR
850=item Can't fork, trying again in 5 seconds
851
c973c02e 852(W pipe) A fork in a piped open failed with EAGAIN and will be retried
b3647a36
SR
853after five seconds.
854
748a9306
LW
855=item Can't get filespec - stale stat buffer?
856
be771a83
GS
857(S) A warning peculiar to VMS. This arises because of the difference
858between access checks under VMS and under the Unix model Perl assumes.
859Under VMS, access checks are done by filename, rather than by bits in
860the stat buffer, so that ACLs and other protections can be taken into
861account. Unfortunately, Perl assumes that the stat buffer contains all
862the necessary information, and passes it, instead of the filespec, to
2fe2bdfd 863the access-checking routine. It will try to retrieve the filespec using
be771a83
GS
864the device name and FID present in the stat buffer, but this works only
865if you haven't made a subsequent call to the CRTL stat() routine,
866because the device name is overwritten with each call. If this warning
2fe2bdfd
FC
867appears, the name lookup failed, and the access-checking routine gave up
868and returned FALSE, just to be conservative. (Note: The access-checking
be771a83
GS
869routine knows about the Perl C<stat> operator and file tests, so you
870shouldn't ever see this warning in response to a Perl command; it arises
871only if some internal code takes stat buffers lightly.)
748a9306 872
a0d0e21e
LW
873=item Can't get pipe mailbox device name
874
be771a83
GS
875(P) An error peculiar to VMS. After creating a mailbox to act as a
876pipe, Perl can't retrieve its name for later use.
a0d0e21e
LW
877
878=item Can't get SYSGEN parameter value for MAXBUF
879
748a9306
LW
880(P) An error peculiar to VMS. Perl asked $GETSYI how big you want your
881mailbox buffers to be, and didn't get an answer.
a0d0e21e 882
6df41af2 883=item Can't "goto" into the middle of a foreach loop
a0d0e21e 884
be771a83
GS
885(F) A "goto" statement was executed to jump into the middle of a foreach
886loop. You can't get there from here. See L<perlfunc/goto>.
6df41af2
GS
887
888=item Can't "goto" out of a pseudo block
889
be771a83
GS
890(F) A "goto" statement was executed to jump out of what might look like
891a block, except that it isn't a proper block. This usually occurs if
892you tried to jump out of a sort() block or subroutine, which is a no-no.
893See L<perlfunc/goto>.
a0d0e21e 894
9850bf21 895=item Can't goto subroutine from a sort sub (or similar callback)
cd299c6e 896
9850bf21
RH
897(F) The "goto subroutine" call can't be used to jump out of the
898comparison sub for a sort(), or from a similar callback (such
899as the reduce() function in List::Util).
900
c74ace89 901=item Can't goto subroutine from an eval-%s
b150fb22 902
be771a83 903(F) The "goto subroutine" call can't be used to jump out of an eval
c74ace89 904"string" or block.
b150fb22 905
6df41af2
GS
906=item Can't goto subroutine outside a subroutine
907
be771a83
GS
908(F) The deeply magical "goto subroutine" call can only replace one
909subroutine call for another. It can't manufacture one out of whole
910cloth. In general you should be calling it out of only an AUTOLOAD
911routine anyway. See L<perlfunc/goto>.
6df41af2 912
0b5b802d
GS
913=item Can't ignore signal CHLD, forcing to default
914
be771a83
GS
915(W signal) Perl has detected that it is being run with the SIGCHLD
916signal (sometimes known as SIGCLD) disabled. Since disabling this
917signal will interfere with proper determination of exit status of child
918processes, Perl has reset the signal to its default value. This
919situation typically indicates that the parent program under which Perl
920may be running (e.g. cron) is being very careless.
0b5b802d 921
e2c0f81f
DG
922=item Can't kill a non-numeric process ID
923
924(F) Process identifiers must be (signed) integers. It is a fatal error to
925attempt to kill() an undefined, empty-string or otherwise non-numeric
926process identifier.
927
6df41af2 928=item Can't "last" outside a loop block
4633a7c4 929
6df41af2 930(F) A "last" statement was executed to break out of the current block,
be771a83
GS
931except that there's this itty bitty problem called there isn't a current
932block. Note that an "if" or "else" block doesn't count as a "loopish"
933block, as doesn't a block given to sort(), map() or grep(). You can
934usually double the curlies to get the same effect though, because the
935inner curlies will be considered a block that loops once. See
936L<perlfunc/last>.
4633a7c4 937
2c7d6b9c
RGS
938=item Can't linearize anonymous symbol table
939
940(F) Perl tried to calculate the method resolution order (MRO) of a
941package, but failed because the package stash has no name.
942
b8170e59
JB
943=item Can't load '%s' for module %s
944
6903afa2
FC
945(F) The module you tried to load failed to load a dynamic extension.
946This may either mean that you upgraded your version of perl to one
947that is incompatible with your old dynamic extensions (which is known
948to happen between major versions of perl), or (more likely) that your
949dynamic extension was built against an older version of the library
950that is installed on your system. You may need to rebuild your old
951dynamic extensions.
b8170e59 952
748a9306
LW
953=item Can't localize lexical variable %s
954
2ba9eb46 955(F) You used local on a variable name that was previously declared as a
b7e4ecc1
FC
956lexical variable using "my" or "state". This is not allowed. If you
957want to localize a package variable of the same name, qualify it with
958the package name.
748a9306 959
6df41af2 960=item Can't localize through a reference
4727527e 961
6df41af2
GS
962(F) You said something like C<local $$ref>, which Perl can't currently
963handle, because when it goes to restore the old value of whatever $ref
be771a83 964pointed to after the scope of the local() is finished, it can't be sure
64977eb6 965that $ref will still be a reference.
4727527e 966
ea071790 967=item Can't locate %s
ec889f3a 968
fa816bf3
FC
969(F) You said to C<do> (or C<require>, or C<use>) a file that couldn't be found.
970Perl looks for the file in all the locations mentioned in @INC, unless
971the file name included the full path to the file. Perhaps you need
972to set the PERL5LIB or PERL5OPT environment variable to say where the
973extra library is, or maybe the script needs to add the library name
be771a83
GS
974to @INC. Or maybe you just misspelled the name of the file. See
975L<perlfunc/require> and L<lib>.
a0d0e21e 976
6df41af2
GS
977=item Can't locate auto/%s.al in @INC
978
be771a83
GS
979(F) A function (or method) was called in a package which allows
980autoload, but there is no function to autoload. Most probable causes
981are a misprint in a function/method name or a failure to C<AutoSplit>
982the file, say, by doing C<make install>.
6df41af2 983
b8170e59
JB
984=item Can't locate loadable object for module %s in @INC
985
986(F) The module you loaded is trying to load an external library, like
d70d8e57 987for example, F<foo.so> or F<bar.dll>, but the L<DynaLoader> module was
b8170e59
JB
988unable to locate this library. See L<DynaLoader>.
989
a0d0e21e
LW
990=item Can't locate object method "%s" via package "%s"
991
992(F) You called a method correctly, and it correctly indicated a package
993functioning as a class, but that package doesn't define that particular
2ba9eb46 994method, nor does any of its base classes. See L<perlobj>.
a0d0e21e
LW
995
996=item Can't locate package %s for @%s::ISA
997
be771a83
GS
998(W syntax) The @ISA array contained the name of another package that
999doesn't seem to exist.
a0d0e21e 1000
2f7da168
RK
1001=item Can't locate PerlIO%s
1002
1003(F) You tried to use in open() a PerlIO layer that does not exist,
1004e.g. open(FH, ">:nosuchlayer", "somefile").
1005
f4ad53f4 1006=item Can't make list assignment to %ENV on this system
3e3baf6d 1007
be771a83
GS
1008(F) List assignment to %ENV is not supported on some systems, notably
1009VMS.
3e3baf6d 1010
a0d0e21e
LW
1011=item Can't modify %s in %s
1012
be771a83
GS
1013(F) You aren't allowed to assign to the item indicated, or otherwise try
1014to change it, such as with an auto-increment.
a0d0e21e 1015
54310121 1016=item Can't modify nonexistent substring
a0d0e21e
LW
1017
1018(P) The internal routine that does assignment to a substr() was handed
1019a NULL.
1020
6df41af2
GS
1021=item Can't modify non-lvalue subroutine call
1022
1023(F) Subroutines meant to be used in lvalue context should be declared as
2fe2bdfd 1024such. See L<perlsub/"Lvalue subroutines">.
6df41af2 1025
5f05dabc 1026=item Can't msgrcv to read-only var
a0d0e21e 1027
5f05dabc 1028(F) The target of a msgrcv must be modifiable to be used as a receive
a0d0e21e
LW
1029buffer.
1030
6df41af2
GS
1031=item Can't "next" outside a loop block
1032
1033(F) A "next" statement was executed to reiterate the current block, but
1034there isn't a current block. Note that an "if" or "else" block doesn't
be771a83
GS
1035count as a "loopish" block, as doesn't a block given to sort(), map() or
1036grep(). You can usually double the curlies to get the same effect
1037though, because the inner curlies will be considered a block that loops
1038once. See L<perlfunc/next>.
6df41af2 1039
46fa9b26
FC
1040=item Can't open %s
1041
1042(F) You tried to run a perl built with MAD support with
1043the PERL_XMLDUMP environment variable set, but the file
1044named by that variable could not be opened.
1045
a0d0e21e
LW
1046=item Can't open %s: %s
1047
c47ff5f1 1048(S inplace) The implicit opening of a file through use of the C<< <> >>
08e9d68e 1049filehandle, either implicitly under the C<-n> or C<-p> command-line
46fa9b26
FC
1050switches, or explicitly, failed for the indicated reason. Usually
1051this is because you don't have read permission for a file which
1052you named on the command line.
1053
1054(F) You tried to call perl with the B<-e> switch, but F</dev/null> (or
1055your operating system's equivalent) could not be opened.
a0d0e21e 1056
9a869a14
RGS
1057=item Can't open a reference
1058
1059(W io) You tried to open a scalar reference for reading or writing,
2fe2bdfd 1060using the 3-arg open() syntax:
9a869a14
RGS
1061
1062 open FH, '>', $ref;
1063
1064but your version of perl is compiled without perlio, and this form of
1065open is not supported.
1066
a0d0e21e
LW
1067=item Can't open bidirectional pipe
1068
be771a83
GS
1069(W pipe) You tried to say C<open(CMD, "|cmd|")>, which is not supported.
1070You can try any of several modules in the Perl library to do this, such
1071as IPC::Open2. Alternately, direct the pipe's output to a file using
1072">", and then read it in under a different file handle.
a0d0e21e 1073
748a9306
LW
1074=item Can't open error file %s as stderr
1075
be771a83
GS
1076(F) An error peculiar to VMS. Perl does its own command line
1077redirection, and couldn't open the file specified after '2>' or '2>>' on
1078the command line for writing.
748a9306
LW
1079
1080=item Can't open input file %s as stdin
1081
be771a83
GS
1082(F) An error peculiar to VMS. Perl does its own command line
1083redirection, and couldn't open the file specified after '<' on the
1084command line for reading.
748a9306
LW
1085
1086=item Can't open output file %s as stdout
1087
be771a83
GS
1088(F) An error peculiar to VMS. Perl does its own command line
1089redirection, and couldn't open the file specified after '>' or '>>' on
1090the command line for writing.
748a9306
LW
1091
1092=item Can't open output pipe (name: %s)
1093
be771a83
GS
1094(P) An error peculiar to VMS. Perl does its own command line
1095redirection, and couldn't open the pipe into which to send data destined
1096for stdout.
748a9306 1097
3b1cf97d 1098=item Can't open perl script "%s": %s
a0d0e21e
LW
1099
1100(F) The script you specified can't be opened for the indicated reason.
1101
fa3aa65a
JC
1102If you're debugging a script that uses #!, and normally relies on the
1103shell's $PATH search, the -S option causes perl to do that search, so
1104you don't have to type the path or C<`which $scriptname`>.
1105
6df41af2
GS
1106=item Can't read CRTL environ
1107
1108(S) A warning peculiar to VMS. Perl tried to read an element of %ENV
1109from the CRTL's internal environment array and discovered the array was
1110missing. You need to figure out where your CRTL misplaced its environ
be771a83
GS
1111or define F<PERL_ENV_TABLES> (see L<perlvms>) so that environ is not
1112searched.
6df41af2 1113
6df41af2
GS
1114=item Can't "redo" outside a loop block
1115
1116(F) A "redo" statement was executed to restart the current block, but
1117there isn't a current block. Note that an "if" or "else" block doesn't
1118count as a "loopish" block, as doesn't a block given to sort(), map()
1119or grep(). You can usually double the curlies to get the same effect
1120though, because the inner curlies will be considered a block that
1121loops once. See L<perlfunc/redo>.
1122
64977eb6 1123=item Can't remove %s: %s, skipping file
10f9c03d 1124
be771a83
GS
1125(S inplace) You requested an inplace edit without creating a backup
1126file. Perl was unable to remove the original file to replace it with
1127the modified file. The file was left unmodified.
10f9c03d 1128
a0d0e21e
LW
1129=item Can't rename %s to %s: %s, skipping file
1130
e476b1b5 1131(S inplace) The rename done by the B<-i> switch failed for some reason,
10f9c03d 1132probably because you don't have write permission to the directory.
a0d0e21e 1133
748a9306
LW
1134=item Can't reopen input pipe (name: %s) in binary mode
1135
be771a83
GS
1136(P) An error peculiar to VMS. Perl thought stdin was a pipe, and tried
1137to reopen it to accept binary data. Alas, it failed.
748a9306 1138
4f12ec0e
FC
1139=item Can't reset %ENV on this system
1140
1141(F) You called C<reset('E')> or similar, which tried to reset
1142all variables in the current package beginning with "E". In
1143the main package, that includes %ENV. Resetting %ENV is not
1144supported on some systems, notably VMS.
1145
fe13d51d 1146=item Can't resolve method "%s" overloading "%s" in package "%s"
6df41af2 1147
1fa582fa
FC
1148(F)(P) Error resolving overloading specified by a method name (as
1149opposed to a subroutine reference): no such method callable via the
1150package. If the method name is C<???>, this is an internal error.
6df41af2 1151
cd06dffe
GS
1152=item Can't return %s from lvalue subroutine
1153
be771a83
GS
1154(F) Perl detected an attempt to return illegal lvalues (such as
1155temporary or readonly values) from a subroutine used as an lvalue. This
1156is not allowed.
cd06dffe 1157
96ebfdd7
RK
1158=item Can't return outside a subroutine
1159
1160(F) The return statement was executed in mainline code, that is, where
1161there was no subroutine call to return out of. See L<perlsub>.
1162
78f9721b
SM
1163=item Can't return %s to lvalue scalar context
1164
6903afa2
FC
1165(F) You tried to return a complete array or hash from an lvalue
1166subroutine, but you called the subroutine in a way that made Perl
1167think you meant to return only one value. You probably meant to
1168write parentheses around the call to the subroutine, which tell
1169Perl that the call should be in list context.
78f9721b 1170
a0d0e21e
LW
1171=item Can't stat script "%s"
1172
be771a83
GS
1173(P) For some reason you can't fstat() the script even though you have it
1174open already. Bizarre.
a0d0e21e 1175
a0d0e21e
LW
1176=item Can't take log of %g
1177
fb73857a 1178(F) For ordinary real numbers, you can't take the logarithm of a
6903afa2 1179negative number or zero. There's a Math::Complex package that comes
be771a83
GS
1180standard with Perl, though, if you really want to do that for the
1181negative numbers.
a0d0e21e
LW
1182
1183=item Can't take sqrt of %g
1184
1185(F) For ordinary real numbers, you can't take the square root of a
fb73857a 1186negative number. There's a Math::Complex package that comes standard
1187with Perl, though, if you really want to do that.
a0d0e21e
LW
1188
1189=item Can't undef active subroutine
1190
1191(F) You can't undefine a routine that's currently running. You can,
1192however, redefine it while it's running, and you can even undef the
1193redefined subroutine while the old routine is running. Go figure.
1194
c81225bc 1195=item Can't upgrade %s (%d) to %d
a0d0e21e 1196
be771a83
GS
1197(P) The internal sv_upgrade routine adds "members" to an SV, making it
1198into a more specialized kind of SV. The top several SV types are so
1199specialized, however, that they cannot be interconverted. This message
1200indicates that such a conversion was attempted.
a0d0e21e 1201
6651ba0b
FC
1202=item Can't use '%c' after -mname
1203
1204(F) You tried to call perl with the B<-m> switch, but you put something
1205other than "=" after the module name.
1206
1db89ea5
BS
1207=item Can't use anonymous symbol table for method lookup
1208
e27ad1f2 1209(F) The internal routine that does method lookup was handed a symbol
1db89ea5
BS
1210table that doesn't have a name. Symbol tables can become anonymous
1211for example by undefining stashes: C<undef %Some::Package::>.
1212
96ebfdd7
RK
1213=item Can't use an undefined value as %s reference
1214
1215(F) A value used as either a hard reference or a symbolic reference must
1216be a defined value. This helps to delurk some insidious errors.
1217
6df41af2
GS
1218=item Can't use bareword ("%s") as %s ref while "strict refs" in use
1219
be771a83
GS
1220(F) Only hard references are allowed by "strict refs". Symbolic
1221references are disallowed. See L<perlref>.
6df41af2 1222
90b75b61 1223=item Can't use %! because Errno.pm is not available
1d2dff63 1224
20561843 1225(F) The first time the C<%!> hash is used, perl automatically loads the
6903afa2 1226Errno.pm module. The Errno module is expected to tie the %! hash to
1d2dff63
GS
1227provide symbolic names for C<$!> errno values.
1228
1109a392
MHM
1229=item Can't use both '<' and '>' after type '%c' in %s
1230
1231(F) A type cannot be forced to have both big-endian and little-endian
1232byte-order at the same time, so this combination of modifiers is not
1233allowed. See L<perlfunc/pack>.
1234
6df41af2
GS
1235=item Can't use %s for loop variable
1236
be771a83
GS
1237(F) Only a simple scalar variable may be used as a loop variable on a
1238foreach.
6df41af2 1239
aab6a793 1240=item Can't use global %s in "%s"
6df41af2 1241
be771a83
GS
1242(F) You tried to declare a magical variable as a lexical variable. This
1243is not allowed, because the magic can be tied to only one location
1244(namely the global variable) and it would be incredibly confusing to
1245have variables in your program that looked like magical variables but
6df41af2
GS
1246weren't.
1247
6d3b25aa
RGS
1248=item Can't use '%c' in a group with different byte-order in %s
1249
1250(F) You attempted to force a different byte-order on a type
1251that is already inside a group with a byte-order modifier.
1252For example you cannot force little-endianness on a type that
1253is inside a big-endian group.
1254
c07a80fd 1255=item Can't use "my %s" in sort comparison
1256
1257(F) The global variables $a and $b are reserved for sort comparisons.
c47ff5f1 1258You mentioned $a or $b in the same line as the <=> or cmp operator,
c07a80fd 1259and the variable had earlier been declared as a lexical variable.
1260Either qualify the sort variable with the package name, or rename the
1261lexical variable.
1262
a0d0e21e
LW
1263=item Can't use %s ref as %s ref
1264
1265(F) You've mixed up your reference types. You have to dereference a
1266reference of the type needed. You can use the ref() function to
1267test the type of the reference, if need be.
1268
748a9306 1269=item Can't use string ("%s") as %s ref while "strict refs" in use
a0d0e21e 1270
be771a83
GS
1271(F) Only hard references are allowed by "strict refs". Symbolic
1272references are disallowed. See L<perlref>.
a0d0e21e 1273
748a9306
LW
1274=item Can't use subscript on %s
1275
1276(F) The compiler tried to interpret a bracketed expression as a
1277subscript. But to the left of the brackets was an expression that
209e7cf1 1278didn't look like a hash or array reference, or anything else subscriptable.
748a9306 1279
6df41af2
GS
1280=item Can't use \%c to mean $%c in expression
1281
75b44862
GS
1282(W syntax) In an ordinary expression, backslash is a unary operator that
1283creates a reference to its argument. The use of backslash to indicate a
1284backreference to a matched substring is valid only as part of a regular
be771a83
GS
1285expression pattern. Trying to do this in ordinary Perl code produces a
1286value that prints out looking like SCALAR(0xdecaf). Use the $1 form
1287instead.
6df41af2 1288
810b8aa5
GS
1289=item Can't weaken a nonreference
1290
1291(F) You attempted to weaken something that was not a reference. Only
1292references can be weakened.
1293
fc7debfb
FC
1294=item Can't "when" outside a topicalizer
1295
1296(F) You have used a when() block that is neither inside a C<foreach>
1297loop nor a C<given> block. (Note that this error is issued on exit
1298from the C<when> block, so you won't get the error if the match fails,
1299or if you use an explicit C<continue>.)
1300
5f05dabc 1301=item Can't x= to read-only value
a0d0e21e 1302
be771a83
GS
1303(F) You tried to repeat a constant value (often the undefined value)
1304with an assignment operator, which implies modifying the value itself.
a0d0e21e
LW
1305Perhaps you need to copy the value to a temporary, and repeat that.
1306
4a68bf9d 1307=item Character following "\c" must be ASCII
f9d13529 1308
1fa582fa 1309(F)(W deprecated, syntax) In C<\cI<X>>, I<X> must be an ASCII character.
79ef86ee 1310It is planned to make this fatal in all instances in Perl 5.18. In the
17a3df4c
KW
1311cases where it isn't fatal, the character this evaluates to is
1312derived by exclusive or'ing the code point of this character with 0x40.
1313
1314Note that non-alphabetic ASCII characters are discouraged here as well.
f9d13529 1315
f337b084 1316=item Character in 'C' format wrapped in pack
ac7cd81a
SC
1317
1318(W pack) You said
1319
1320 pack("C", $x)
1321
1322where $x is either less than 0 or more than 255; the C<"C"> format is
1323only for encoding native operating system characters (ASCII, EBCDIC,
1324and so on) and not for Unicode characters, so Perl behaved as if you meant
1325
1326 pack("C", $x & 255)
1327
1328If you actually want to pack Unicode codepoints, use the C<"U"> format
1329instead.
1330
f337b084
TH
1331=item Character in 'W' format wrapped in pack
1332
1333(W pack) You said
1334
1335 pack("U0W", $x)
1336
6903afa2
FC
1337where $x is either less than 0 or more than 255. However, C<U0>-mode
1338expects all values to fall in the interval [0, 255], so Perl behaved
1339as if you meant:
f337b084
TH
1340
1341 pack("U0W", $x & 255)
1342
1343=item Character in 'c' format wrapped in pack
ac7cd81a
SC
1344
1345(W pack) You said
1346
1347 pack("c", $x)
1348
1349where $x is either less than -128 or more than 127; the C<"c"> format
1350is only for encoding native operating system characters (ASCII, EBCDIC,
1351and so on) and not for Unicode characters, so Perl behaved as if you meant
1352
1353 pack("c", $x & 255);
1354
1355If you actually want to pack Unicode codepoints, use the C<"U"> format
1356instead.
1357
f337b084
TH
1358=item Character in '%c' format wrapped in unpack
1359
1360(W unpack) You tried something like
1361
1362 unpack("H", "\x{2a1}")
1363
1a147d38 1364where the format expects to process a byte (a character with a value
6903afa2
FC
1365below 256), but a higher value was provided instead. Perl uses the
1366value modulus 256 instead, as if you had provided:
f337b084
TH
1367
1368 unpack("H", "\x{a1}")
1369
1370=item Character(s) in '%c' format wrapped in pack
1371
1372(W pack) You tried something like
1373
1374 pack("u", "\x{1f3}b")
1375
1a147d38 1376where the format expects to process a sequence of bytes (character with a
6903afa2 1377value below 256), but some of the characters had a higher value. Perl
f337b084
TH
1378uses the character values modulus 256 instead, as if you had provided:
1379
1380 pack("u", "\x{f3}b")
1381
1382=item Character(s) in '%c' format wrapped in unpack
1383
1384(W unpack) You tried something like
1385
1386 unpack("s", "\x{1f3}b")
1387
1a147d38 1388where the format expects to process a sequence of bytes (character with a
6903afa2 1389value below 256), but some of the characters had a higher value. Perl
f337b084
TH
1390uses the character values modulus 256 instead, as if you had provided:
1391
1392 unpack("s", "\x{f3}b")
1393
f866a7cd
FC
1394=item "\c{" is deprecated and is more clearly written as ";"
1395
1396(D deprecated, syntax) The C<\cI<X>> construct is intended to be a way
1397to specify non-printable characters. You used it with a "{" which
1398evaluates to ";", which is printable. It is planned to remove the
79ef86ee 1399ability to specify a semi-colon this way in Perl 5.18. Just use a
f866a7cd
FC
1400semi-colon or a backslash-semi-colon without the "\c".
1401
1402=item "\c%c" is more clearly written simply as "%s"
1403
1404(W syntax) The C<\cI<X>> construct is intended to be a way to specify
1405non-printable characters. You used it for a printable one, which is better
1406written as simply itself, perhaps preceded by a backslash for non-word
1407characters.
1408
6651ba0b
FC
1409=item Cloning substitution context is unimplemented
1410
1411(F) Creating a new thread inside the C<s///> operator is not supported.
1412
96ebfdd7
RK
1413=item close() on unopened filehandle %s
1414
1415(W unopened) You tried to close a filehandle that was never opened.
1416
abc7ecad
SP
1417=item closedir() attempted on invalid dirhandle %s
1418
1419(W io) The dirhandle you tried to close is either closed or not really
1420a dirhandle. Check your control flow.
1421
541ed3a9
FC
1422=item Closure prototype called
1423
1424(F) If a closure has attributes, the subroutine passed to an attribute
1425handler is the prototype that is cloned when a new closure is created.
1426This subroutine cannot be called.
1427
49704364
WL
1428=item Code missing after '/'
1429
6903afa2
FC
1430(F) You had a (sub-)template that ends with a '/'. There must be
1431another template code following the slash. See L<perlfunc/pack>.
49704364 1432
0876b9a0
KW
1433=item Code point 0x%X is not Unicode, may not be portable
1434
c634fdd3 1435=item Code point 0x%X is not Unicode, all \p{} matches fail; all \P{} matches succeed
9ae3ac1a 1436
1b64326b
FC
1437(W utf8, non_unicode) You had a code point above the Unicode maximum
1438of U+10FFFF.
1439
1440Perl allows strings to contain a superset of Unicode code points, up
1441to the limit of what is storable in an unsigned integer on your system,
1442but these may not be accepted by other languages/systems. At one time,
1443it was legal in some standards to have code points up to 0x7FFF_FFFF,
1444but not higher. Code points above 0xFFFF_FFFF require larger than a
144532 bit word.
0876b9a0 1446
9ae3ac1a
KW
1447None of the Unicode or Perl-defined properties will match a non-Unicode
1448code point. For example,
1449
1450 chr(0x7FF_FFFF) =~ /\p{Any}/
1451
1452will not match, because the code point is not in Unicode. But
1453
1454 chr(0x7FF_FFFF) =~ /\P{Any}/
1455
1456will match.
1457
94b42e47
KW
1458This may be counterintuitive at times, as both these fail:
1459
1460 chr(0x110000) =~ \p{ASCII_Hex_Digit=True} # Fails.
1461 chr(0x110000) =~ \p{ASCII_Hex_Digit=False} # Also fails!
1462
1463and both these succeed:
1464
1465 chr(0x110000) =~ \P{ASCII_Hex_Digit=True} # Succeeds.
1466 chr(0x110000) =~ \P{ASCII_Hex_Digit=False} # Also succeeds!
1467
6df41af2
GS
1468=item %s: Command not found
1469
a892b81a
FC
1470(A) You've accidentally run your script through B<csh> or another shell
1471shell instead of Perl. Check the #! line, or manually feed your script
1472into Perl yourself. The #! line at the top of your file could look like
8f721816
MM
1473
1474 #!/usr/bin/perl -w
6df41af2 1475
7a2e2cd6 1476=item Compilation failed in require
1477
1478(F) Perl could not compile a file specified in a C<require> statement.
be771a83
GS
1479Perl uses this generic message when none of the errors that it
1480encountered were severe enough to halt compilation immediately.
7a2e2cd6 1481
c3464db5
DD
1482=item Complex regular subexpression recursion limit (%d) exceeded
1483
be771a83
GS
1484(W regexp) The regular expression engine uses recursion in complex
1485situations where back-tracking is required. Recursion depth is limited
1486to 32766, or perhaps less in architectures where the stack cannot grow
1487arbitrarily. ("Simple" and "medium" situations are handled without
1488recursion and are not subject to a limit.) Try shortening the string
1489under examination; looping in Perl code (e.g. with C<while>) rather than
1490in the regular expression engine; or rewriting the regular expression so
c2e66d9e 1491that it is simpler or backtracks less. (See L<perlfaq2> for information
be771a83 1492on I<Mastering Regular Expressions>.)
c3464db5 1493
38875929
DM
1494=item cond_broadcast() called on unlocked variable
1495
6903afa2
FC
1496(W threads) Within a thread-enabled program, you tried to
1497call cond_broadcast() on a variable which wasn't locked.
1498The cond_broadcast() function is used to wake up another thread
1499that is waiting in a cond_wait(). To ensure that the signal isn't
1500sent before the other thread has a chance to enter the wait, it
1501is usual for the signaling thread first to wait for a lock on
1502variable. This lock attempt will only succeed after the other
1503thread has entered cond_wait() and thus relinquished the lock.
38875929 1504
38875929
DM
1505=item cond_signal() called on unlocked variable
1506
6903afa2
FC
1507(W threads) Within a thread-enabled program, you tried to
1508call cond_signal() on a variable which wasn't locked. The
1509cond_signal() function is used to wake up another thread that
1510is waiting in a cond_wait(). To ensure that the signal isn't
1511sent before the other thread has a chance to enter the wait, it
1512is usual for the signaling thread first to wait for a lock on
1513variable. This lock attempt will only succeed after the other
1514thread has entered cond_wait() and thus relinquished the lock.
38875929 1515
69282e91 1516=item connect() on closed socket %s
a0d0e21e 1517
be771a83
GS
1518(W closed) You tried to do a connect on a closed socket. Did you forget
1519to check the return value of your socket() call? See
1520L<perlfunc/connect>.
a0d0e21e 1521
41ab332f 1522=item Constant(%s)%s: %s
6df41af2 1523
be771a83
GS
1524(F) The parser found inconsistencies either while attempting to define
1525an overloaded constant, or when trying to find the character name
1526specified in the C<\N{...}> escape. Perhaps you forgot to load the
fbb93542 1527corresponding L<overload> pragma?.
6df41af2 1528
fc8cd66c
YO
1529=item Constant(%s)%s: %s in regex; marked by <-- HERE in m/%s/
1530
1a147d38 1531(F) The parser found inconsistencies while attempting to find
fbb93542 1532the character name specified in the C<\N{...}> escape.
fc8cd66c 1533
779c5bc9
GS
1534=item Constant is not %s reference
1535
1536(F) A constant value (perhaps declared using the C<use constant> pragma)
be771a83 1537is being dereferenced, but it amounts to the wrong type of reference.
6903afa2 1538The message indicates the type of reference that was expected. This
be771a83 1539usually indicates a syntax error in dereferencing the constant value.
779c5bc9
GS
1540See L<perlsub/"Constant Functions"> and L<constant>.
1541
4cee8e80
CS
1542=item Constant subroutine %s redefined
1543
aeb94125
FC
1544(W redefine)(S) You redefined a subroutine which had previously
1545been eligible for inlining. See L<perlsub/"Constant Functions">
1546for commentary and workarounds.
4cee8e80 1547
9607fc9c 1548=item Constant subroutine %s undefined
1549
be771a83
GS
1550(W misc) You undefined a subroutine which had previously been eligible
1551for inlining. See L<perlsub/"Constant Functions"> for commentary and
1552workarounds.
9607fc9c 1553
e7ea3e70
IZ
1554=item Copy method did not return a reference
1555
6903afa2 1556(F) The method which overloads "=" is buggy. See
13a2d996 1557L<overload/Copy Constructor>.
e7ea3e70 1558
4aaa4757
FC
1559=item &CORE::%s cannot be called directly
1560
1561(F) You tried to call a subroutine in the C<CORE::> namespace
8d605c0d 1562with C<&foo> syntax or through a reference. Some subroutines
4aaa4757
FC
1563in this package cannot yet be called that way, but must be
1564called as barewords. Something like this will work:
1565
1566 BEGIN { *shove = \&CORE::push; }
1567 shove @array, 1,2,3; # pushes on to @array
1568
6798c92b
GS
1569=item CORE::%s is not a keyword
1570
1571(F) The CORE:: namespace is reserved for Perl keywords.
1572
a0d0e21e
LW
1573=item corrupted regexp pointers
1574
1575(P) The regular expression engine got confused by what the regular
1576expression compiler gave it.
1577
1578=item corrupted regexp program
1579
be771a83
GS
1580(P) The regular expression engine got passed a regexp program without a
1581valid magic number.
a0d0e21e 1582
de42a5a9 1583=item Corrupt malloc ptr 0x%x at 0x%x
6df41af2
GS
1584
1585(P) The malloc package that comes with Perl had an internal failure.
1586
49704364
WL
1587=item Count after length/code in unpack
1588
1589(F) You had an unpack template indicating a counted-length string, but
1590you have also specified an explicit size for the string. See
1591L<perlfunc/pack>.
1592
6651ba0b
FC
1593=item Deep recursion on anonymous subroutine
1594
a0d0e21e
LW
1595=item Deep recursion on subroutine "%s"
1596
be771a83
GS
1597(W recursion) This subroutine has called itself (directly or indirectly)
1598100 times more than it has returned. This probably indicates an
1599infinite recursion, unless you're writing strange benchmark programs, in
1600which case it indicates something else.
a0d0e21e 1601
aad1d01f
NC
1602This threshold can be changed from 100, by recompiling the F<perl> binary,
1603setting the C pre-processor macro C<PERL_SUB_DEPTH_WARN> to the desired value.
1604
f10b0346 1605=item defined(@array) is deprecated
69794302 1606
be771a83
GS
1607(D deprecated) defined() is not usually useful on arrays because it
1608checks for an undefined I<scalar> value. If you want to see if the
64977eb6 1609array is empty, just use C<if (@array) { # not empty }> for example.
69794302 1610
f10b0346 1611=item defined(%hash) is deprecated
69794302 1612
f0ec9725
KR
1613(D deprecated) C<defined()> is not usually right on hashes and has been
1614discouraged since 5.004.
1615
1616Although C<defined %hash> is false on a plain not-yet-used hash, it
1617becomes true in several non-obvious circumstances, including iterators,
1618weak references, stash names, even remaining true after C<undef %hash>.
1619These things make C<defined %hash> fairly useless in practice.
1620
1621If a check for non-empty is what you wanted then just put it in boolean
1622context (see L<perldata/Scalar values>):
16546e45
KR
1623
1624 if (%hash) {
1625 # not empty
1626 }
1627
f0ec9725
KR
1628If you had C<defined %Foo::Bar::QUUX> to check whether such a package
1629variable exists then that's never really been reliable, and isn't
1630a good way to enquire about the features of a package, or whether
1631it's loaded, etc.
1632
69794302 1633
bcb95744
FC
1634=item (?(DEFINE)....) does not allow branches in regex; marked by <-- HERE in m/%s/
1635
6903afa2 1636(F) You used something like C<(?(DEFINE)...|..)> which is illegal. The
bcb95744
FC
1637most likely cause of this error is that you left out a parenthesis inside
1638of the C<....> part.
1639
1640The <-- HERE shows in the regular expression about where the problem was
1641discovered.
1642
62658f4d
PM
1643=item %s defines neither package nor VERSION--version check failed
1644
1645(F) You said something like "use Module 42" but in the Module file
1646there are neither package declarations nor a C<$VERSION>.
1647
fc36a67e 1648=item Delimiter for here document is too long
1649
be771a83
GS
1650(F) In a here document construct like C<<<FOO>, the label C<FOO> is too
1651long for Perl to handle. You have to be seriously twisted to write code
1652that triggers this error.
fc36a67e 1653
4a68bf9d 1654=item Deprecated character in \N{...}; marked by <-- HERE in \N{%s<-- HERE %s
cb233ae3
KW
1655
1656(D deprecated) Just about anything is legal for the C<...> in C<\N{...}>.
5fca8acb
FC
1657But starting in 5.12, non-reasonable ones that don't look like names
1658are deprecated. A reasonable name begins with an alphabetic character
1659and continues with any combination of alphanumerics, dashes, spaces,
1660parentheses or colons.
cb233ae3 1661
6d3b25aa
RGS
1662=item Deprecated use of my() in false conditional
1663
fa816bf3
FC
1664(D deprecated) You used a declaration similar to C<my $x if 0>. There
1665has been a long-standing bug in Perl that causes a lexical variable
6d3b25aa 1666not to be cleared at scope exit when its declaration includes a false
6903afa2 1667conditional. Some people have exploited this bug to achieve a kind of
fa816bf3 1668static variable. Since we intend to fix this bug, we don't want people
6903afa2 1669relying on this behavior. You can achieve a similar static effect by
6d3b25aa 1670declaring the variable in a separate block outside the function, eg
36fb85f3 1671
6d3b25aa
RGS
1672 sub f { my $x if 0; return $x++ }
1673
1674becomes
1675
1676 { my $x; sub f { return $x++ } }
1677
fa816bf3
FC
1678Beginning with perl 5.9.4, you can also use C<state> variables to have
1679lexicals that are initialized only once (see L<feature>):
36fb85f3
RGS
1680
1681 sub f { state $x; return $x++ }
1682
500ab966
RGS
1683=item DESTROY created new reference to dead object '%s'
1684
1685(F) A DESTROY() method created a new reference to the object which is
6903afa2
FC
1686just being DESTROYed. Perl is confused, and prefers to abort rather
1687than to create a dangling reference.
500ab966 1688
3cdd684c
TP
1689=item Did not produce a valid header
1690
1691See Server error.
1692
6df41af2
GS
1693=item %s did not return a true value
1694
1695(F) A required (or used) file must return a true value to indicate that
1696it compiled correctly and ran its initialization code correctly. It's
1697traditional to end such a file with a "1;", though any true value would
1698do. See L<perlfunc/require>.
1699
cc507455 1700=item (Did you mean &%s instead?)
4633a7c4 1701
413ff9f6
FC
1702(W misc) You probably referred to an imported subroutine &FOO as $FOO or
1703some such.
4633a7c4 1704
cc507455 1705=item (Did you mean "local" instead of "our"?)
33633739 1706
be771a83
GS
1707(W misc) Remember that "our" does not localize the declared global
1708variable. You have declared it again in the same lexical scope, which
1709seems superfluous.
33633739 1710
cc507455 1711=item (Did you mean $ or @ instead of %?)
a0d0e21e 1712
be771a83
GS
1713(W) You probably said %hash{$key} when you meant $hash{$key} or
1714@hash{@keys}. On the other hand, maybe you just meant %hash and got
1715carried away.
748a9306 1716
7e1af8bc 1717=item Died
5f05dabc 1718
1719(F) You passed die() an empty string (the equivalent of C<die "">) or
075b00aa 1720you called it with no args and C<$@> was empty.
5f05dabc 1721
3cdd684c
TP
1722=item Document contains no data
1723
1724See Server error.
1725
62658f4d
PM
1726=item %s does not define %s::VERSION--version check failed
1727
1728(F) You said something like "use Module 42" but the Module did not
1729define a C<$VERSION.>
1730
49704364
WL
1731=item '/' does not take a repeat count
1732
1733(F) You cannot put a repeat count of any kind right after the '/' code.
1734See L<perlfunc/pack>.
1735
a0d0e21e
LW
1736=item Don't know how to handle magic of type '%s'
1737
1738(P) The internal handling of magical variables has been cursed.
1739
1740=item do_study: out of memory
1741
1742(P) This should have been caught by safemalloc() instead.
1743
6df41af2
GS
1744=item (Do you need to predeclare %s?)
1745
56da5a46
RGS
1746(S syntax) This is an educated guess made in conjunction with the message
1747"%s found where operator expected". It often means a subroutine or module
6df41af2
GS
1748name is being referenced that hasn't been declared yet. This may be
1749because of ordering problems in your file, or because of a missing
be771a83
GS
1750"sub", "package", "require", or "use" statement. If you're referencing
1751something that isn't defined yet, you don't actually have to define the
1752subroutine or package before the current location. You can use an empty
1753"sub foo;" or "package FOO;" to enter a "forward" declaration.
6df41af2 1754
ac206dc8
RGS
1755=item dump() better written as CORE::dump()
1756
1757(W misc) You used the obsolescent C<dump()> built-in function, without fully
1758qualifying it as C<CORE::dump()>. Maybe it's a typo. See L<perlfunc/dump>.
1759
84d78eb7
YO
1760=item dump is not supported
1761
1762(F) Your machine doesn't support dump/undump.
1763
a0d0e21e
LW
1764=item Duplicate free() ignored
1765
be771a83
GS
1766(S malloc) An internal routine called free() on something that had
1767already been freed.
a0d0e21e 1768
1109a392
MHM
1769=item Duplicate modifier '%c' after '%c' in %s
1770
1771(W) You have applied the same modifier more than once after a type
1772in a pack template. See L<perlfunc/pack>.
1773
4633a7c4
LW
1774=item elseif should be elsif
1775
fa816bf3
FC
1776(S syntax) There is no keyword "elseif" in Perl because Larry thinks
1777it's ugly. Your code will be interpreted as an attempt to call a method
1778named "elseif" for the class returned by the following block. This is
4633a7c4
LW
1779unlikely to be what you want.
1780
ab13f0c7
JH
1781=item Empty %s
1782
af6f566e 1783(F) C<\p> and C<\P> are used to introduce a named Unicode property, as
6903afa2 1784described in L<perlunicode> and L<perlre>. You used C<\p> or C<\P> in
af6f566e 1785a regular expression without specifying the property name.
ab13f0c7 1786
85ab1d1d 1787=item entering effective %s failed
5ff3f7a4 1788
85ab1d1d 1789(F) While under the C<use filetest> pragma, switching the real and
5ff3f7a4
GS
1790effective uids or gids failed.
1791
c038024b
RGS
1792=item %ENV is aliased to %s
1793
1794(F) You're running under taint mode, and the C<%ENV> variable has been
1795aliased to another hash, so it doesn't reflect anymore the state of the
6903afa2 1796program's environment. This is potentially insecure.
c038024b 1797
748a9306
LW
1798=item Error converting file specification %s
1799
5f05dabc 1800(F) An error peculiar to VMS. Because Perl may have to deal with file
748a9306 1801specifications in either VMS or Unix syntax, it converts them to a
be771a83
GS
1802single form when it must operate on them directly. Either you've passed
1803an invalid file specification to Perl, or you've found a case the
1804conversion routines don't handle. Drat.
748a9306 1805
e4d48cc9
GS
1806=item %s: Eval-group in insecure regular expression
1807
be771a83
GS
1808(F) Perl detected tainted data when trying to compile a regular
1809expression that contains the C<(?{ ... })> zero-width assertion, which
1810is unsafe. See L<perlre/(?{ code })>, and L<perlsec>.
e4d48cc9 1811
fc8f615e 1812=item %s: Eval-group not allowed at runtime, use re 'eval'
e4d48cc9 1813
be771a83
GS
1814(F) Perl tried to compile a regular expression containing the
1815C<(?{ ... })> zero-width assertion at run time, as it would when the
f11307f5
FC
1816pattern contains interpolated values. Since that is a security risk,
1817it is not allowed. If you insist, you may still do this by using the
1818C<re 'eval'> pragma or by explicitly building the pattern from an
1819interpolated string at run time and using that in an eval(). See
1820L<perlre/(?{ code })>.
e4d48cc9 1821
6df41af2
GS
1822=item %s: Eval-group not allowed, use re 'eval'
1823
be771a83
GS
1824(F) A regular expression contained the C<(?{ ... })> zero-width
1825assertion, but that construct is only allowed when the C<use re 'eval'>
1826pragma is in effect. See L<perlre/(?{ code })>.
6df41af2 1827
1a147d38
YO
1828=item EVAL without pos change exceeded limit in regex; marked by <-- HERE in m/%s/
1829
1830(F) You used a pattern that nested too many EVAL calls without consuming
6903afa2 1831any text. Restructure the pattern so that text is consumed.
1a147d38
YO
1832
1833The <-- HERE shows in the regular expression about where the problem was
1834discovered.
1835
fc36a67e 1836=item Excessively long <> operator
1837
1838(F) The contents of a <> operator may not exceed the maximum size of a
1839Perl identifier. If you're just trying to glob a long list of
1840filenames, try using the glob() operator, or put the filenames into a
1841variable and glob that.
1842
ed9aa3b7
SG
1843=item exec? I'm not *that* kind of operating system
1844
af8bb25a 1845(F) The C<exec> function is not implemented on some systems, e.g., Symbian
6903afa2 1846OS. See L<perlport>.
ed9aa3b7 1847
fe13d51d 1848=item Execution of %s aborted due to compilation errors.
a0d0e21e
LW
1849
1850(F) The final summary message when a Perl compilation fails.
1851
1852=item Exiting eval via %s
1853
be771a83
GS
1854(W exiting) You are exiting an eval by unconventional means, such as a
1855goto, or a loop control statement.
e476b1b5
GS
1856
1857=item Exiting format via %s
1858
9a2ff54b 1859(W exiting) You are exiting a format by unconventional means, such as a
be771a83 1860goto, or a loop control statement.
a0d0e21e 1861
0a753a76 1862=item Exiting pseudo-block via %s
1863
be771a83
GS
1864(W exiting) You are exiting a rather special block construct (like a
1865sort block or subroutine) by unconventional means, such as a goto, or a
1866loop control statement. See L<perlfunc/sort>.
0a753a76 1867
a0d0e21e
LW
1868=item Exiting subroutine via %s
1869
be771a83
GS
1870(W exiting) You are exiting a subroutine by unconventional means, such
1871as a goto, or a loop control statement.
a0d0e21e
LW
1872
1873=item Exiting substitution via %s
1874
be771a83
GS
1875(W exiting) You are exiting a substitution by unconventional means, such
1876as a return, a goto, or a loop control statement.
a0d0e21e 1877
7b8d334a
GS
1878=item Explicit blessing to '' (assuming package main)
1879
be771a83
GS
1880(W misc) You are blessing a reference to a zero length string. This has
1881the effect of blessing the reference into the package main. This is
1882usually not what you want. Consider providing a default target package,
1883e.g. bless($ref, $p || 'MyPackage');
7b8d334a 1884
6df41af2
GS
1885=item %s: Expression syntax
1886
be771a83
GS
1887(A) You've accidentally run your script through B<csh> instead of Perl.
1888Check the #! line, or manually feed your script into Perl yourself.
6df41af2
GS
1889
1890=item %s failed--call queue aborted
1891
3c10abe3
AG
1892(F) An untrapped exception was raised while executing a UNITCHECK,
1893CHECK, INIT, or END subroutine. Processing of the remainder of the
1894queue of such routines has been prematurely ended.
6df41af2 1895
7253e4e3 1896=item False [] range "%s" in regex; marked by <-- HERE in m/%s/
73b437c8 1897
be771a83 1898(W regexp) A character class range must start and end at a literal
7253e4e3
RK
1899character, not another character class like C<\d> or C<[:alpha:]>. The "-"
1900in your false range is interpreted as a literal "-". Consider quoting the
1901"-", "\-". The <-- HERE shows in the regular expression about where the
1902problem was discovered. See L<perlre>.
73b437c8 1903
1b1ee2ef 1904=item Fatal VMS error (status=%d) at %s, line %d
a0d0e21e 1905
be771a83
GS
1906(P) An error peculiar to VMS. Something untoward happened in a VMS
1907system service or RTL routine; Perl's exit status should provide more
1908details. The filename in "at %s" and the line number in "line %d" tell
1909you which section of the Perl source code is distressed.
a0d0e21e
LW
1910
1911=item fcntl is not implemented
1912
1913(F) Your machine apparently doesn't implement fcntl(). What is this, a
1914PDP-11 or something?
1915
22846ab4
AB
1916=item FETCHSIZE returned a negative value
1917
1918(F) A tied array claimed to have a negative number of elements, which
1919is not possible.
1920
f337b084
TH
1921=item Field too wide in 'u' format in pack
1922
1923(W pack) Each line in an uuencoded string start with a length indicator
6903afa2
FC
1924which can't encode values above 63. So there is no point in asking for
1925a line length bigger than that. Perl will behave as if you specified
5c96f6f7 1926C<u63> as the format.
f337b084 1927
af8c498a 1928=item Filehandle %s opened only for input
a0d0e21e 1929
6c8d78fb
HS
1930(W io) You tried to write on a read-only filehandle. If you intended
1931it to be a read-write filehandle, you needed to open it with "+<" or
1932"+>" or "+>>" instead of with "<" or nothing. If you intended only to
1933write the file, use ">" or ">>". See L<perlfunc/open>.
a0d0e21e 1934
af8c498a 1935=item Filehandle %s opened only for output
a0d0e21e 1936
6c8d78fb
HS
1937(W io) You tried to read from a filehandle opened only for writing, If
1938you intended it to be a read/write filehandle, you needed to open it
89a1bda8
FC
1939with "+<" or "+>" or "+>>" instead of with ">". If you intended only to
1940read from the file, use "<". See L<perlfunc/open>. Another possibility
1941is that you attempted to open filedescriptor 0 (also known as STDIN) for
1942output (maybe you closed STDIN earlier?).
97828cef
RGS
1943
1944=item Filehandle %s reopened as %s only for input
1945
1946(W io) You opened for reading a filehandle that got the same filehandle id
6903afa2 1947as STDOUT or STDERR. This occurred because you closed STDOUT or STDERR
97828cef
RGS
1948previously.
1949
1950=item Filehandle STDIN reopened as %s only for output
1951
1952(W io) You opened for writing a filehandle that got the same filehandle id
fa816bf3 1953as STDIN. This occurred because you closed STDIN previously.
a0d0e21e
LW
1954
1955=item Final $ should be \$ or $name
1956
1957(F) You must now decide whether the final $ in a string was meant to be
be771a83
GS
1958a literal dollar sign, or was meant to introduce a variable name that
1959happens to be missing. So you have to put either the backslash or the
1960name.
a0d0e21e 1961
56e90b21
GS
1962=item flock() on closed filehandle %s
1963
be771a83 1964(W closed) The filehandle you're attempting to flock() got itself closed
c289d2f7 1965some time before now. Check your control flow. flock() operates on
be771a83
GS
1966filehandles. Are you attempting to call flock() on a dirhandle by the
1967same name?
56e90b21 1968
6df41af2
GS
1969=item Format not terminated
1970
1971(F) A format must be terminated by a line with a solitary dot. Perl got
1972to the end of your file without finding such a line.
1973
a0d0e21e
LW
1974=item Format %s redefined
1975
e476b1b5 1976(W redefine) You redefined a format. To suppress this warning, say
a0d0e21e
LW
1977
1978 {
271595cc 1979 no warnings 'redefine';
a0d0e21e
LW
1980 eval "format NAME =...";
1981 }
1982
a0d0e21e
LW
1983=item Found = in conditional, should be ==
1984
e476b1b5 1985(W syntax) You said
a0d0e21e
LW
1986
1987 if ($foo = 123)
1988
1989when you meant
1990
1991 if ($foo == 123)
1992
1993(or something like that).
1994
6df41af2
GS
1995=item %s found where operator expected
1996
56da5a46
RGS
1997(S syntax) The Perl lexer knows whether to expect a term or an operator.
1998If it sees what it knows to be a term when it was expecting to see an
be771a83
GS
1999operator, it gives you this warning. Usually it indicates that an
2000operator or delimiter was omitted, such as a semicolon.
6df41af2 2001
a0d0e21e
LW
2002=item gdbm store returned %d, errno %d, key "%s"
2003
2004(S) A warning from the GDBM_File extension that a store failed.
2005
2006=item gethostent not implemented
2007
2008(F) Your C library apparently doesn't implement gethostent(), probably
2009because if it did, it'd feel morally obligated to return every hostname
2010on the Internet.
2011
69282e91 2012=item get%sname() on closed socket %s
a0d0e21e 2013
be771a83
GS
2014(W closed) You tried to get a socket or peer socket name on a closed
2015socket. Did you forget to check the return value of your socket() call?
a0d0e21e 2016
748a9306
LW
2017=item getpwnam returned invalid UIC %#o for user "%s"
2018
2019(S) A warning peculiar to VMS. The call to C<sys$getuai> underlying the
2020C<getpwnam> operator returned an invalid UIC.
2021
6df41af2
GS
2022=item getsockopt() on closed socket %s
2023
be771a83
GS
2024(W closed) You tried to get a socket option on a closed socket. Did you
2025forget to check the return value of your socket() call? See
6df41af2
GS
2026L<perlfunc/getsockopt>.
2027
2028=item Global symbol "%s" requires explicit package name
2029
a4edf47d 2030(F) You've said "use strict" or "use strict vars", which indicates
30c282f6 2031that all variables must either be lexically scoped (using "my" or "state"),
a4edf47d
GS
2032declared beforehand using "our", or explicitly qualified to say
2033which package the global variable is in (using "::").
6df41af2 2034
e476b1b5
GS
2035=item glob failed (%s)
2036
73c4e9dc
FC
2037(W glob) Something went wrong with the external program(s) used
2038for C<glob> and C<< <*.c> >>. Usually, this means that you supplied a C<glob>
2039pattern that caused the external program to fail and exit with a
be771a83 2040nonzero status. If the message indicates that the abnormal exit
73c4e9dc
FC
2041resulted in a coredump, this may also mean that your csh (C shell)
2042is broken. If so, you should change all of the csh-related variables
2043in config.sh: If you have tcsh, make the variables refer to it as
2044if it were csh (e.g. C<full_csh='/usr/bin/tcsh'>); otherwise, make them
2045all empty (except that C<d_csh> should be C<'undef'>) so that Perl will
be771a83 2046think csh is missing. In either case, after editing config.sh, run
75b44862 2047C<./Configure -S> and rebuild Perl.
e476b1b5 2048
a0d0e21e
LW
2049=item Glob not terminated
2050
2051(F) The lexer saw a left angle bracket in a place where it was expecting
be771a83
GS
2052a term, so it's looking for the corresponding right angle bracket, and
2053not finding it. Chances are you left some needed parentheses out
2054earlier in the line, and you really meant a "less than".
a0d0e21e 2055
bcd05b94 2056=item gmtime(%f) too large
8b56d6ff 2057
e9200be3 2058(W overflow) You called C<gmtime> with a number that was larger than
fc003d4b 2059it can reliably handle and C<gmtime> probably returned the wrong
6903afa2 2060date. This warning is also triggered with NaN (the special
fc003d4b
MS
2061not-a-number value).
2062
bcd05b94 2063=item gmtime(%f) too small
fc003d4b 2064
e9200be3 2065(W overflow) You called C<gmtime> with a number that was smaller than
e7a1a147 2066it can reliably handle and C<gmtime> probably returned the wrong date.
8b56d6ff 2067
6df41af2 2068=item Got an error from DosAllocMem
a0d0e21e 2069
6df41af2
GS
2070(P) An error peculiar to OS/2. Most probably you're using an obsolete
2071version of Perl, and this should not happen anyway.
a0d0e21e
LW
2072
2073=item goto must have label
2074
2075(F) Unlike with "next" or "last", you're not allowed to goto an
2076unspecified destination. See L<perlfunc/goto>.
2077
6651ba0b
FC
2078=item Goto undefined subroutine%s
2079
2080(F) You tried to call a subroutine with C<goto &sub> syntax, but
2081the indicated subroutine hasn't been defined, or if it was, it
2082has since been undefined.
2083
49704364 2084=item ()-group starts with a count
18529408 2085
bca4a986
FC
2086(F) A ()-group started with a count. A count is supposed to follow
2087something: a template character or a ()-group. See L<perlfunc/pack>.
18529408 2088
fe13d51d 2089=item %s had compilation errors.
6df41af2
GS
2090
2091(F) The final summary message when a C<perl -c> fails.
2092
a0d0e21e
LW
2093=item Had to create %s unexpectedly
2094
be771a83
GS
2095(S internal) A routine asked for a symbol from a symbol table that ought
2096to have existed already, but for some reason it didn't, and had to be
2097created on an emergency basis to prevent a core dump.
a0d0e21e
LW
2098
2099=item Hash %%s missing the % in argument %d of %s()
2100
be771a83
GS
2101(D deprecated) Really old Perl let you omit the % on hash names in some
2102spots. This is now heavily deprecated.
a0d0e21e 2103
6df41af2
GS
2104=item %s has too many errors
2105
2106(F) The parser has given up trying to parse the program after 10 errors.
2107Further error messages would likely be uninformative.
2108
e6897b1a
KW
2109=item Having no space between pattern and following word is deprecated
2110
2111(D syntax)
2112
6903afa2
FC
2113You had a word that isn't a regex modifier immediately following
2114a pattern without an intervening space. If you are trying to use
2115the C</le> flags on a substitution, use C</el> instead. Otherwise, add
2116white space between the pattern and following word to eliminate
2117the warning. As an example of the latter, the two constructs:
2118
e6897b1a
KW
2119
2120 $a =~ m/$foo/sand $bar
2121 $a =~ m/$foo/s and $bar
2122
6903afa2
FC
2123both currently mean the same thing, but it is planned to disallow
2124the first form in Perl 5.18. And,
e6897b1a
KW
2125
2126 $a =~ m/$foo/and $bar
2127
2128will be disallowed too.
2129
252aa082
JH
2130=item Hexadecimal number > 0xffffffff non-portable
2131
e476b1b5 2132(W portable) The hexadecimal number you specified is larger than 2**32-1
9e24b6e2
JH
2133(4294967295) and therefore non-portable between systems. See
2134L<perlport> for more on portability concerns.
252aa082 2135
8903cb82 2136=item Identifier too long
2137
2138(F) Perl limits identifiers (names for variables, functions, etc.) to
fc36a67e 2139about 250 characters for simple names, and somewhat more for compound
be771a83
GS
2140names (like C<$A::B>). You've exceeded Perl's limits. Future versions
2141of Perl are likely to eliminate these arbitrary limitations.
8903cb82 2142
c3c41406 2143=item Ignoring zero length \N{} in character class
fc8cd66c 2144
20561843 2145(W) Named Unicode character escapes C<(\N{...})> may return a zero-length
6903afa2
FC
2146sequence. When such an escape is used in a character class its
2147behaviour is not well defined. Check that the correct escape has
fc8cd66c
YO
2148been used, and the correct charname handler is in scope.
2149
6df41af2 2150=item Illegal binary digit %s
f675dbe5 2151
6df41af2 2152(F) You used a digit other than 0 or 1 in a binary number.
f675dbe5 2153
6df41af2 2154=item Illegal binary digit %s ignored
a0d0e21e 2155
be771a83
GS
2156(W digit) You may have tried to use a digit other than 0 or 1 in a
2157binary number. Interpretation of the binary number stopped before the
2158offending digit.
a0d0e21e 2159
6597eb22
FC
2160=item Illegal character after '_' in prototype for %s : %s
2161
2162(W illegalproto) An illegal character was found in a prototype declaration.
2163Legal characters in prototypes are $, @, %, *, ;, [, ], &, \, and +.
2164
78d0fecf 2165=item Illegal character \%o (carriage return)
4fdae800 2166
d5898338 2167(F) Perl normally treats carriage returns in the program text as it
be771a83
GS
2168would any other whitespace, which means you should never see this error
2169when Perl was built using standard options. For some reason, your
2170version of Perl appears to have been built without this support. Talk
2171to your Perl administrator.
4fdae800 2172
d37a9538
ST
2173=item Illegal character in prototype for %s : %s
2174
197afce1 2175(W illegalproto) An illegal character was found in a prototype declaration.
2e9cc7ef 2176Legal characters in prototypes are $, @, %, *, ;, [, ], &, \, and +.
d37a9538 2177
904d85c5
RGS
2178=item Illegal declaration of anonymous subroutine
2179
2180(F) When using the C<sub> keyword to construct an anonymous subroutine,
6903afa2 2181you must always specify a block of code. See L<perlsub>.
904d85c5 2182
8e742a20
MHM
2183=item Illegal declaration of subroutine %s
2184
6903afa2 2185(F) A subroutine was not declared correctly. See L<perlsub>.
8e742a20 2186
a0d0e21e
LW
2187=item Illegal division by zero
2188
be771a83
GS
2189(F) You tried to divide a number by 0. Either something was wrong in
2190your logic, or you need to put a conditional in to guard against
2191meaningless input.
a0d0e21e 2192
6df41af2
GS
2193=item Illegal hexadecimal digit %s ignored
2194
be771a83
GS
2195(W digit) You may have tried to use a character other than 0 - 9 or
2196A - F, a - f in a hexadecimal number. Interpretation of the hexadecimal
2197number stopped before the illegal character.
6df41af2 2198
a0d0e21e
LW
2199=item Illegal modulus zero
2200
be771a83
GS
2201(F) You tried to divide a number by 0 to get the remainder. Most
2202numbers don't take to this kindly.
a0d0e21e 2203
6df41af2 2204=item Illegal number of bits in vec
399388f4 2205
6df41af2
GS
2206(F) The number of bits in vec() (the third argument) must be a power of
2207two from 1 to 32 (or 64, if your platform supports that).
399388f4
GS
2208
2209=item Illegal octal digit %s
a0d0e21e 2210
d1be9408 2211(F) You used an 8 or 9 in an octal number.
a0d0e21e 2212
399388f4 2213=item Illegal octal digit %s ignored
748a9306 2214
d1be9408 2215(W digit) You may have tried to use an 8 or 9 in an octal number.
75b44862 2216Interpretation of the octal number stopped before the 8 or 9.
748a9306 2217
fe13d51d 2218=item Illegal switch in PERL5OPT: -%c
6ff81951 2219
6df41af2 2220(X) The PERL5OPT environment variable may only be used to set the
646ca9b2 2221following switches: B<-[CDIMUdmtw]>.
6ff81951 2222
6df41af2 2223=item Ill-formed CRTL environ value "%s"
81e118e0 2224
75b44862 2225(W internal) A warning peculiar to VMS. Perl tried to read the CRTL's
be771a83
GS
2226internal environ array, and encountered an element without the C<=>
2227delimiter used to separate keys from values. The element is ignored.
09bef843 2228
6df41af2 2229=item Ill-formed message in prime_env_iter: |%s|
54310121 2230
be771a83
GS
2231(W internal) A warning peculiar to VMS. Perl tried to read a logical
2232name or CLI symbol definition when preparing to iterate over %ENV, and
2233didn't see the expected delimiter between key and value, so the line was
2234ignored.
54310121 2235
6df41af2 2236=item (in cleanup) %s
9607fc9c 2237
be771a83
GS
2238(W misc) This prefix usually indicates that a DESTROY() method raised
2239the indicated exception. Since destructors are usually called by the
2240system at arbitrary points during execution, and often a vast number of
2241times, the warning is issued only once for any number of failures that
2242would otherwise result in the same message being repeated.
6df41af2 2243
be771a83
GS
2244Failure of user callbacks dispatched using the C<G_KEEPERR> flag could
2245also result in this warning. See L<perlcall/G_KEEPERR>.
9607fc9c 2246
2c7d6b9c
RGS
2247=item Inconsistent hierarchy during C3 merge of class '%s': merging failed on parent '%s'
2248
2249(F) The method resolution order (MRO) of the given class is not
2250C3-consistent, and you have enabled the C3 MRO for this class. See the C3
2251documentation in L<mro> for more information.
2252
979699d9
JH
2253=item In EBCDIC the v-string components cannot exceed 2147483647
2254
2255(F) An error peculiar to EBCDIC. Internally, v-strings are stored as
2256Unicode code points, and encoded in EBCDIC as UTF-EBCDIC. The UTF-EBCDIC
2257encoding is limited to code points no larger than 2147483647 (0x7FFFFFFF).
2258
1a147d38
YO
2259=item Infinite recursion in regex; marked by <-- HERE in m/%s/
2260
2261(F) You used a pattern that references itself without consuming any input
6903afa2 2262text. You should check the pattern to ensure that recursive patterns
1a147d38
YO
2263either consume text or fail.
2264
2265The <-- HERE shows in the regular expression about where the problem was
2266discovered.
2267
6dbe9451
NC
2268=item Initialization of state variables in list context currently forbidden
2269
6903afa2
FC
2270(F) Currently the implementation of "state" only permits the
2271initialization of scalar variables in scalar context. Re-write
2272C<state ($a) = 42> as C<state $a = 42> to change from list to scalar
2273context. Constructions such as C<state (@a) = foo()> will be
2274supported in a future perl release.
6dbe9451 2275
a0d0e21e
LW
2276=item Insecure dependency in %s
2277
8b1a09fc 2278(F) You tried to do something that the tainting mechanism didn't like.
be771a83
GS
2279The tainting mechanism is turned on when you're running setuid or
2280setgid, or when you specify B<-T> to turn it on explicitly. The
2281tainting mechanism labels all data that's derived directly or indirectly
2282from the user, who is considered to be unworthy of your trust. If any
2283such data is used in a "dangerous" operation, you get this error. See
2284L<perlsec> for more information.
a0d0e21e
LW
2285
2286=item Insecure directory in %s
2287
be771a83
GS
2288(F) You can't use system(), exec(), or a piped open in a setuid or
2289setgid script if C<$ENV{PATH}> contains a directory that is writable by
df98f984
RGS
2290the world. Also, the PATH must not contain any relative directory.
2291See L<perlsec>.
a0d0e21e 2292
62f468fc 2293=item Insecure $ENV{%s} while running %s
a0d0e21e
LW
2294
2295(F) You can't use system(), exec(), or a piped open in a setuid or
62f468fc 2296setgid script if any of C<$ENV{PATH}>, C<$ENV{IFS}>, C<$ENV{CDPATH}>,
332d5f78
SR
2297C<$ENV{ENV}>, C<$ENV{BASH_ENV}> or C<$ENV{TERM}> are derived from data
2298supplied (or potentially supplied) by the user. The script must set
2299the path to a known value, using trustworthy data. See L<perlsec>.
a0d0e21e 2300
0e9be77f
DM
2301=item Insecure user-defined property %s
2302
2303(F) Perl detected tainted data when trying to compile a regular
2304expression that contains a call to a user-defined character property
2305function, i.e. C<\p{IsFoo}> or C<\p{InFoo}>.
2306See L<perlunicode/User-Defined Character Properties> and L<perlsec>.
2307
b9ef414d
FC
2308=item Integer overflow in format string for %s
2309
2310(F) The indexes and widths specified in the format string of C<printf()>
2311or C<sprintf()> are too large. The numbers must not overflow the size of
2312integers for your architecture.
2313
a7ae9550
GS
2314=item Integer overflow in %s number
2315
75b44862 2316(W overflow) The hexadecimal, octal or binary number you have specified
be771a83
GS
2317either as a literal or as an argument to hex() or oct() is too big for
2318your architecture, and has been converted to a floating point number.
2319On a 32-bit architecture the largest hexadecimal, octal or binary number
9e24b6e2
JH
2320representable without overflow is 0xFFFFFFFF, 037777777777, or
23210b11111111111111111111111111111111 respectively. Note that Perl
2322transparently promotes all numbers to a floating point representation
2323internally--subject to loss of precision errors in subsequent
2324operations.
bbce6d69 2325
46314c13
JP
2326=item Integer overflow in version
2327
2328(F) Some portion of a version initialization is too large for the
2329size of integers for your architecture. This is not a warning
2330because there is no rational reason for a version to try and use a
2331element larger than typically 2**32. This is usually caused by
2332trying to use some odd mathematical operation as a version, like
2333100/9.
2334
7253e4e3 2335=item Internal disaster in regex; marked by <-- HERE in m/%s/
6df41af2
GS
2336
2337(P) Something went badly wrong in the regular expression parser.
7253e4e3 2338The <-- HERE shows in the regular expression about where the problem was
b45f050a
JF
2339discovered.
2340
748a9306
LW
2341=item Internal inconsistency in tracking vforks
2342
be771a83
GS
2343(S) A warning peculiar to VMS. Perl keeps track of the number of times
2344you've called C<fork> and C<exec>, to determine whether the current call
2345to C<exec> should affect the current script or a subprocess (see
2346L<perlvms/"exec LIST">). Somehow, this count has become scrambled, so
2347Perl is making a guess and treating this C<exec> as a request to
2348terminate the Perl script and execute the specified command.
748a9306 2349
7253e4e3 2350=item Internal urp in regex; marked by <-- HERE in m/%s/
b45f050a 2351
fa816bf3 2352(P) Something went badly awry in the regular expression parser. The
7253e4e3
RK
2353<-- HERE shows in the regular expression about where the problem was
2354discovered.
a0d0e21e 2355
6df41af2
GS
2356=item %s (...) interpreted as function
2357
75b44862 2358(W syntax) You've run afoul of the rule that says that any list operator
be771a83 2359followed by parentheses turns into a function, with all the list
64977eb6 2360operators arguments found inside the parentheses. See
13a2d996 2361L<perlop/Terms and List Operators (Leftward)>.
6df41af2 2362
09bef843
SB
2363=item Invalid %s attribute: %s
2364
a4a4c9e2 2365(F) The indicated attribute for a subroutine or variable was not recognized
09bef843
SB
2366by Perl or by a user-supplied handler. See L<attributes>.
2367
2368=item Invalid %s attributes: %s
2369
a4a4c9e2 2370(F) The indicated attributes for a subroutine or variable were not
be771a83 2371recognized by Perl or by a user-supplied handler. See L<attributes>.
09bef843 2372
c635e13b 2373=item Invalid conversion in %s: "%s"
2374
be771a83
GS
2375(W printf) Perl does not understand the given format conversion. See
2376L<perlfunc/sprintf>.
c635e13b 2377
9e08bc66
TS
2378=item Invalid escape in the specified encoding in regex; marked by <-- HERE in m/%s/
2379
2380(W regexp) The numeric escape (for example C<\xHH>) of value < 256
2381didn't correspond to a single character through the conversion
2382from the encoding specified by the encoding pragma.
2383The escape was replaced with REPLACEMENT CHARACTER (U+FFFD) instead.
2384The <-- HERE shows in the regular expression about where the
2385escape was discovered.
2386
8149aa9f
FC
2387=item Invalid hexadecimal number in \N{U+...}
2388
2389(F) The character constant represented by C<...> is not a valid hexadecimal
74f8e9e3
FC
2390number. Either it is empty, or you tried to use a character other than
23910 - 9 or A - F, a - f in a hexadecimal number.
8149aa9f 2392
6651ba0b
FC
2393=item Invalid module name %s with -%c option: contains single ':'
2394
2395(F) The module argument to perl's B<-m> and B<-M> command-line options
2396cannot contain single colons in the module name, but only in the
2397arguments after "=". In other words, B<-MFoo::Bar=:baz> is ok, but
2398B<-MFoo:Bar=baz> is not.
2399
2c7d6b9c
RGS
2400=item Invalid mro name: '%s'
2401
162a3e34
FC
2402(F) You tried to C<mro::set_mro("classname", "foo")> or C<use mro 'foo'>,
2403where C<foo> is not a valid method resolution order (MRO). Currently,
2404the only valid ones supported are C<dfs> and C<c3>, unless you have loaded
2405a module that is a MRO plugin. See L<mro> and L<perlmroapi>.
2c7d6b9c 2406
6651ba0b
FC
2407=item invalid option -D%c, use -D'' to see choices
2408
2409(F) Perl was called with invalid debugger flags. Call perl with
2410the B<-D> option with no flags to see the list of acceptable values.
2411See also L<< perlrun/B<-D>I<letters> >>.
2412
7253e4e3 2413=item Invalid [] range "%s" in regex; marked by <-- HERE in m/%s/
6df41af2
GS
2414
2415(F) The range specified in a character class had a minimum character
7253e4e3
RK
2416greater than the maximum character. One possibility is that you forgot the
2417C<{}> from your ending C<\x{}> - C<\x> without the curly braces can go only
2418up to C<ff>. The <-- HERE shows in the regular expression about where the
2419problem was discovered. See L<perlre>.
6df41af2 2420
d1573ac7 2421=item Invalid range "%s" in transliteration operator
c2e66d9e
GS
2422
2423(F) The range specified in the tr/// or y/// operator had a minimum
2424character greater than the maximum character. See L<perlop>.
2425
09bef843
SB
2426=item Invalid separator character %s in attribute list
2427
0120eecf 2428(F) Something other than a colon or whitespace was seen between the
be771a83
GS
2429elements of an attribute list. If the previous attribute had a
2430parenthesised parameter list, perhaps that list was terminated too soon.
2431See L<attributes>.
09bef843 2432
b4581f09
JH
2433=item Invalid separator character %s in PerlIO layer specification %s
2434
2bfc5f71
FC
2435(W layer) When pushing layers onto the Perl I/O system, something other
2436than a colon or whitespace was seen between the elements of a layer list.
b4581f09
JH
2437If the previous attribute had a parenthesised parameter list, perhaps that
2438list was terminated too soon.
2439
2c86d456
DG
2440=item Invalid strict version format (%s)
2441
fa816bf3 2442(F) A version number did not meet the "strict" criteria for versions.
2c86d456
DG
2443A "strict" version number is a positive decimal number (integer or
2444decimal-fraction) without exponentiation or else a dotted-decimal
2445v-string with a leading 'v' character and at least three components.
a6485a24 2446The parenthesized text indicates which criteria were not met.
2c86d456
DG
2447See the L<version> module for more details on allowed version formats.
2448
49704364 2449=item Invalid type '%s' in %s
96e4d5b1 2450
49704364
WL
2451(F) The given character is not a valid pack or unpack type.
2452See L<perlfunc/pack>.
6728c851 2453
49704364 2454(W) The given character is not a valid pack or unpack type but used to be
75b44862 2455silently ignored.
96e4d5b1 2456
2c86d456
DG
2457=item Invalid version format (%s)
2458
fa816bf3 2459(F) A version number did not meet the "lax" criteria for versions.
2c86d456
DG
2460A "lax" version number is a positive decimal number (integer or
2461decimal-fraction) without exponentiation or else a dotted-decimal
fa816bf3
FC
2462v-string. If the v-string has fewer than three components, it
2463must have a leading 'v' character. Otherwise, the leading 'v' is
2464optional. Both decimal and dotted-decimal versions may have a
2465trailing "alpha" component separated by an underscore character
2466after a fractional or dotted-decimal component. The parenthesized
2467text indicates which criteria were not met. See the L<version> module
2468for more details on allowed version formats.
46314c13 2469
798ae1b7
DG
2470=item Invalid version object
2471
fa816bf3
FC
2472(F) The internal structure of the version object was invalid.
2473Perhaps the internals were modified directly in some way or
2474an arbitrary reference was blessed into the "version" class.
798ae1b7 2475
a0d0e21e
LW
2476=item ioctl is not implemented
2477
2478(F) Your machine apparently doesn't implement ioctl(), which is pretty
2479strange for a machine that supports C.
2480
c289d2f7
JH
2481=item ioctl() on unopened %s
2482
2483(W unopened) You tried ioctl() on a filehandle that was never opened.
34b6fd5e 2484Check your control flow and number of arguments.
c289d2f7 2485
fe13d51d 2486=item IO layers (like '%s') unavailable
363c40c4
SB
2487
2488(F) Your Perl has not been configured to have PerlIO, and therefore
34b6fd5e 2489you cannot use IO layers. To have PerlIO, Perl must be configured
363c40c4
SB
2490with 'useperlio'.
2491
80cbd5ad
JH
2492=item IO::Socket::atmark not implemented on this architecture
2493
2494(F) Your machine doesn't implement the sockatmark() functionality,
34b6fd5e 2495neither as a system call nor an ioctl call (SIOCATMARK).
80cbd5ad 2496
b4581f09
JH
2497=item $* is no longer supported
2498
a58ac25e 2499(D deprecated, syntax) The special variable C<$*>, deprecated in older
6903afa2 2500perls, has been removed as of 5.9.0 and is no longer supported. In
a58ac25e
FC
2501previous versions of perl the use of C<$*> enabled or disabled multi-line
2502matching within a string.
4fd19576
B
2503
2504Instead of using C<$*> you should use the C</m> (and maybe C</s>) regexp
6903afa2
FC
2505modifiers. You can enable C</m> for a lexical scope (even a whole file)
2506with C<use re '/m'>. (In older versions: when C<$*> was set to a true value
570dedd4 2507then all regular expressions behaved as if they were written using C</m>.)
b4581f09 2508
8ae1fe26
RGS
2509=item $# is no longer supported
2510
a58ac25e 2511(D deprecated, syntax) The special variable C<$#>, deprecated in older
6903afa2 2512perls, has been removed as of 5.9.3 and is no longer supported. You
a58ac25e 2513should use the printf/sprintf functions instead.
8ae1fe26 2514
ccf3535a 2515=item '%s' is not a code reference
6ad11d81 2516
6903afa2
FC
2517(W overload) The second (fourth, sixth, ...) argument of
2518overload::constant needs to be a code reference. Either
2519an anonymous subroutine, or a reference to a subroutine.
6ad11d81 2520
ccf3535a 2521=item '%s' is not an overloadable type
6ad11d81 2522
04a80ee0
RGS
2523(W overload) You tried to overload a constant type the overload package is
2524unaware of.
6ad11d81 2525
a0d0e21e
LW
2526=item junk on end of regexp
2527
2528(P) The regular expression parser is confused.
2529
2530=item Label not found for "last %s"
2531
be771a83
GS
2532(F) You named a loop to break out of, but you're not currently in a loop
2533of that name, not even if you count where you were called from. See
2534L<perlfunc/last>.
a0d0e21e
LW
2535
2536=item Label not found for "next %s"
2537
2538(F) You named a loop to continue, but you're not currently in a loop of
2539that name, not even if you count where you were called from. See
2540L<perlfunc/last>.
2541
2542=item Label not found for "redo %s"
2543
2544(F) You named a loop to restart, but you're not currently in a loop of
2545that name, not even if you count where you were called from. See
2546L<perlfunc/last>.
2547
85ab1d1d 2548=item leaving effective %s failed
5ff3f7a4 2549
85ab1d1d 2550(F) While under the C<use filetest> pragma, switching the real and
5ff3f7a4
GS
2551effective uids or gids failed.
2552
49704364
WL
2553=item length/code after end of string in unpack
2554
d7f8936a 2555(F) While unpacking, the string buffer was already used up when an unpack
6903afa2
FC
2556length/code combination tried to obtain more data. This results in
2557an undefined value for the length. See L<perlfunc/pack>.
49704364 2558
e508c8a4
MH
2559=item length() used on %s
2560
0d46a4e7
FC
2561(W syntax) You used length() on either an array or a hash when you
2562probably wanted a count of the items.
e508c8a4
MH
2563
2564Array size can be obtained by doing:
2565
2566 scalar(@array);
2567
2568The number of items in a hash can be obtained by doing:
2569
2570 scalar(keys %hash);
2571
f0e67a1d
Z
2572=item Lexing code attempted to stuff non-Latin-1 character into Latin-1 input
2573
2574(F) An extension is attempting to insert text into the current parse
6903afa2
FC
2575(using L<lex_stuff_pvn|perlapi/lex_stuff_pvn> or similar), but tried to insert a character that
2576couldn't be part of the current input. This is an inherent pitfall
2577of the stuffing mechanism, and one of the reasons to avoid it. Where
2578it is necessary to stuff, stuffing only plain ASCII is recommended.
f0e67a1d
Z
2579
2580=item Lexing code internal error (%s)
2581
2582(F) Lexing code supplied by an extension violated the lexer's API in a
2583detectable way.
2584
69282e91 2585=item listen() on closed socket %s
a0d0e21e 2586
be771a83
GS
2587(W closed) You tried to do a listen on a closed socket. Did you forget
2588to check the return value of your socket() call? See
2589L<perlfunc/listen>.
a0d0e21e 2590
6651ba0b
FC
2591=item List form of piped open not implemented
2592
2593(F) On some platforms, notably Windows, the three-or-more-arguments
2594form of C<open> does not support pipes, such as C<open($pipe, '|-', @args)>.
2595Use the two-argument C<open($pipe, '|prog arg1 arg2...')> form instead.
2596
bcd05b94 2597=item localtime(%f) too large
8b56d6ff 2598
e9200be3 2599(W overflow) You called C<localtime> with a number that was larger
fc003d4b 2600than it can reliably handle and C<localtime> probably returned the
6903afa2 2601wrong date. This warning is also triggered with NaN (the special
fc003d4b
MS
2602not-a-number value).
2603
bcd05b94 2604=item localtime(%f) too small
fc003d4b 2605
e9200be3 2606(W overflow) You called C<localtime> with a number that was smaller
fc003d4b 2607than it can reliably handle and C<localtime> probably returned the
e7a1a147 2608wrong date.
8b56d6ff 2609
58e23c8d 2610=item Lookbehind longer than %d not implemented in regex m/%s/
b45f050a
JF
2611
2612(F) There is currently a limit on the length of string which lookbehind can
6903afa2 2613handle. This restriction may be eased in a future release.
2e50fd82 2614
b88df990
NC
2615=item Lost precision when %s %f by 1
2616
2617(W) The value you attempted to increment or decrement by one is too large
2618for the underlying floating point representation to store accurately,
6903afa2 2619hence the target of C<++> or C<--> is unchanged. Perl issues this warning
b88df990
NC
2620because it has already switched from integers to floating point when values
2621are too large for integers, and now even floating point is insufficient.
2622You may wish to switch to using L<Math::BigInt> explicitly.
2623
93fad930 2624=item lstat() on filehandle%s
2f7da168
RK
2625
2626(W io) You tried to do an lstat on a filehandle. What did you mean
2627by that? lstat() makes sense only on filenames. (Perl did a fstat()
2628instead on the filehandle.)
2629
345d70e3 2630=item lvalue attribute %s already-defined subroutine
bb3abb05 2631
345d70e3
FC
2632(W misc) Although L<attributes.pm|attributes> allows this, turning the lvalue
2633attribute on or off on a Perl subroutine that is already defined
2634does not always work properly. It may or may not do what you
2635want, depending on what code is inside the subroutine, with exact
2636details subject to change between Perl versions. Only do this
2637if you really know what you are doing.
bb3abb05 2638
885ef6f5
GG
2639=item lvalue attribute ignored after the subroutine has been defined
2640
345d70e3
FC
2641(W misc) Using the C<:lvalue> declarative syntax to make a Perl
2642subroutine an lvalue subroutine after it has been defined is
2643not permitted. To make the subroutine an lvalue subroutine,
2644add the lvalue attribute to the definition, or put the C<sub
2645foo :lvalue;> declaration before the definition.
2646
2647See also L<attributes.pm|attributes>.
885ef6f5 2648
2db62bbc 2649=item Malformed integer in [] in pack
49704364 2650
2db62bbc 2651(F) Between the brackets enclosing a numeric repeat count only digits
49704364
WL
2652are permitted. See L<perlfunc/pack>.
2653
2654=item Malformed integer in [] in unpack
2655
2db62bbc 2656(F) Between the brackets enclosing a numeric repeat count only digits
49704364
WL
2657are permitted. See L<perlfunc/pack>.
2658
6df41af2
GS
2659=item Malformed PERLLIB_PREFIX
2660
2661(F) An error peculiar to OS/2. PERLLIB_PREFIX should be of the form
2662
2663 prefix1;prefix2
2664
2665or
6df41af2
GS
2666 prefix1 prefix2
2667
be771a83
GS
2668with nonempty prefix1 and prefix2. If C<prefix1> is indeed a prefix of
2669a builtin library search path, prefix2 is substituted. The error may
2670appear if components are not found, or are too long. See
fecfaeb8 2671"PERLLIB_PREFIX" in L<perlos2>.
6df41af2 2672
2f758a16
ST
2673=item Malformed prototype for %s: %s
2674
d37a9538
ST
2675(F) You tried to use a function with a malformed prototype. The
2676syntax of function prototypes is given a brief compile-time check for
2677obvious errors like invalid characters. A more rigorous check is run
2678when the function is called.
2f758a16 2679
ba210ebe
JH
2680=item Malformed UTF-8 character (%s)
2681
4d6f11e5 2682(S utf8)(F) Perl detected a string that didn't comply with UTF-8
2575c402 2683encoding rules, even though it had the UTF8 flag on.
ba210ebe 2684
2575c402
JW
2685One possible cause is that you set the UTF8 flag yourself for data that
2686you thought to be in UTF-8 but it wasn't (it was for example legacy
6903afa2 26878-bit data). To guard against this, you can use Encode::decode_utf8.
2575c402
JW
2688
2689If you use the C<:encoding(UTF-8)> PerlIO layer for input, invalid byte
2690sequences are handled gracefully, but if you use C<:utf8>, the flag is
2691set without validating the data, possibly resulting in this error
2692message.
2693
2694See also L<Encode/"Handling Malformed Data">.
901b21bf 2695
ff3f963a
KW
2696=item Malformed UTF-8 returned by \N
2697
2698(F) The charnames handler returned malformed UTF-8.
2699
4a5d3a93
FC
2700=item Malformed UTF-8 string in '%c' format in unpack
2701
2702(F) You tried to unpack something that didn't comply with UTF-8 encoding
2703rules and perl was unable to guess how to make more progress.
2704
f337b084
TH
2705=item Malformed UTF-8 string in pack
2706
2707(F) You tried to pack something that didn't comply with UTF-8 encoding
2708rules and perl was unable to guess how to make more progress.
2709
2710=item Malformed UTF-8 string in unpack
2711
2712(F) You tried to unpack something that didn't comply with UTF-8 encoding
2713rules and perl was unable to guess how to make more progress.
2714
4a5d3a93 2715=item Malformed UTF-16 surrogate
f337b084 2716
4a5d3a93
FC
2717(F) Perl thought it was reading UTF-16 encoded character data but while
2718doing it Perl met a malformed Unicode surrogate.
2719
2720=item %s matches null string many times in regex; marked by <-- HERE in m/%s/
2721
2722(W regexp) The pattern you've specified would be an infinite loop if the
2723regular expression engine didn't specifically check for that. The <-- HERE
2724shows in the regular expression about where the problem was discovered.
2725See L<perlre>.
f337b084 2726
de42a5a9 2727=item Maximal count of pending signals (%u) exceeded
2563cec5 2728
6903afa2 2729(F) Perl aborted due to too high a number of signals pending. This
2563cec5
IZ
2730usually indicates that your operating system tried to deliver signals
2731too fast (with a very high priority), starving the perl process from
2732resources it would need to reach a point where it can process signals
6903afa2 2733safely. (See L<perlipc/"Deferred Signals (Safe Signals)">.)
2563cec5 2734
25f58aea
PN
2735=item "%s" may clash with future reserved word
2736
2737(W) This warning may be due to running a perl5 script through a perl4
2738interpreter, especially if the word that is being warned about is
2739"use" or "my".
2740
0d2487cd 2741=item '%' may not be used in pack
6df41af2
GS
2742
2743(F) You can't pack a string by supplying a checksum, because the
be771a83
GS
2744checksumming process loses information, and you can't go the other way.
2745See L<perlfunc/unpack>.
6df41af2 2746
a0d0e21e
LW
2747=item Method for operation %s not found in package %s during blessing
2748
2749(F) An attempt was made to specify an entry in an overloading table that
e7ea3e70 2750doesn't resolve to a valid subroutine. See L<overload>.
a0d0e21e 2751
3cdd684c
TP
2752=item Method %s not permitted
2753
2754See Server error.
2755
a0d0e21e
LW
2756=item Might be a runaway multi-line %s string starting on line %d
2757
2758(S) An advisory indicating that the previous error may have been caused
2759by a missing delimiter on a string or pattern, because it eventually
2760ended earlier on the current line.
2761
2762=item Misplaced _ in number
2763
d4ced10d
JH
2764(W syntax) An underscore (underbar) in a numeric constant did not
2765separate two digits.
a0d0e21e 2766
7baa4690
HS
2767=item Missing argument in %s
2768
2769(W uninitialized) A printf-type format required more arguments than were
2770supplied.
2771
9e81e6a1
RGS
2772=item Missing argument to -%c
2773
2774(F) The argument to the indicated command line switch must follow
2775immediately after the switch, without intervening spaces.
2776
ff3f963a 2777=item Missing braces on \N{}
423cee85 2778
4a2d328f 2779(F) Wrong syntax of character name literal C<\N{charname}> within
532cb70d
FC
2780double-quotish context. This can also happen when there is a space
2781(or comment) between the C<\N> and the C<{> in a regex with the C</x> modifier.
2782This modifier does not change the requirement that the brace immediately
2783follow the C<\N>.
423cee85 2784
f0a2b745
KW
2785=item Missing braces on \o{}
2786
2787(F) A C<\o> must be followed immediately by a C<{> in double-quotish context.
2788
a0d0e21e
LW
2789=item Missing comma after first argument to %s function
2790
2791(F) While certain functions allow you to specify a filehandle or an
2792"indirect object" before the argument list, this ain't one of them.
2793
06eaf0bc
GS
2794=item Missing command in piped open
2795
be771a83
GS
2796(W pipe) You used the C<open(FH, "| command")> or
2797C<open(FH, "command |")> construction, but the command was missing or
2798blank.
06eaf0bc 2799
961ce445
RGS
2800=item Missing control char name in \c
2801
2802(F) A double-quoted string ended with "\c", without the required control
2803character name.
2804
6df41af2
GS
2805=item Missing name in "my sub"
2806
be771a83
GS
2807(F) The reserved syntax for lexically scoped subroutines requires that
2808they have a name with which they can be found.
6df41af2
GS
2809
2810=item Missing $ on loop variable
2811
be771a83
GS
2812(F) Apparently you've been programming in B<csh> too much. Variables
2813are always mentioned with the $ in Perl, unlike in the shells, where it
2814can vary from one line to the next.
6df41af2 2815
cc507455 2816=item (Missing operator before %s?)
748a9306 2817
56da5a46
RGS
2818(S syntax) This is an educated guess made in conjunction with the message
2819"%s found where operator expected". Often the missing operator is a comma.
748a9306 2820
ab13f0c7
JH
2821=item Missing right brace on %s
2822
ff3f963a
KW
2823(F) Missing right brace in C<\x{...}>, C<\p{...}>, C<\P{...}>, or C<\N{...}>.
2824
4a68bf9d 2825=item Missing right brace on \N{} or unescaped left brace after \N
ff3f963a 2826
d32207c9
FC
2827(F) C<\N> has two meanings.
2828
2829The traditional one has it followed by a name enclosed in braces,
2830meaning the character (or sequence of characters) given by that
fa816bf3 2831name. Thus C<\N{ASTERISK}> is another way of writing C<*>, valid in both
d32207c9
FC
2832double-quoted strings and regular expression patterns. In patterns,
2833it doesn't have the meaning an unescaped C<*> does.
2834
2835Starting in Perl 5.12.0, C<\N> also can have an additional meaning (only)
2836in patterns, namely to match a non-newline character. (This is short
2837for C<[^\n]>, and like C<.> but is not affected by the C</s> regex modifier.)
2838
2839This can lead to some ambiguities. When C<\N> is not followed immediately
2840by a left brace, Perl assumes the C<[^\n]> meaning. Also, if the braces
2841form a valid quantifier such as C<\N{3}> or C<\N{5,}>, Perl assumes that this
2842means to match the given quantity of non-newlines (in these examples,
28433; and 5 or more, respectively). In all other case, where there is a
2844C<\N{> and a matching C<}>, Perl assumes that a character name is desired.
2845
2846However, if there is no matching C<}>, Perl doesn't know if it was
2847mistakenly omitted, or if C<[^\n]{> was desired, and raises this error.
2848If you meant the former, add the right brace; if you meant the latter,
2849escape the brace with a backslash, like so: C<\N\{>
ab13f0c7 2850
d98d5fff 2851=item Missing right curly or square bracket
a0d0e21e 2852
be771a83
GS
2853(F) The lexer counted more opening curly or square brackets than closing
2854ones. As a general rule, you'll find it's missing near the place you
2855were last editing.
a0d0e21e 2856
6df41af2
GS
2857=item (Missing semicolon on previous line?)
2858
56da5a46
RGS
2859(S syntax) This is an educated guess made in conjunction with the message
2860"%s found where operator expected". Don't automatically put a semicolon on
6df41af2
GS
2861the previous line just because you saw this message.
2862
a0d0e21e
LW
2863=item Modification of a read-only value attempted
2864
2865(F) You tried, directly or indirectly, to change the value of a
5f05dabc 2866constant. You didn't, of course, try "2 = 1", because the compiler
a0d0e21e
LW
2867catches that. But an easy way to do the same thing is:
2868
2869 sub mod { $_[0] = 1 }
2870 mod(2);
2871
2872Another way is to assign to a substr() that's off the end of the string.
2873
c5674021
PDF
2874Yet another way is to assign to a C<foreach> loop I<VAR> when I<VAR>
2875is aliased to a constant in the look I<LIST>:
2876
b7e4ecc1
FC
2877 $x = 1;
2878 foreach my $n ($x, 2) {
2879 $n *= 2; # modifies the $x, but fails on attempt to
2880 } # modify the 2
c5674021 2881
7a4340ed 2882=item Modification of non-creatable array value attempted, %s
a0d0e21e
LW
2883
2884(F) You tried to make an array value spring into existence, and the
2885subscript was probably negative, even counting from end of the array
2886backwards.
2887
7a4340ed 2888=item Modification of non-creatable hash value attempted, %s
a0d0e21e 2889
be771a83
GS
2890(P) You tried to make a hash value spring into existence, and it
2891couldn't be created for some peculiar reason.
a0d0e21e
LW
2892
2893=item Module name must be constant
2894
2895(F) Only a bare module name is allowed as the first argument to a "use".
2896
be98fb35 2897=item Module name required with -%c option
6df41af2 2898
be98fb35
GS
2899(F) The C<-M> or C<-m> options say that Perl should load some module, but
2900you omitted the name of the module. Consult L<perlrun> for full details
2901about C<-M> and C<-m>.
6df41af2 2902
fe13d51d 2903=item More than one argument to '%s' open
ed9aa3b7 2904
6903afa2 2905(F) The C<open> function has been asked to open multiple files. This
ed9aa3b7
SG
2906can happen if you are trying to open a pipe to a command that takes a
2907list of arguments, but have forgotten to specify a piped open mode.
2908See L<perlfunc/open> for details.
2909
a0d0e21e
LW
2910=item msg%s not implemented
2911
2912(F) You don't have System V message IPC on your system.
2913
2914=item Multidimensional syntax %s not supported
2915
75b44862
GS
2916(W syntax) Multidimensional arrays aren't written like C<$foo[1,2,3]>.
2917They're written like C<$foo[1][2][3]>, as in C.
8b1a09fc 2918
49704364 2919=item '/' must follow a numeric type in unpack
6df41af2 2920
49704364
WL
2921(F) You had an unpack template that contained a '/', but this did not
2922follow some unpack specification producing a numeric value.
2923See L<perlfunc/pack>.
6df41af2
GS
2924
2925=item "my sub" not yet implemented
2926
be771a83
GS
2927(F) Lexically scoped subroutines are not yet implemented. Don't try
2928that yet.
6df41af2 2929
fd1b7234 2930=item "my" variable %s can't be in a package
6df41af2 2931
be771a83
GS
2932(F) Lexically scoped variables aren't in a package, so it doesn't make
2933sense to try to declare one with a package qualifier on the front. Use
2934local() if you want to localize a package variable.
09bef843 2935
8149aa9f
FC
2936=item Name "%s::%s" used only once: possible typo
2937
2938(W once) Typographical errors often show up as unique variable names.
2939If you had a good reason for having a unique name, then just mention it
2940again somehow to suppress the message. The C<our> declaration is
2941provided for this purpose.
2942
2943NOTE: This warning detects symbols that have been used only once so $c, @c,
2944%c, *c, &c, sub c{}, c(), and c (the filehandle or format) are considered
2945the same; if a program uses $c only once but also uses any of the others it
2946will not trigger this warning.
2947
4a68bf9d 2948=item \N in a character class must be a named character: \N{...}
ff3f963a 2949
c3c41406 2950(F) The new (5.12) meaning of C<\N> as C<[^\n]> is not valid in a bracketed
f4e361c7
FC
2951character class, for the same reason that C<.> in a character class loses
2952its specialness: it matches almost everything, which is probably not
2953what you want.
c3c41406 2954
4a68bf9d 2955=item \N{NAME} must be resolved by the lexer
c3c41406 2956
f4e361c7
FC
2957(F) When compiling a regex pattern, an unresolved named character or
2958sequence was encountered. This can happen in any of several ways that
2959bypass the lexer, such as using single-quotish context, or an extra
7fae04b9 2960backslash in double-quotish:
c3c41406
KW
2961
2962 $re = '\N{SPACE}'; # Wrong!
b09c05e6 2963 $re = "\\N{SPACE}"; # Wrong!
c3c41406
KW
2964 /$re/;
2965
b09c05e6 2966Instead, use double-quotes with a single backslash:
c3c41406
KW
2967
2968 $re = "\N{SPACE}"; # ok
2969 /$re/;
2970
2971The lexer can be bypassed as well by creating the pattern from smaller
2972components:
2973
2974 $re = '\N';
2975 /${re}{SPACE}/; # Wrong!
2976
2977It's not a good idea to split a construct in the middle like this, and it
2978doesn't work here. Instead use the solution above.
2979
2980Finally, the message also can happen under the C</x> regex modifier when the
2981C<\N> is separated by spaces from the C<{>, in which case, remove the spaces.
2982
2983 /\N {SPACE}/x; # Wrong!
2984 /\N{SPACE}/x; # ok
ff3f963a 2985
49704364
WL
2986=item Negative '/' count in unpack
2987
2988(F) The length count obtained from a length/code unpack operation was
2989negative. See L<perlfunc/pack>.
2990
a0d0e21e
LW
2991=item Negative length
2992
be771a83
GS
2993(F) You tried to do a read/write/send/recv operation with a buffer
2994length that is less than 0. This is difficult to imagine.
a0d0e21e 2995
ed9aa3b7
SG
2996=item Negative offset to vec in lvalue context
2997
2998(F) When C<vec> is called in an lvalue context, the second argument must be
2999greater than or equal to zero.
3000
7253e4e3 3001=item Nested quantifiers in regex; marked by <-- HERE in m/%s/
a0d0e21e 3002
6903afa2
FC
3003(F) You can't quantify a quantifier without intervening parentheses.
3004So things like ** or +* or ?* are illegal. The <-- HERE shows in the
3005regular expression about where the problem was discovered.
a0d0e21e 3006
7253e4e3 3007Note that the minimal matching quantifiers, C<*?>, C<+?>, and
be771a83 3008C<??> appear to be nested quantifiers, but aren't. See L<perlre>.
a0d0e21e 3009
6df41af2 3010=item %s never introduced
a0d0e21e 3011
be771a83
GS
3012(S internal) The symbol in question was declared but somehow went out of
3013scope before it could possibly have been used.
a0d0e21e 3014
2c7d6b9c
RGS
3015=item next::method/next::can/maybe::next::method cannot find enclosing method
3016
3017(F) C<next::method> needs to be called within the context of a
3018real method in a real package, and it could not find such a context.
3019See L<mro>.
3020
a0d0e21e
LW
3021=item No %s allowed while running setuid
3022
be771a83
GS
3023(F) Certain operations are deemed to be too insecure for a setuid or
3024setgid script to even be allowed to attempt. Generally speaking there
3025will be another way to do what you want that is, if not secure, at least
3026securable. See L<perlsec>.
a0d0e21e 3027
6651ba0b
FC
3028=item No code specified for -%c
3029
3030(F) Perl's B<-e> and B<-E> command-line options require an argument. If
3031you want to run an empty program, pass the empty string as a separate
3032argument or run a program consisting of a single 0 or 1:
3033
3034 perl -e ""
3035 perl -e0
3036 perl -e1
3037
a0d0e21e
LW
3038=item No comma allowed after %s
3039
6903afa2
FC
3040(F) A list operator that has a filehandle or "indirect object" is
3041not allowed to have a comma between that and the following arguments.
a0d0e21e
LW
3042Otherwise it'd be just another one of the arguments.
3043
6903afa2
FC
3044One possible cause for this is that you expected to have imported
3045a constant to your name space with B<use> or B<import> while no such
3046importing took place, it may for example be that your operating
3047system does not support that particular constant. Hopefully you did
3048use an explicit import list for the constants you expect to see;
3049please see L<perlfunc/use> and L<perlfunc/import>. While an
3050explicit import list would probably have caught this error earlier
3051it naturally does not remedy the fact that your operating system
3052still does not support that constant. Maybe you have a typo in
3053the constants of the symbol import list of B<use> or B<import> or in the
3054constant name at the line where this error was triggered?
0a753a76 3055
748a9306
LW
3056=item No command into which to pipe on command line
3057
be771a83
GS
3058(F) An error peculiar to VMS. Perl handles its own command line
3059redirection, and found a '|' at the end of the command line, so it
3060doesn't know where you want to pipe the output from this command.
748a9306 3061
a0d0e21e
LW
3062=item No DB::DB routine defined
3063
be771a83 3064(F) The currently executing code was compiled with the B<-d> switch, but
f7af5ce1 3065for some reason the current debugger (e.g. F<perl5db.pl> or a C<Devel::>
ccafdc96
RGS
3066module) didn't define a routine to be called at the beginning of each
3067statement.
a0d0e21e
LW
3068
3069=item No dbm on this machine
3070
3071(P) This is counted as an internal error, because every machine should
5f05dabc 3072supply dbm nowadays, because Perl comes with SDBM. See L<SDBM_File>.
a0d0e21e 3073
ccafdc96 3074=item No DB::sub routine defined
a0d0e21e 3075
ccafdc96
RGS
3076(F) The currently executing code was compiled with the B<-d> switch, but
3077for some reason the current debugger (e.g. F<perl5db.pl> or a C<Devel::>
3078module) didn't define a C<DB::sub> routine to be called at the beginning
3079of each ordinary subroutine call.
a0d0e21e 3080
6651ba0b
FC
3081=item No directory specified for -I
3082
3083(F) The B<-I> command-line switch requires a directory name as part of the
3084I<same> argument. Use B<-Ilib>, for instance. B<-I lib> won't work.
3085
c47ff5f1 3086=item No error file after 2> or 2>> on command line
748a9306 3087
be771a83
GS
3088(F) An error peculiar to VMS. Perl handles its own command line
3089redirection, and found a '2>' or a '2>>' on the command line, but can't
3090find the name of the file to which to write data destined for stderr.
748a9306 3091
49704364
WL
3092=item No group ending character '%c' found in template
3093
3094(F) A pack or unpack template has an opening '(' or '[' without its
6903afa2 3095matching counterpart. See L<perlfunc/pack>.
49704364 3096
c47ff5f1 3097=item No input file after < on command line
748a9306 3098
be771a83
GS
3099(F) An error peculiar to VMS. Perl handles its own command line
3100redirection, and found a '<' on the command line, but can't find the
3101name of the file from which to read data for stdin.
748a9306 3102
2c7d6b9c
RGS
3103=item No next::method '%s' found for %s
3104
3105(F) C<next::method> found no further instances of this method name
3106in the remaining packages of the MRO of this class. If you don't want
3107it throwing an exception, use C<maybe::next::method>
fa816bf3 3108or C<next::can>. See L<mro>.
2c7d6b9c 3109
6df41af2
GS
3110=item "no" not allowed in expression
3111
be771a83
GS
3112(F) The "no" keyword is recognized and executed at compile time, and
3113returns no useful value. See L<perlmod>.
6df41af2 3114
c47ff5f1 3115=item No output file after > on command line
748a9306 3116
be771a83
GS
3117(F) An error peculiar to VMS. Perl handles its own command line
3118redirection, and found a lone '>' at the end of the command line, so it
3119doesn't know where you wanted to redirect stdout.
748a9306 3120
c47ff5f1 3121=item No output file after > or >> on command line
748a9306 3122
be771a83
GS
3123(F) An error peculiar to VMS. Perl handles its own command line
3124redirection, and found a '>' or a '>>' on the command line, but can't
3125find the name of the file to which to write data destined for stdout.
748a9306 3126
1ec3e8de
GS
3127=item No package name allowed for variable %s in "our"
3128
be771a83
GS
3129(F) Fully qualified variable names are not allowed in "our"
3130declarations, because that doesn't make much sense under existing
3131semantics. Such syntax is reserved for future extensions.
1ec3e8de 3132
a0d0e21e
LW
3133=item No Perl script found in input
3134
3135(F) You called C<perl -x>, but no line was found in the file beginning
3136with #! and containing the word "perl".
3137
3138=item No setregid available
3139
3140(F) Configure didn't find anything resembling the setregid() call for
3141your system.
3142
3143=item No setreuid available
3144
3145(F) Configure didn't find anything resembling the setreuid() call for
3146your system.
3147
e75d1f10
RD
3148=item No such class field "%s" in variable %s of type %s
3149
b7e4ecc1
FC
3150(F) You tried to access a key from a hash through the indicated typed
3151variable but that key is not allowed by the package of the same type.
3152The indicated package has restricted the set of allowed keys using the
3153L<fields> pragma.
e75d1f10 3154
2c692339
RGS
3155=item No such class %s
3156
dc7e5945
FC
3157(F) You provided a class qualifier in a "my", "our" or "state"
3158declaration, but this class doesn't exist at this point in your program.
2c692339 3159
3c20a832
SP
3160=item No such hook: %s
3161
dc7e5945
FC
3162(F) You specified a signal hook that was not recognized by Perl.
3163Currently, Perl accepts C<__DIE__> and C<__WARN__> as valid signal hooks.
3c20a832 3164
6df41af2
GS
3165=item No such pipe open
3166
3167(P) An error peculiar to VMS. The internal routine my_pclose() tried to
be771a83
GS
3168close a pipe which hadn't been opened. This should have been caught
3169earlier as an attempt to close an unopened filehandle.
6df41af2 3170
a0d0e21e
LW
3171=item No such signal: SIG%s
3172
be771a83
GS
3173(W signal) You specified a signal name as a subscript to %SIG that was
3174not recognized. Say C<kill -l> in your shell to see the valid signal
3175names on your system.
a0d0e21e
LW
3176
3177=item Not a CODE reference
3178
3179(F) Perl was trying to evaluate a reference to a code value (that is, a
3180subroutine), but found a reference to something else instead. You can
be771a83
GS
3181use the ref() function to find out what kind of ref it really was. See
3182also L<perlref>.
a0d0e21e
LW
3183
3184=item Not a format reference
3185
3186(F) I'm not sure how you managed to generate a reference to an anonymous
3187format, but this indicates you did, and that it didn't exist.
3188
3189=item Not a GLOB reference
3190
be771a83
GS
3191(F) Perl was trying to evaluate a reference to a "typeglob" (that is, a
3192symbol table entry that looks like C<*foo>), but found a reference to
3193something else instead. You can use the ref() function to find out what
3194kind of ref it really was. See L<perlref>.
a0d0e21e
LW
3195
3196=item Not a HASH reference
3197
be771a83
GS
3198(F) Perl was trying to evaluate a reference to a hash value, but found a
3199reference to something else instead. You can use the ref() function to
3200find out what kind of ref it really was. See L<perlref>.
a0d0e21e 3201
6df41af2
GS
3202=item Not an ARRAY reference
3203
be771a83
GS
3204(F) Perl was trying to evaluate a reference to an array value, but found
3205a reference to something else instead. You can use the ref() function
3206to find out what kind of ref it really was. See L<perlref>.
6df41af2 3207
d4fc4415
FC
3208=item Not an unblessed ARRAY reference
3209
3210(F) You passed a reference to a blessed array to C<push>, C<shift> or
3211another array function. These only accept unblessed array references
3212or arrays beginning explicitly with C<@>.
3213
a0d0e21e
LW
3214=item Not a SCALAR reference
3215
be771a83
GS
3216(F) Perl was trying to evaluate a reference to a scalar value, but found
3217a reference to something else instead. You can use the ref() function
3218to find out what kind of ref it really was. See L<perlref>.
a0d0e21e
LW
3219
3220=item Not a subroutine reference
3221
3222(F) Perl was trying to evaluate a reference to a code value (that is, a
3223subroutine), but found a reference to something else instead. You can
be771a83
GS
3224use the ref() function to find out what kind of ref it really was. See
3225also L<perlref>.
a0d0e21e 3226
e7ea3e70 3227=item Not a subroutine reference in overload table
a0d0e21e
LW
3228
3229(F) An attempt was made to specify an entry in an overloading table that
8b1a09fc 3230doesn't somehow point to a valid subroutine. See L<overload>.
a0d0e21e 3231
a0d0e21e
LW
3232=item Not enough arguments for %s
3233
3234(F) The function requires more arguments than you specified.
3235
6df41af2
GS
3236=item Not enough format arguments
3237
be771a83
GS
3238(W syntax) A format specified more picture fields than the next line
3239supplied. See L<perlform>.
6df41af2
GS
3240
3241=item %s: not found
3242
be771a83
GS
3243(A) You've accidentally run your script through the Bourne shell instead
3244of Perl. Check the #! line, or manually feed your script into Perl
3245yourself.
6df41af2
GS
3246
3247=item no UTC offset information; assuming local time is UTC
a0d0e21e 3248
6df41af2
GS
3249(S) A warning peculiar to VMS. Perl was unable to find the local
3250timezone offset, so it's assuming that local system time is equivalent
be771a83
GS
3251to UTC. If it's not, define the logical name
3252F<SYS$TIMEZONE_DIFFERENTIAL> to translate to the number of seconds which
3253need to be added to UTC to get local time.
a0d0e21e 3254
f0a2b745
KW
3255=item Non-octal character '%c'. Resolved as "%s"
3256
fa816bf3
FC
3257(W digit) In parsing an octal numeric constant, a character was
3258unexpectedly encountered that isn't octal. The resulting value
3259is as indicated.
f0a2b745 3260
4ef2275c
GA
3261=item Non-string passed as bitmask
3262
3263(W misc) A number has been passed as a bitmask argument to select().
3264Use the vec() function to construct the file descriptor bitmasks for
6903afa2 3265select. See L<perlfunc/select>.
4ef2275c 3266
a0d0e21e
LW
3267=item Null filename used
3268
be771a83
GS
3269(F) You can't require the null filename, especially because on many
3270machines that means the current directory! See L<perlfunc/require>.
a0d0e21e 3271
6df41af2
GS
3272=item NULL OP IN RUN
3273
f84fe999 3274(S debugging) Some internal routine called run() with a null opcode
be771a83 3275pointer.
6df41af2 3276
55497cff 3277=item Null picture in formline
3278
3279(F) The first argument to formline must be a valid format picture
3280specification. It was found to be empty, which probably means you
3281supplied it an uninitialized value. See L<perlform>.
3282
a0d0e21e
LW
3283=item Null realloc
3284
3285(P) An attempt was made to realloc NULL.
3286
3287=item NULL regexp argument
3288
5f05dabc 3289(P) The internal pattern matching routines blew it big time.
a0d0e21e
LW
3290
3291=item NULL regexp parameter
3292
3293(P) The internal pattern matching routines are out of their gourd.
3294
fc36a67e 3295=item Number too long
3296
be771a83 3297(F) Perl limits the representation of decimal numbers in programs to
da75cd15 3298about 250 characters. You've exceeded that length. Future
be771a83
GS
3299versions of Perl are likely to eliminate this arbitrary limitation. In
3300the meantime, try using scientific notation (e.g. "1e6" instead of
3301"1_000_000").
fc36a67e 3302
f0a2b745
KW
3303=item Number with no digits
3304
1043934d 3305(F) Perl was looking for a number but found nothing that looked like
6903afa2 3306a number. This happens, for example with C<\o{}>, with no number between
1043934d 3307the braces.
f0a2b745 3308
252aa082
JH
3309=item Octal number > 037777777777 non-portable
3310
75b44862 3311(W portable) The octal number you specified is larger than 2**32-1
be771a83
GS
3312(4294967295) and therefore non-portable between systems. See
3313L<perlport> for more on portability concerns.
252aa082 3314
6ad11d81
JH
3315=item Odd number of arguments for overload::constant
3316
04a80ee0 3317(W overload) The call to overload::constant contained an odd number of
6903afa2 3318arguments. The arguments should come in pairs.
6ad11d81 3319
b21befc1
MG
3320=item Odd number of elements in anonymous hash
3321
3322(W misc) You specified an odd number of elements to initialize a hash,
3323which is odd, because hashes come in key/value pairs.
3324
1930e939 3325=item Odd number of elements in hash assignment
a0d0e21e 3326
be771a83
GS
3327(W misc) You specified an odd number of elements to initialize a hash,
3328which is odd, because hashes come in key/value pairs.
a0d0e21e 3329
bbce6d69 3330=item Offset outside string
3331
1fa582fa 3332(F)(W layer) You tried to do a read/write/send/recv/seek operation
42bc49da 3333with an offset pointing outside the buffer. This is difficult to
f5a7294f
JH
3334imagine. The sole exceptions to this are that zero padding will
3335take place when going past the end of the string when either
3336C<sysread()>ing a file, or when seeking past the end of a scalar opened
1a7a2554
MB
3337for I/O (in anticipation of future reads and to imitate the behaviour
3338with real files).
bbce6d69 3339
c289d2f7 3340=item %s() on unopened %s
2dd78f96
JH
3341
3342(W unopened) An I/O operation was attempted on a filehandle that was
3343never initialized. You need to do an open(), a sysopen(), or a socket()
3344call, or call a constructor from the FileHandle package.
3345
96ebfdd7
RK
3346=item -%s on unopened filehandle %s
3347
3348(W unopened) You tried to invoke a file test operator on a filehandle
3349that isn't open. Check your control flow. See also L<perlfunc/-X>.
3350
a0d0e21e
LW
3351=item oops: oopsAV
3352
e476b1b5 3353(S internal) An internal warning that the grammar is screwed up.
a0d0e21e
LW
3354
3355=item oops: oopsHV
3356
e476b1b5 3357(S internal) An internal warning that the grammar is screwed up.
a0d0e21e 3358
abc718f2
RGS
3359=item Opening dirhandle %s also as a file
3360
a4a4c9e2 3361(W io, deprecated) You used open() to associate a filehandle to
abc718f2
RGS
3362a symbol (glob or scalar) that already holds a dirhandle.
3363Although legal, this idiom might render your code confusing
3364and is deprecated.
3365
3366=item Opening filehandle %s also as a directory
3367
a4a4c9e2 3368(W io, deprecated) You used opendir() to associate a dirhandle to
abc718f2
RGS
3369a symbol (glob or scalar) that already holds a filehandle.
3370Although legal, this idiom might render your code confusing
3371and is deprecated.
3372
a0288114 3373=item Operation "%s": no method found, %s
44a8e56a 3374
be771a83
GS
3375(F) An attempt was made to perform an overloaded operation for which no
3376handler was defined. While some handlers can be autogenerated in terms
3377of other handlers, there is no default handler for any operation, unless
e4aad80d 3378the C<fallback> overloading key is specified to be true. See L<overload>.
44a8e56a 3379
5ff1373f 3380=item Operation "%s" returns its argument for non-Unicode code point 0x%X
9ae3ac1a 3381
8457b38f 3382(W utf8, non_unicode) You performed an operation requiring Unicode
73c4e9dc
FC
3383semantics on a code point that is not in Unicode, so what it should do
3384is not defined. Perl has chosen to have it do nothing, and warn you.
9ae3ac1a
KW
3385
3386If the operation shown is "ToFold", it means that case-insensitive
3387matching in a regular expression was done on the code point.
3388
3389If you know what you are doing you can turn off this warning by
8457b38f 3390C<no warnings 'non_unicode';>.
9ae3ac1a 3391
5ff1373f 3392=item Operation "%s" returns its argument for UTF-16 surrogate U+%X
9ae3ac1a 3393
8457b38f 3394(W utf8, surrogate) You performed an operation requiring Unicode
73c4e9dc
FC
3395semantics on a Unicode surrogate. Unicode frowns upon the use of
3396surrogates for anything but storing strings in UTF-16, but semantics
3397are (reluctantly) defined for the surrogates, and they are to do
3398nothing for this operation. Because the use of surrogates can be
3399dangerous, Perl warns.
9ae3ac1a
KW
3400
3401If the operation shown is "ToFold", it means that case-insensitive
3402matching in a regular expression was done on the code point.
3403
3404If you know what you are doing you can turn off this warning by
8457b38f 3405C<no warnings 'surrogate';>.
9ae3ac1a 3406
748a9306
LW
3407=item Operator or semicolon missing before %s
3408
be771a83
GS
3409(S ambiguous) You used a variable or subroutine call where the parser
3410was expecting an operator. The parser has assumed you really meant to
3411use an operator, but this is highly likely to be incorrect. For
3412example, if you say "*foo *foo" it will be interpreted as if you said
3413"*foo * 'foo'".
748a9306 3414
6df41af2
GS
3415=item "our" variable %s redeclared
3416
be771a83
GS
3417(W misc) You seem to have already declared the same global once before
3418in the current lexical scope.
6df41af2 3419
a80b8354
GS
3420=item Out of memory!
3421
3422(X) The malloc() function returned 0, indicating there was insufficient
be771a83
GS
3423remaining memory (or virtual memory) to satisfy the request. Perl has
3424no option but to exit immediately.
a80b8354 3425
19a52907
JH
3426At least in Unix you may be able to get past this by increasing your
3427process datasize limits: in csh/tcsh use C<limit> and
3428C<limit datasize n> (where C<n> is the number of kilobytes) to check
3429the current limits and change them, and in ksh/bash/zsh use C<ulimit -a>
3430and C<ulimit -d n>, respectively.
3431
6d3b25aa
RGS
3432=item Out of memory during %s extend
3433
3434(X) An attempt was made to extend an array, a list, or a string beyond
3435the largest possible memory allocation.
3436
6df41af2 3437=item Out of memory during "large" request for %s
a0d0e21e 3438
6df41af2 3439(F) The malloc() function returned 0, indicating there was insufficient
6903afa2 3440remaining memory (or virtual memory) to satisfy the request. However,
be771a83
GS
3441the request was judged large enough (compile-time default is 64K), so a
3442possibility to shut down by trapping this error is granted.
a0d0e21e 3443
1b979e0a 3444=item Out of memory during request for %s
a0d0e21e 3445
1fa582fa 3446(X)(F) The malloc() function returned 0, indicating there was
be771a83
GS
3447insufficient remaining memory (or virtual memory) to satisfy the
3448request.
eff9c6e2
CS
3449
3450The request was judged to be small, so the possibility to trap it
3451depends on the way perl was compiled. By default it is not trappable.
be771a83
GS
3452However, if compiled for this, Perl may use the contents of C<$^M> as an
3453emergency pool after die()ing with this message. In this case the error
b022d2d2
IZ
3454is trappable I<once>, and the error message will include the line and file
3455where the failed request happened.
55497cff 3456
1b979e0a
IZ
3457=item Out of memory during ridiculously large request
3458
3459(F) You can't allocate more than 2^31+"small amount" bytes. This error
be771a83
GS
3460is most likely to be caused by a typo in the Perl program. e.g.,
3461C<$arr[time]> instead of C<$arr[$time]>.
1b979e0a 3462
6df41af2
GS
3463=item Out of memory for yacc stack
3464
be771a83
GS
3465(F) The yacc parser wanted to grow its stack so it could continue
3466parsing, but realloc() wouldn't give it more memory, virtual or
3467otherwise.
6df41af2 3468
28be1210
TH
3469=item '.' outside of string in pack
3470
3471(F) The argument to a '.' in your template tried to move the working
3472position to before the start of the packed string being built.
3473
49704364 3474=item '@' outside of string in unpack
6df41af2 3475
49704364 3476(F) You had a template that specified an absolute position outside
6df41af2
GS
3477the string being unpacked. See L<perlfunc/pack>.
3478
f337b084
TH
3479=item '@' outside of string with malformed UTF-8 in unpack
3480
3481(F) You had a template that specified an absolute position outside
6903afa2 3482the string being unpacked. The string being unpacked was also invalid
fa816bf3 3483UTF-8. See L<perlfunc/pack>.
f337b084 3484
7778d804
FC
3485=item overload arg '%s' is invalid
3486
3487(W overload) The L<overload> pragma was passed an argument it did not
3488recognize. Did you mistype an operator?
3489
7cb0cfe6
BM
3490=item Overloaded dereference did not return a reference
3491
3492(F) An object with an overloaded dereference operator was dereferenced,
6903afa2 3493but the overloaded operation did not return a reference. See
7cb0cfe6
BM
3494L<overload>.
3495
3496=item Overloaded qr did not return a REGEXP
3497
3498(F) An object with a C<qr> overload was used as part of a match, but the
6903afa2 3499overloaded operation didn't return a compiled regexp. See L<overload>.
7cb0cfe6 3500
6df41af2
GS
3501=item %s package attribute may clash with future reserved word: %s
3502
be771a83
GS
3503(W reserved) A lowercase attribute name was used that had a
3504package-specific handler. That name might have a meaning to Perl itself
3505some day, even though it doesn't yet. Perhaps you should use a
3506mixed-case attribute name, instead. See L<attributes>.
6df41af2 3507
96ebfdd7
RK
3508=item pack/unpack repeat count overflow
3509
3510(F) You can't specify a repeat count so large that it overflows your
3511signed integers. See L<perlfunc/pack>.
3512
a0d0e21e
LW
3513=item page overflow
3514
be771a83
GS
3515(W io) A single call to write() produced more lines than can fit on a
3516page. See L<perlform>.
a0d0e21e 3517
6df41af2
GS
3518=item panic: %s
3519
3520(P) An internal error.
3521
c99a1475
NC
3522=item panic: attempt to call %s in %s
3523
3524(P) One of the file test operators entered a code branch that calls
3525an ACL related-function, but that function is not available on this
3526platform. Earlier checks mean that it should not be possible to
3527enter this branch on this platform.
3528
5637ef5b 3529=item panic: ck_grep, type=%u
a0d0e21e
LW
3530
3531(P) Failed an internal consistency check trying to compile a grep.
3532
5637ef5b 3533=item panic: ck_split, type=%u
a0d0e21e
LW
3534
3535(P) Failed an internal consistency check trying to compile a split.
3536
5637ef5b 3537=item panic: corrupt saved stack index %ld
a0d0e21e 3538
be771a83
GS
3539(P) The savestack was requested to restore more localized values than
3540there are in the savestack.
a0d0e21e 3541
810b8aa5
GS
3542=item panic: del_backref
3543
3544(P) Failed an internal consistency check while trying to reset a weak
3545reference.
3546
a0d0e21e
LW
3547=item panic: die %s
3548
3549(P) We popped the context stack to an eval context, and then discovered
3550it wasn't an eval context.
3551
a0d0e21e
LW
3552=item panic: do_subst
3553
be771a83
GS
3554(P) The internal pp_subst() routine was called with invalid operational
3555data.
a0d0e21e 3556
2269b42e 3557=item panic: do_trans_%s
a0d0e21e 3558
2269b42e 3559(P) The internal do_trans routines were called with invalid operational
be771a83 3560data.
a0d0e21e 3561
b7f7fd0b
NC
3562=item panic: fold_constants JMPENV_PUSH returned %d
3563
10203f38 3564(P) While attempting folding constants an exception other than an C<eval>
b7f7fd0b
NC
3565failure was caught.
3566
c635e13b 3567=item panic: frexp
3568
3569(P) The library function frexp() failed, making printf("%f") impossible.
3570
5637ef5b 3571=item panic: goto, type=%u, ix=%ld
a0d0e21e
LW
3572
3573(P) We popped the context stack to a context with the specified label,
3574and then discovered it wasn't a context we know how to do a goto in.
3575
b0d55c99
FC
3576=item panic: gp_free failed to free glob pointer
3577
3578(P) The internal routine used to clear a typeglob's entries tried
6903afa2
FC
3579repeatedly, but each time something re-created entries in the glob.
3580Most likely the glob contains an object with a reference back to
3581the glob and a destructor that adds a new object to the glob.
b0d55c99 3582
5637ef5b 3583=item panic: INTERPCASEMOD, %s
a0d0e21e
LW
3584
3585(P) The lexer got into a bad state at a case modifier.
3586
5637ef5b 3587=item panic: INTERPCONCAT, %s
a0d0e21e
LW
3588
3589(P) The lexer got into a bad state parsing a string with brackets.
3590
e446cec8
IZ
3591=item panic: kid popen errno read
3592
3593(F) forked child returned an incomprehensible message about its errno.
3594
5637ef5b 3595=item panic: last, type=%u
a0d0e21e
LW
3596
3597(P) We popped the context stack to a block context, and then discovered
3598it wasn't a block context.
3599
3600=item panic: leave_scope clearsv
3601
be771a83
GS
3602(P) A writable lexical variable became read-only somehow within the
3603scope.
a0d0e21e 3604
5637ef5b 3605=item panic: leave_scope inconsistency %u
a0d0e21e
LW
3606
3607(P) The savestack probably got out of sync. At least, there was an
3608invalid enum on the top of it.
3609
810b8aa5
GS
3610=item panic: magic_killbackrefs
3611
3612(P) Failed an internal consistency check while trying to reset all weak
3613references to an object.
3614
5637ef5b 3615=item panic: malloc, %s
6df41af2
GS
3616
3617(P) Something requested a negative number of bytes of malloc.
3618
27d5b266
JH
3619=item panic: memory wrap
3620
3621(P) Something tried to allocate more memory than possible.
3622
5637ef5b 3623=item panic: pad_alloc, %p!=%p
a0d0e21e
LW
3624
3625(P) The compiler got confused about which scratch pad it was allocating
3626and freeing temporaries and lexicals from.
3627
5637ef5b 3628=item panic: pad_free curpad, %p!=%p
a0d0e21e
LW
3629
3630(P) The compiler got confused about which scratch pad it was allocating
3631and freeing temporaries and lexicals from.
3632
3633=item panic: pad_free po
3634
3635(P) An invalid scratch pad offset was detected internally.
3636
5637ef5b 3637=item panic: pad_reset curpad, %p!=%p
a0d0e21e
LW
3638
3639(P) The compiler got confused about which scratch pad it was allocating
3640and freeing temporaries and lexicals from.
3641
3642=item panic: pad_sv po
3643
3644(P) An invalid scratch pad offset was detected internally.
3645
5637ef5b 3646=item panic: pad_swipe curpad, %p!=%p
a0d0e21e
LW
3647
3648(P) The compiler got confused about which scratch pad it was allocating
3649and freeing temporaries and lexicals from.
3650
3651=item panic: pad_swipe po
3652
3653(P) An invalid scratch pad offset was detected internally.
3654
5637ef5b 3655=item panic: pp_iter, type=%u
a0d0e21e
LW
3656
3657(P) The foreach iterator got called in a non-loop context frame.
3658
96ebfdd7
RK
3659=item panic: pp_match%s
3660
3661(P) The internal pp_match() routine was called with invalid operational
3662data.
3663
5637ef5b 3664=item panic: pp_split, pm=%p, s=%p
2269b42e
JH
3665
3666(P) Something terrible went wrong in setting up for the split.
3667
5637ef5b 3668=item panic: realloc, %s
a0d0e21e
LW
3669
3670(P) Something requested a negative number of bytes of realloc.
3671
ccfb6d2e
FC
3672=item panic: reference miscount on nsv in sv_replace() (%d != 1)
3673
3674(P) The internal sv_replace() function was handed a new SV with a
3675reference count other than 1.
3676
5637ef5b 3677=item panic: restartop in %s
a0d0e21e
LW
3678
3679(P) Some internal routine requested a goto (or something like it), and
3680didn't supply the destination.
3681
5637ef5b 3682=item panic: return, type=%u
a0d0e21e
LW
3683
3684(P) We popped the context stack to a subroutine or eval context, and
3685then discovered it wasn't a subroutine or eval context.
3686
5637ef5b 3687=item panic: scan_num, %s
a0d0e21e
LW
3688
3689(P) scan_num() got called on something that wasn't a number.
3690
6c65d5f9
NC
3691=item panic: sv_chop %s
3692
3693(P) The sv_chop() routine was passed a position that is not within the
3694scalar's string buffer.
3695
5637ef5b 3696=item panic: sv_insert, midend=%p, bigend=%p
a0d0e21e
LW
3697
3698(P) The sv_insert() routine was told to remove more string than there
3699was string.
3700
ad49ad39
NC
3701=item panic: strxfrm() gets absurd - a => %u, ab => %u
3702
3703(P) The interpreter's sanity check of the C function strxfrm() failed.
3704In your current locale the returned transformation of the string "ab" is
3705shorter than that of the string "a", which makes no sense.
3706
a0d0e21e
LW
3707=item panic: top_env
3708
6224f72b 3709(P) The compiler attempted to do a goto, or something weird like that.
a0d0e21e 3710
65bca31a
NC
3711=item panic: unimplemented op %s (#%d) called
3712
a1efa96e
FC
3713(P) The compiler is screwed up and attempted to use an op that isn't
3714permitted at run time.
65bca31a 3715
dea0fc0b
JH
3716=item panic: utf16_to_utf8: odd bytelen
3717
3718(P) Something tried to call utf16_to_utf8 with an odd (as opposed
64977eb6 3719to even) byte length.
dea0fc0b 3720
e0ea5e2d
NC
3721=item panic: utf16_to_utf8_reversed: odd bytelen
3722
3723(P) Something tried to call utf16_to_utf8_reversed with an odd (as opposed
3724to even) byte length.
3725
5637ef5b 3726=item panic: yylex, %s
2f7da168
RK
3727
3728(P) The lexer got into a bad state while processing a case modifier.
3729
28ac2b49
Z
3730=item Parsing code internal error (%s)
3731
3732(F) Parsing code supplied by an extension violated the parser's API in
3733a detectable way.
3734
1a147d38
YO
3735=item Pattern subroutine nesting without pos change exceeded limit in regex; marked by <-- HERE in m/%s/
3736
3737(F) You used a pattern that uses too many nested subpattern calls without
6903afa2
FC
3738consuming any text. Restructure the pattern so text is consumed before
3739the nesting limit is exceeded.
1a147d38
YO
3740
3741The <-- HERE shows in the regular expression about where the problem was
3742discovered.
3743
7b8d334a 3744=item Parentheses missing around "%s" list
a0d0e21e 3745
e476b1b5 3746(W parenthesis) You said something like
a0d0e21e
LW
3747
3748 my $foo, $bar = @_;
3749
3750when you meant
3751
3752 my ($foo, $bar) = @_;
3753
30c282f6 3754Remember that "my", "our", "local" and "state" bind tighter than comma.
a0d0e21e 3755
96ebfdd7
RK
3756=item C<-p> destination: %s
3757
3758(F) An error occurred during the implicit output invoked by the C<-p>
3759command-line switch. (This output goes to STDOUT unless you've
3760redirected it with select().)
3761
3762=item (perhaps you forgot to load "%s"?)
3763
3764(F) This is an educated guess made in conjunction with the message
3765"Can't locate object method \"%s\" via package \"%s\"". It often means
3766that a method requires a package that has not been loaded.
3767
801eb083 3768=item Perl folding rules are not up-to-date for 0x%x; please use the perlbug utility to report
d50a4f90
KW
3769
3770(W regex, deprecated) You used a regular expression with
3771case-insensitive matching, and there is a bug in Perl in which the
3772built-in regular expression folding rules are not accurate. This may
3773lead to incorrect results. Please report this as a bug using the
3774"perlbug" utility. (This message is marked deprecated, so that it by
3775default will be turned-on.)
3776
1109a392
MHM
3777=item Perl_my_%s() not available
3778
3779(F) Your platform has very uncommon byte-order and integer size,
3780so it was not possible to set up some or all fixed-width byte-order
3781conversion functions. This is only a problem when you're using the
3782'<' or '>' modifiers in (un)pack templates. See L<perlfunc/pack>.
3783
6651ba0b
FC
3784=item Perl %s required (did you mean %s?)--this is only %s, stopped
3785
3786(F) The code you are trying to run has asked for a newer version of
3787Perl than you are running. Perhaps C<use 5.10> was written instead
3788of C<use 5.010> or C<use v5.10>. Without the leading C<v>, the number is
3789interpreted as a decimal, with every three digits after the
3790decimal point representing a part of the version number. So 5.10
3791is equivalent to v5.100.
3792
6d3b25aa
RGS
3793=item Perl %s required--this is only version %s, stopped
3794
3795(F) The module in question uses features of a version of Perl more
3796recent than the currently running version. How long has it been since
3797you upgraded, anyway? See L<perlfunc/require>.
3798
6df41af2
GS
3799=item PERL_SH_DIR too long
3800
fa816bf3 3801(F) An error peculiar to OS/2. PERL_SH_DIR is the directory to find the
fecfaeb8 3802C<sh>-shell in. See "PERL_SH_DIR" in L<perlos2>.
6df41af2 3803
96ebfdd7
RK
3804=item PERL_SIGNALS illegal: "%s"
3805
3806See L<perlrun/PERL_SIGNALS> for legal values.
3807
6651ba0b
FC
3808=item Perls since %s too modern--this is %s, stopped
3809
3810(F) The code you are trying to run claims it will not run
3811on the version of Perl you are using because it is too new.
3812Maybe the code needs to be updated, or maybe it is simply
3813wrong and the version check should just be removed.
3814
6df41af2
GS
3815=item perl: warning: Setting locale failed.
3816
3817(S) The whole warning message will look something like:
3818
3819 perl: warning: Setting locale failed.
3820 perl: warning: Please check that your locale settings:
3821 LC_ALL = "En_US",
3822 LANG = (unset)
3823 are supported and installed on your system.
3824 perl: warning: Falling back to the standard locale ("C").
3825
3826Exactly what were the failed locale settings varies. In the above the
3827settings were that the LC_ALL was "En_US" and the LANG had no value.
0ea6b70f
JH
3828This error means that Perl detected that you and/or your operating
3829system supplier and/or system administrator have set up the so-called
3830locale system but Perl could not use those settings. This was not
3831dead serious, fortunately: there is a "default locale" called "C" that
4b07a369
FC
3832Perl can and will use, and the script will be run. Before you really
3833fix the problem, however, you will get the same error message each
3834time you run Perl. How to really fix the problem can be found in
0ea6b70f 3835L<perllocale> section B<LOCALE PROBLEMS>.
6df41af2 3836
bd3fa61c 3837=item pid %x not a child
748a9306 3838
be771a83
GS
3839(W exec) A warning peculiar to VMS. Waitpid() was asked to wait for a
3840process which isn't a subprocess of the current process. While this is
3841fine from VMS' perspective, it's probably not what you intended.
748a9306 3842
49704364 3843=item 'P' must have an explicit size in unpack
3bf38418
WL
3844
3845(F) The unpack format P must have an explicit size, not "*".
3846
96ebfdd7
RK
3847=item POSIX class [:%s:] unknown in regex; marked by <-- HERE in m/%s/
3848
3849(F) The class in the character class [: :] syntax is unknown. The <-- HERE
3850shows in the regular expression about where the problem was discovered.
3851Note that the POSIX character classes do B<not> have the C<is> prefix
3852the corresponding C interfaces have: in other words, it's C<[[:print:]]>,
3853not C<isprint>. See L<perlre>.
3854
3855=item POSIX getpgrp can't take an argument
3856
3857(F) Your system has POSIX getpgrp(), which takes no argument, unlike
3858the BSD version, which takes a pid.
3859
49704364 3860=item POSIX syntax [%s] belongs inside character classes in regex; marked by <-- HERE in m/%s/
b45f050a 3861
9a0b3859 3862(W regexp) The character class constructs [: :], [= =], and [. .] go
7253e4e3
RK
3863I<inside> character classes, the [] are part of the construct, for example:
3864/[012[:alpha:]345]/. Note that [= =] and [. .] are not currently
3865implemented; they are simply placeholders for future extensions and will
3866cause fatal errors. The <-- HERE shows in the regular expression about
3867where the problem was discovered. See L<perlre>.
b45f050a 3868
49704364 3869=item POSIX syntax [. .] is reserved for future extensions in regex; marked by <-- HERE in m/%s/
b45f050a
JF
3870
3871(F regexp) Within regular expression character classes ([]) the syntax
7253e4e3
RK
3872beginning with "[." and ending with ".]" is reserved for future extensions.
3873If you need to represent those character sequences inside a regular
3874expression character class, just quote the square brackets with the
3875backslash: "\[." and ".\]". The <-- HERE shows in the regular expression
3876about where the problem was discovered. See L<perlre>.
b45f050a 3877
49704364 3878=item POSIX syntax [= =] is reserved for future extensions in regex; marked by <-- HERE in m/%s/
b45f050a 3879
7253e4e3
RK
3880(F) Within regular expression character classes ([]) the syntax beginning
3881with "[=" and ending with "=]" is reserved for future extensions. If you
3882need to represent those character sequences inside a regular expression
3883character class, just quote the square brackets with the backslash: "\[="
3884and "=\]". The <-- HERE shows in the regular expression about where the
3885problem was discovered. See L<perlre>.
b45f050a 3886
bbce6d69 3887=item Possible attempt to put comments in qw() list
3888
e476b1b5 3889(W qw) qw() lists contain items separated by whitespace; as with literal
75b44862 3890strings, comment characters are not ignored, but are instead treated as
be771a83
GS
3891literal data. (You may have used different delimiters than the
3892parentheses shown here; braces are also frequently used.)
bbce6d69 3893
774d564b 3894You probably wrote something like this:
3895
54310121 3896 @list = qw(
774d564b 3897 a # a comment
bbce6d69 3898 b # another comment
774d564b 3899 );
bbce6d69 3900
3901when you should have written this:
3902
774d564b 3903 @list = qw(
54310121 3904 a
3905 b
774d564b 3906 );
3907
3908If you really want comments, build your list the
3909old-fashioned way, with quotes and commas:
3910
3911 @list = (
3912 'a', # a comment
3913 'b', # another comment
3914 );
bbce6d69 3915
3916=item Possible attempt to separate words with commas
3917
be771a83
GS
3918(W qw) qw() lists contain items separated by whitespace; therefore
3919commas aren't needed to separate the items. (You may have used
3920different delimiters than the parentheses shown here; braces are also
3921frequently used.)
bbce6d69 3922
54310121 3923You probably wrote something like this:
bbce6d69 3924
774d564b 3925 qw! a, b, c !;
3926
3927which puts literal commas into some of the list items. Write it without
3928commas if you don't want them to appear in your data:
bbce6d69 3929
774d564b 3930 qw! a b c !;
bbce6d69 3931
a0d0e21e
LW
3932=item Possible memory corruption: %s overflowed 3rd argument
3933
3934(F) An ioctl() or fcntl() returned more than Perl was bargaining for.
3935Perl guesses a reasonable buffer size, but puts a sentinel byte at the
3936end of the buffer just in case. This sentinel byte got clobbered, and
3937Perl assumes that memory is now corrupted. See L<perlfunc/ioctl>.
3938
276b2a0c
RGS
3939=item Possible precedence problem on bitwise %c operator
3940
3941(W precedence) Your program uses a bitwise logical operator in conjunction
3942with a numeric comparison operator, like this :
3943
3944 if ($x & $y == 0) { ... }
3945
3946This expression is actually equivalent to C<$x & ($y == 0)>, due to the
6903afa2 3947higher precedence of C<==>. This is probably not what you want. (If you
96a925ab
YST
3948really meant to write this, disable the warning, or, better, put the
3949parentheses explicitly and write C<$x & ($y == 0)>).
276b2a0c 3950
77772344
B
3951=item Possible unintended interpolation of $\ in regex
3952
3953(W ambiguous) You said something like C<m/$\/> in a regex.
3954The regex C<m/foo$\s+bar/m> translates to: match the word 'foo', the output
8ddb446c 3955record separator (see L<perlvar/$\>) and the letter 's' (one time or more)
77772344
B
3956followed by the word 'bar'.
3957
3958If this is what you intended then you can silence the warning by using
3959C<m/${\}/> (for example: C<m/foo${\}s+bar/>).
3960
3961If instead you intended to match the word 'foo' at the end of the line
3962followed by whitespace and the word 'bar' on the next line then you can use
3963C<m/$(?)\/> (for example: C<m/foo$(?)\s+bar/>).
3964
e5035638
FC
3965=item Possible unintended interpolation of %s in string
3966
ccf3535a 3967(W ambiguous) You said something like '@foo' in a double-quoted string
6903afa2 3968but there was no array C<@foo> in scope at the time. If you wanted a
e5035638
FC
3969literal @foo, then write it as \@foo; otherwise find out what happened
3970to the array you apparently lost track of.
3971
a0d0e21e
LW
3972=item Precedence problem: open %s should be open(%s)
3973
e476b1b5 3974(S precedence) The old irregular construct
cb1a09d0 3975
a0d0e21e
LW
3976 open FOO || die;
3977
3978is now misinterpreted as
3979
3980 open(FOO || die);
3981
be771a83
GS
3982because of the strict regularization of Perl 5's grammar into unary and
3983list operators. (The old open was a little of both.) You must put
3984parentheses around the filehandle, or use the new "or" operator instead
3985of "||".
a0d0e21e 3986
3cdd684c
TP
3987=item Premature end of script headers
3988
3989See Server error.
3990
6df41af2
GS
3991=item printf() on closed filehandle %s
3992
be771a83 3993(W closed) The filehandle you're writing to got itself closed sometime
c289d2f7 3994before now. Check your control flow.
6df41af2 3995
9a7dcd9c 3996=item print() on closed filehandle %s
a0d0e21e 3997
be771a83 3998(W closed) The filehandle you're printing on got itself closed sometime
c289d2f7 3999before now. Check your control flow.
a0d0e21e 4000
6df41af2 4001=item Process terminated by SIG%s
a0d0e21e 4002
6df41af2
GS
4003(W) This is a standard message issued by OS/2 applications, while *nix
4004applications die in silence. It is considered a feature of the OS/2
4005port. One can easily disable this by appropriate sighandlers, see
4006L<perlipc/"Signals">. See also "Process terminated by SIGTERM/SIGINT"
fecfaeb8 4007in L<perlos2>.
a0d0e21e 4008
327323c1
RGS
4009=item Prototype after '%c' for %s : %s
4010
fa816bf3
FC
4011(W illegalproto) A character follows % or @ in a prototype. This is
4012useless, since % and @ gobble the rest of the subroutine arguments.
327323c1 4013
3fe9a6f1 4014=item Prototype mismatch: %s vs %s
4633a7c4 4015
9a0b3859 4016(S prototype) The subroutine being declared or defined had previously been
be771a83 4017declared or defined with a different function prototype.
4633a7c4 4018
ed9aa3b7
SG
4019=item Prototype not terminated
4020
2a6fd447 4021(F) You've omitted the closing parenthesis in a function prototype
ed9aa3b7
SG
4022definition.
4023
f9eb106c
FC
4024=item \p{} uses Unicode rules, not locale rules
4025
4026(W) You compiled a regular expression that contained a Unicode property
4027match (C<\p> or C<\P>), but the regular expression is also being told to
4028use the run-time locale, not Unicode. Instead, use a POSIX character
4029class, which should know about the locale's rules.
4030(See L<perlrecharclass/POSIX Character Classes>.)
4031
4032Even if the run-time locale is ISO 8859-1 (Latin1), which is a subset of
4033Unicode, some properties will give results that are not valid for that
4034subset.
4035
4036Here are a couple of examples to help you see what's going on. If the
4037locale is ISO 8859-7, the character at code point 0xD7 is the "GREEK
4038CAPITAL LETTER CHI". But in Unicode that code point means the
4039"MULTIPLICATION SIGN" instead, and C<\p> always uses the Unicode
4040meaning. That means that C<\p{Alpha}> won't match, but C<[[:alpha:]]>
4041should. Only in the Latin1 locale are all the characters in the same
4042positions as they are in Unicode. But, even here, some properties give
4043incorrect results. An example is C<\p{Changes_When_Uppercased}> which
4044is true for "LATIN SMALL LETTER Y WITH DIAERESIS", but since the upper
4045case of that character is not in Latin1, in that locale it doesn't
4046change when upper cased.
4047
96ebfdd7
RK
4048=item Quantifier follows nothing in regex; marked by <-- HERE in m/%s/
4049
6903afa2
FC
4050(F) You started a regular expression with a quantifier. Backslash it if
4051you meant it literally. The <-- HERE shows in the regular expression
4052about where the problem was discovered. See L<perlre>.
96ebfdd7 4053
49704364 4054=item Quantifier in {,} bigger than %d in regex; marked by <-- HERE in m/%s/
9baa0206 4055
6903afa2
FC
4056(F) There is currently a limit to the size of the min and max values of
4057the {min,max} construct. The <-- HERE shows in the regular expression
4058about where the problem was discovered. See L<perlre>.
9baa0206 4059
49704364 4060=item Quantifier unexpected on zero-length expression; marked by <-- HERE in m/%s/
9baa0206 4061
b45f050a
JF
4062(W regexp) You applied a regular expression quantifier in a place where
4063it makes no sense, such as on a zero-width assertion. Try putting the
4064quantifier inside the assertion instead. For example, the way to match
4065"abc" provided that it is followed by three repetitions of "xyz" is
4066C</abc(?=(?:xyz){3})/>, not C</abc(?=xyz){3}/>.
9baa0206 4067
7253e4e3
RK
4068The <-- HERE shows in the regular expression about where the problem was
4069discovered.
4070
89ea2908
GA
4071=item Range iterator outside integer range
4072
4073(F) One (or both) of the numeric arguments to the range operator ".."
4074are outside the range which can be represented by integers internally.
be771a83
GS
4075One possible workaround is to force Perl to use magical string increment
4076by prepending "0" to your numbers.
89ea2908 4077
3b7fbd4a
SP
4078=item readdir() attempted on invalid dirhandle %s
4079
1a147d38 4080(W io) The dirhandle you're reading from is either closed or not really
3b7fbd4a
SP
4081a dirhandle. Check your control flow.
4082
96ebfdd7
RK
4083=item readline() on closed filehandle %s
4084
4085(W closed) The filehandle you're reading from got itself closed sometime
4086before now. Check your control flow.
4087
b5fe5ca2
SR
4088=item read() on closed filehandle %s
4089
4090(W closed) You tried to read from a closed filehandle.
4091
4092=item read() on unopened filehandle %s
4093
4094(W unopened) You tried to read from a filehandle that was never opened.
4095
de42a5a9 4096=item Reallocation too large: %x
6df41af2
GS
4097
4098(F) You can't allocate more than 64K on an MS-DOS machine.
4099
4ad56ec9
IZ
4100=item realloc() of freed memory ignored
4101
be771a83
GS
4102(S malloc) An internal routine called realloc() on something that had
4103already been freed.
4ad56ec9 4104
a0d0e21e
LW
4105=item Recompile perl with B<-D>DEBUGGING to use B<-D> switch
4106
be771a83
GS
4107(F debugging) You can't use the B<-D> option unless the code to produce
4108the desired output is compiled into Perl, which entails some overhead,
a0d0e21e
LW
4109which is why it's currently left out of your copy.
4110
6651ba0b
FC
4111=item Recursive call to Perl_load_module in PerlIO_find_layer
4112
4113(P) It is currently not permitted to load modules when creating
4114a filehandle inside an %INC hook. This can happen with C<open my
4115$fh, '<', \$scalar>, which implicitly loads PerlIO::scalar. Try
4116loading PerlIO::scalar explicitly first.
4117
3e0ccd42 4118=item Recursive inheritance detected in package '%s'
a0d0e21e 4119
2c7d6b9c
RGS
4120(F) While calculating the method resolution order (MRO) of a package, Perl
4121believes it found an infinite loop in the C<@ISA> hierarchy. This is a
4122crude check that bails out after 100 levels of C<@ISA> depth.
a0d0e21e 4123
12605ff9
FC
4124=item refcnt_dec: fd %d%s
4125
2e0cfa16
FC
4126=item refcnt: fd %d%s
4127
12605ff9
FC
4128=item refcnt_inc: fd %d%s
4129
fa816bf3 4130(P) Perl's I/O implementation failed an internal consistency check. If
2e0cfa16
FC
4131you see this message, something is very wrong.
4132
1930e939
TP
4133=item Reference found where even-sized list expected
4134
be771a83 4135(W misc) You gave a single reference where Perl was expecting a list
6903afa2
FC
4136with an even number of elements (for assignment to a hash). This
4137usually means that you used the anon hash constructor when you meant
4138to use parens. In any case, a hash requires key/value B<pairs>.
7b8d334a
GS
4139
4140 %hash = { one => 1, two => 2, }; # WRONG
4141 %hash = [ qw/ an anon array / ]; # WRONG
4142 %hash = ( one => 1, two => 2, ); # right
4143 %hash = qw( one 1 two 2 ); # also fine
4144
810b8aa5
GS
4145=item Reference is already weak
4146
e476b1b5 4147(W misc) You have attempted to weaken a reference that is already weak.
810b8aa5
GS
4148Doing so has no effect.
4149
b72d83b2
RGS
4150=item Reference to invalid group 0
4151
6903afa2
FC
4152(F) You used C<\g0> or similar in a regular expression. You may refer
4153to capturing parentheses only with strictly positive integers
4154(normal backreferences) or with strictly negative integers (relative
4155backreferences). Using 0 does not make sense.
b72d83b2 4156
49704364 4157=item Reference to nonexistent group in regex; marked by <-- HERE in m/%s/
b45f050a
JF
4158
4159(F) You used something like C<\7> in your regular expression, but there are
6903afa2 4160not at least seven sets of capturing parentheses in the expression. If
bbaee129
FC
4161you wanted to have the character with ordinal 7 inserted into the regular
4162expression, prepend zeroes to make it three digits long: C<\007>
9baa0206 4163
7253e4e3 4164The <-- HERE shows in the regular expression about where the problem was
b45f050a 4165discovered.
9baa0206 4166
1a147d38
YO
4167=item Reference to nonexistent named group in regex; marked by <-- HERE in m/%s/
4168
4169(F) You used something like C<\k'NAME'> or C<< \k<NAME> >> in your regular
9381611c 4170expression, but there is no corresponding named capturing parentheses
6903afa2 4171such as C<(?'NAME'...)> or C<< (?<NAME>...) >>. Check if the name has been
9381611c 4172spelled correctly both in the backreference and the declaration.
1a147d38
YO
4173
4174The <-- HERE shows in the regular expression about where the problem was
4175discovered.
4176
bcb95744 4177=item Reference to nonexistent or unclosed group in regex; marked by <-- HERE in m/%s/
1a147d38 4178
bcb95744
FC
4179(F) You used something like C<\g{-7}> in your regular expression, but there
4180are not at least seven sets of closed capturing parentheses in the
4181expression before where the C<\g{-7}> was located.
1a147d38
YO
4182
4183The <-- HERE shows in the regular expression about where the problem was
4184discovered.
4185
a0d0e21e
LW
4186=item regexp memory corruption
4187
4188(P) The regular expression engine got confused by what the regular
4189expression compiler gave it.
4190
ff3f26d2
KW
4191=item Regexp modifier "/%c" may appear a maximum of twice
4192
3955e1a9
KW
4193=item Regexp modifier "/%c" may not appear twice
4194
f6a766d5 4195(F syntax, regexp) The regular expression pattern had too many occurrences
ff3f26d2 4196of the specified modifier. Remove the extraneous ones.
3955e1a9 4197
9442e3b8
KW
4198=item Regexp modifier "%c" may not appear after the "-"
4199
4200(F regexp) Turning off the given modifier has the side effect of turning
4201on another one. Perl currently doesn't allow this. Reword the regular
4202expression to use the modifier you want to turn on (and place it before
4203the minus), instead of the one you want to turn off.
4204
3955e1a9
KW
4205=item Regexp modifiers "/%c" and "/%c" are mutually exclusive
4206
f6a766d5 4207(F syntax, regexp) The regular expression pattern had more than one of these
3955e1a9
KW
4208mutually exclusive modifiers. Retain only the modifier that is
4209supposed to be there.
4210
b45f050a 4211=item Regexp out of space
a0d0e21e 4212
be771a83
GS
4213(P) A "can't happen" error, because safemalloc() should have caught it
4214earlier.
a0d0e21e 4215
a1b95068
WL
4216=item Repeated format line will never terminate (~~ and @# incompatible)
4217
d7f8936a 4218(F) Your format contains the ~~ repeat-until-blank sequence and a
a1b95068 4219numeric field that will never go blank so that the repetition never
6903afa2 4220terminates. You might use ^# instead. See L<perlform>.
a1b95068 4221
b08e453b
RB
4222=item Replacement list is longer than search list
4223
4224(W misc) You have used a replacement list that is longer than the
fa816bf3 4225search list. So the additional elements in the replacement list
b08e453b
RB
4226are meaningless.
4227
a0d0e21e
LW
4228=item Reversed %s= operator
4229
be771a83 4230(W syntax) You wrote your assignment operator backwards. The = must
964742a1 4231always come last, to avoid ambiguity with subsequent unary operators.
a0d0e21e 4232
abc7ecad
SP
4233=item rewinddir() attempted on invalid dirhandle %s
4234
4235(W io) The dirhandle you tried to do a rewinddir() on is either closed or not
4236really a dirhandle. Check your control flow.
4237
96ebfdd7
RK
4238=item Scalars leaked: %d
4239
4240(P) Something went wrong in Perl's internal bookkeeping of scalars:
4241not all scalar variables were deallocated by the time Perl exited.
4242What this usually indicates is a memory leak, which is of course bad,
4243especially if the Perl program is intended to be long-running.
4244
a0d0e21e
LW
4245=item Scalar value @%s[%s] better written as $%s[%s]
4246
be771a83
GS
4247(W syntax) You've used an array slice (indicated by @) to select a
4248single element of an array. Generally it's better to ask for a scalar
4249value (indicated by $). The difference is that C<$foo[&bar]> always
4250behaves like a scalar, both when assigning to it and when evaluating its
4251argument, while C<@foo[&bar]> behaves like a list when you assign to it,
4252and provides a list context to its subscript, which can do weird things
4253if you're expecting only one subscript.
a0d0e21e 4254
748a9306 4255On the other hand, if you were actually hoping to treat the array
5f05dabc 4256element as a list, you need to look into how references work, because
748a9306
LW
4257Perl will not magically convert between scalars and lists for you. See
4258L<perlref>.
4259
a6006777 4260=item Scalar value @%s{%s} better written as $%s{%s}
4261
75b44862 4262(W syntax) You've used a hash slice (indicated by @) to select a single
be771a83
GS
4263element of a hash. Generally it's better to ask for a scalar value
4264(indicated by $). The difference is that C<$foo{&bar}> always behaves
4265like a scalar, both when assigning to it and when evaluating its
4266argument, while C<@foo{&bar}> behaves like a list when you assign to it,
4267and provides a list context to its subscript, which can do weird things
4268if you're expecting only one subscript.
4269
4270On the other hand, if you were actually hoping to treat the hash element
4271as a list, you need to look into how references work, because Perl will
4272not magically convert between scalars and lists for you. See
a6006777 4273L<perlref>.
4274
a0d0e21e
LW
4275=item Search pattern not terminated
4276
4277(F) The lexer couldn't find the final delimiter of a // or m{}
4278construct. Remember that bracketing delimiters count nesting level.
fb73857a 4279Missing the leading C<$> from a variable C<$m> may cause this error.
a0d0e21e 4280
0cb1bcd7 4281Note that since Perl 5.9.0 a // can also be the I<defined-or>
5d9c98cd
JH
4282construct, not just the empty search pattern. Therefore code written
4283in Perl 5.9.0 or later that uses the // as the I<defined-or> can be
4284misparsed by pre-5.9.0 Perls as a non-terminated search pattern.
4285
25c09cbf
SF
4286=item Search pattern not terminated or ternary operator parsed as search pattern
4287
4288(F) The lexer couldn't find the final delimiter of a C<?PATTERN?>
4289construct.
4290
4291The question mark is also used as part of the ternary operator (as in
4292C<foo ? 0 : 1>) leading to some ambiguous constructions being wrongly
6903afa2 4293parsed. One way to disambiguate the parsing is to put parentheses around
25c09cbf
SF
4294the conditional expression, i.e. C<(foo) ? 0 : 1>.
4295
abc7ecad
SP
4296=item seekdir() attempted on invalid dirhandle %s
4297
4298(W io) The dirhandle you are doing a seekdir() on is either closed or not
4299really a dirhandle. Check your control flow.
4300
3257ea4f
FC
4301=item %sseek() on unopened filehandle
4302
4303(W unopened) You tried to use the seek() or sysseek() function on a
4304filehandle that was either never opened or has since been closed.
4305
a0d0e21e
LW
4306=item select not implemented
4307
4308(F) This machine doesn't implement the select() system call.
4309
ae21d580 4310=item Self-ties of arrays and hashes are not supported
68a4a7e4 4311
ae21d580
JH
4312(F) Self-ties are of arrays and hashes are not supported in
4313the current implementation.
68a4a7e4 4314
6df41af2 4315=item Semicolon seems to be missing
a0d0e21e 4316
75b44862
GS
4317(W semicolon) A nearby syntax error was probably caused by a missing
4318semicolon, or possibly some other missing operator, such as a comma.
a0d0e21e
LW
4319
4320=item semi-panic: attempt to dup freed string
4321
be771a83
GS
4322(S internal) The internal newSVsv() routine was called to duplicate a
4323scalar that had previously been marked as free.
a0d0e21e 4324
6df41af2 4325=item sem%s not implemented
a0d0e21e 4326
6df41af2 4327(F) You don't have System V semaphore IPC on your system.
a0d0e21e 4328
69282e91 4329=item send() on closed socket %s
a0d0e21e 4330
be771a83 4331(W closed) The socket you're sending to got itself closed sometime
c289d2f7 4332before now. Check your control flow.
a0d0e21e 4333
7253e4e3 4334=item Sequence (? incomplete in regex; marked by <-- HERE in m/%s/
7b8d334a 4335
6903afa2
FC
4336(F) A regular expression ended with an incomplete extension (?. The
4337<-- HERE shows in the regular expression about where the problem was
4338discovered. See L<perlre>.
1b1626e4 4339
49704364 4340=item Sequence (?%s...) not implemented in regex; marked by <-- HERE in m/%s/
a0d0e21e 4341
6903afa2
FC
4342(F) A proposed regular expression extension has the character reserved
4343but has not yet been written. The <-- HERE shows in the regular
4344expression about where the problem was discovered. See L<perlre>.
b45f050a 4345
49704364 4346=item Sequence (?%s...) not recognized in regex; marked by <-- HERE in m/%s/
a0d0e21e 4347
7253e4e3
RK
4348(F) You used a regular expression extension that doesn't make sense. The
4349<-- HERE shows in the regular expression about where the problem was
fb85c044
KW
4350discovered. This happens when using the C<(?^...)> construct to tell
4351Perl to use the default regular expression modifiers, and you
9442e3b8 4352redundantly specify a default modifier. For other
9de15fec 4353causes, see L<perlre>.
a0d0e21e 4354
4a68bf9d 4355=item Sequence \%s... not terminated in regex; marked by <-- HERE in m/%s/
1f1031fe
YO
4356
4357(F) The regular expression expects a mandatory argument following the escape
4358sequence and this has been omitted or incorrectly written.
4359
49704364 4360=item Sequence (?#... not terminated in regex; marked by <-- HERE in m/%s/
6df41af2
GS
4361
4362(F) A regular expression comment must be terminated by a closing
7253e4e3 4363parenthesis. Embedded parentheses aren't allowed. The <-- HERE shows in
6903afa2 4364the regular expression about where the problem was discovered. See
7253e4e3 4365L<perlre>.
6df41af2 4366
96ebfdd7
RK
4367=item Sequence (?{...}) not terminated or not {}-balanced in regex; marked by <-- HERE in m/%s/
4368
6903afa2
FC
4369(F) If the contents of a (?{...}) clause contain braces, they
4370must balance for Perl to detect the end of the clause properly.
4371The <-- HERE shows in the regular expression about where the
4372problem was discovered. See L<perlre>.
96ebfdd7 4373
d7201950 4374=item Z<>500 Server error
6df41af2
GS
4375
4376See Server error.
4377
a5f75d66
AD
4378=item Server error
4379
6903afa2
FC
4380(A) This is the error message generally seen in a browser window
4381when trying to run a CGI program (including SSI) over the web. The
4382actual error text varies widely from server to server. The most
4383frequently-seen variants are "500 Server error", "Method (something)
4384not permitted", "Document contains no data", "Premature end of script
4385headers", and "Did not produce a valid header".
9607fc9c 4386
4387B<This is a CGI error, not a Perl error>.
4388
6903afa2
FC
4389You need to make sure your script is executable, is accessible by
4390the user CGI is running the script under (which is probably not the
4391user account you tested it under), does not rely on any environment
4392variables (like PATH) from the user it isn't running under, and isn't
4393in a location where the CGI server can't find it, basically, more or
4394less. Please see the following for more information:
9607fc9c 4395
06a5f41f
JH
4396 http://www.perl.org/CGI_MetaFAQ.html
4397 http://www.htmlhelp.org/faq/cgifaq.html
4398 http://www.w3.org/Security/Faq/
a5f75d66 4399
be94a901
GS
4400You should also look at L<perlfaq9>.
4401
a0d0e21e
LW
4402=item setegid() not implemented
4403
be771a83
GS
4404(F) You tried to assign to C<$)>, and your operating system doesn't
4405support the setegid() system call (or equivalent), or at least Configure
4406didn't think so.
a0d0e21e
LW
4407
4408=item seteuid() not implemented
4409
be771a83
GS
4410(F) You tried to assign to C<< $> >>, and your operating system doesn't
4411support the seteuid() system call (or equivalent), or at least Configure
4412didn't think so.
a0d0e21e 4413
81777298
GS
4414=item setpgrp can't take arguments
4415
be771a83
GS
4416(F) Your system has the setpgrp() from BSD 4.2, which takes no
4417arguments, unlike POSIX setpgid(), which takes a process ID and process
4418group ID.
81777298 4419
a0d0e21e
LW
4420=item setrgid() not implemented
4421
be771a83
GS
4422(F) You tried to assign to C<$(>, and your operating system doesn't
4423support the setrgid() system call (or equivalent), or at least Configure
4424didn't think so.
a0d0e21e
LW
4425
4426=item setruid() not implemented
4427
be771a83
GS
4428(F) You tried to assign to C<$<>, and your operating system doesn't
4429support the setruid() system call (or equivalent), or at least Configure
4430didn't think so.
a0d0e21e 4431
6df41af2
GS
4432=item setsockopt() on closed socket %s
4433
be771a83
GS
4434(W closed) You tried to set a socket option on a closed socket. Did you
4435forget to check the return value of your socket() call? See
6df41af2
GS
4436L<perlfunc/setsockopt>.
4437
a0d0e21e
LW
4438=item shm%s not implemented
4439
4440(F) You don't have System V shared memory IPC on your system.
4441
984200d0
YST
4442=item !=~ should be !~
4443
4444(W syntax) The non-matching operator is !~, not !=~. !=~ will be
4445interpreted as the != (numeric not equal) and ~ (1's complement)
4446operators: probably not what you intended.
4447
6df41af2
GS
4448=item <> should be quotes
4449
4450(F) You wrote C<< require <file> >> when you should have written
4451C<require 'file'>.
4452
4453=item /%s/ should probably be written as "%s"
4454
4455(W syntax) You have used a pattern where Perl expected to find a string,
be771a83
GS
4456as in the first argument to C<join>. Perl will treat the true or false
4457result of matching the pattern against $_ as the string, which is
4458probably not what you had in mind.
6df41af2 4459
69282e91 4460=item shutdown() on closed socket %s
a0d0e21e 4461
75b44862
GS
4462(W closed) You tried to do a shutdown on a closed socket. Seems a bit
4463superfluous.
a0d0e21e 4464
f86702cc 4465=item SIG%s handler "%s" not defined
a0d0e21e 4466
be771a83
GS
4467(W signal) The signal handler named in %SIG doesn't, in fact, exist.
4468Perhaps you put it into the wrong package?
a0d0e21e 4469
229c18ce
RGS
4470=item Smart matching a non-overloaded object breaks encapsulation
4471
4472(F) You should not use the C<~~> operator on an object that does not
4473overload it: Perl refuses to use the object's underlying structure for
4474the smart match.
4475
a0d0e21e
LW
4476=item sort is now a reserved word
4477
4478(F) An ancient error message that almost nobody ever runs into anymore.
4479But before sort was a keyword, people sometimes used it as a filehandle.
4480
a0d0e21e
LW
4481=item Sort subroutine didn't return single value
4482
4483(F) A sort comparison subroutine may not return a list value with more
4484or less than one element. See L<perlfunc/sort>.
4485
f1c31c52
FC
4486=item Source filters apply only to byte streams
4487
4488(F) You tried to activate a source filter (usually by loading a
4489source filter module) within a string passed to C<eval>. This is
4490not permitted under the C<unicode_eval> feature. Consider using
4491C<evalbytes> instead. See L<feature>.
4492
8cbc2e3b
JH
4493=item splice() offset past end of array
4494
4495(W misc) You attempted to specify an offset that was past the end of
fa816bf3
FC
4496the array passed to splice(). Splicing will instead commence at the
4497end of the array, rather than past it. If this isn't what you want,
4498try explicitly pre-extending the array by assigning $#array = $offset.
4499See L<perlfunc/splice>.
8cbc2e3b 4500
a0d0e21e
LW
4501=item Split loop
4502
be771a83
GS
4503(P) The split was looping infinitely. (Obviously, a split shouldn't
4504iterate more times than there are characters of input, which is what
6903afa2 4505happened.) See L<perlfunc/split>.
a0d0e21e 4506
a0d0e21e
LW
4507=item Statement unlikely to be reached
4508
be771a83
GS
4509(W exec) You did an exec() with some statement after it other than a
4510die(). This is almost always an error, because exec() never returns
4511unless there was a failure. You probably wanted to use system()
4512instead, which does return. To suppress this warning, put the exec() in
4513a block by itself.
a0d0e21e 4514
fd1b7234
FC
4515=item "state" variable %s can't be in a package
4516
4517(F) Lexically scoped variables aren't in a package, so it doesn't make
4518sense to try to declare one with a package qualifier on the front. Use
4519local() if you want to localize a package variable.
4520
9ddeeac9 4521=item stat() on unopened filehandle %s
6df41af2 4522
355b1299
JH
4523(W unopened) You tried to use the stat() function on a filehandle that
4524was either never opened or has since been closed.
6df41af2 4525
fe13d51d 4526=item Stub found while resolving method "%s" overloading "%s" in package "%s"
e7ea3e70 4527
be771a83
GS
4528(P) Overloading resolution over @ISA tree may be broken by importation
4529stubs. Stubs should never be implicitly created, but explicit calls to
4530C<can> may break this.
e7ea3e70 4531
a0d0e21e
LW
4532=item Subroutine %s redefined
4533
e476b1b5 4534(W redefine) You redefined a subroutine. To suppress this warning, say
a0d0e21e
LW
4535
4536 {
271595cc 4537 no warnings 'redefine';
a0d0e21e
LW
4538 eval "sub name { ... }";
4539 }
4540
4541=item Substitution loop
4542
be771a83
GS
4543(P) The substitution was looping infinitely. (Obviously, a substitution
4544shouldn't iterate more times than there are characters of input, which
4545is what happened.) See the discussion of substitution in
5d44bfff 4546L<perlop/"Regexp Quote-Like Operators">.
a0d0e21e
LW
4547
4548=item Substitution pattern not terminated
4549
d1be9408 4550(F) The lexer couldn't find the interior delimiter of an s/// or s{}{}
a0d0e21e 4551construct. Remember that bracketing delimiters count nesting level.
fb73857a 4552Missing the leading C<$> from variable C<$s> may cause this error.
a0d0e21e
LW
4553
4554=item Substitution replacement not terminated
4555
d1be9408 4556(F) The lexer couldn't find the final delimiter of an s/// or s{}{}
a0d0e21e 4557construct. Remember that bracketing delimiters count nesting level.
fb73857a 4558Missing the leading C<$> from variable C<$s> may cause this error.
a0d0e21e
LW
4559
4560=item substr outside of string
4561
8a9eb13d 4562(W substr)(F) You tried to reference a substr() that pointed outside of
be771a83
GS
4563a string. That is, the absolute value of the offset was larger than the
4564length of the string. See L<perlfunc/substr>. This warning is fatal if
4565substr is used in an lvalue context (as the left hand side of an
4566assignment or as a subroutine argument for example).
a0d0e21e 4567
bf1320bf
RGS
4568=item sv_upgrade from type %d down to type %d
4569
9d277376 4570(P) Perl tried to force the upgrade of an SV to a type which was actually
bf1320bf
RGS
4571inferior to its current type.
4572
49704364 4573=item Switch (?(condition)... contains too many branches in regex; marked by <-- HERE in m/%s/
b45f050a 4574
fa816bf3
FC
4575(F) A (?(condition)if-clause|else-clause) construct can have at most
4576two branches (the if-clause and the else-clause). If you want one or
4577both to contain alternation, such as using C<this|that|other>, enclose
4578it in clustering parentheses:
b45f050a
JF
4579
4580 (?(condition)(?:this|that|other)|else-clause)
4581
fa816bf3
FC
4582The <-- HERE shows in the regular expression about where the problem
4583was discovered. See L<perlre>.
b45f050a 4584
49704364 4585=item Switch condition not recognized in regex; marked by <-- HERE in m/%s/
b45f050a 4586
39ef1de7 4587(F) If the argument to the (?(...)if-clause|else-clause) construct is
fa816bf3 4588a number, it can be only a number. The <-- HERE shows in the regular
6903afa2 4589expression about where the problem was discovered. See L<perlre>.
b45f050a 4590
85ab1d1d
JH
4591=item switching effective %s is not implemented
4592
be771a83
GS
4593(F) While under the C<use filetest> pragma, we cannot switch the real
4594and effective uids or gids.
85ab1d1d 4595
ae7df085 4596=item %s syntax OK
2f7da168
RK
4597
4598(F) The final summary message when a C<perl -c> succeeds.
4599
a0d0e21e
LW
4600=item syntax error
4601
4602(F) Probably means you had a syntax error. Common reasons include:
4603
4604 A keyword is misspelled.
4605 A semicolon is missing.
4606 A comma is missing.
4607 An opening or closing parenthesis is missing.
4608 An opening or closing brace is missing.
4609 A closing quote is missing.
4610
4611Often there will be another error message associated with the syntax
4612error giving more information. (Sometimes it helps to turn on B<-w>.)
4613The error message itself often tells you where it was in the line when
4614it decided to give up. Sometimes the actual error is several tokens
5f05dabc 4615before this, because Perl is good at understanding random input.
a0d0e21e
LW
4616Occasionally the line number may be misleading, and once in a blue moon
4617the only way to figure out what's triggering the error is to call
4618C<perl -c> repeatedly, chopping away half the program each time to see
524e9188 4619if the error went away. Sort of the cybernetic version of S<20 questions>.
a0d0e21e 4620
ccf3535a 4621=item syntax error at line %d: '%s' unexpected
cb1a09d0 4622
be771a83
GS
4623(A) You've accidentally run your script through the Bourne shell instead
4624of Perl. Check the #! line, or manually feed your script into Perl
4625yourself.
cb1a09d0 4626
25f58aea
PN
4627=item syntax error in file %s at line %d, next 2 tokens "%s"
4628
4629(F) This error is likely to occur if you run a perl5 script through
4630a perl4 interpreter, especially if the next 2 tokens are "use strict"
4631or "my $var" or "our $var".
4632
b5fe5ca2
SR
4633=item sysread() on closed filehandle %s
4634
4635(W closed) You tried to read from a closed filehandle.
4636
4637=item sysread() on unopened filehandle %s
4638
4639(W unopened) You tried to read from a filehandle that was never opened.
4640
6087ac44 4641=item System V %s is not implemented on this machine
a0d0e21e 4642
6087ac44
JH
4643(F) You tried to do something with a function beginning with "sem",
4644"shm", or "msg" but that System V IPC is not implemented in your
4645machine. In some machines the functionality can exist but be
4646unconfigured. Consult your system support.
a0d0e21e 4647
69282e91 4648=item syswrite() on closed filehandle %s
a0d0e21e 4649
be771a83 4650(W closed) The filehandle you're writing to got itself closed sometime
c289d2f7 4651before now. Check your control flow.
a0d0e21e 4652
96ebfdd7
RK
4653=item C<-T> and C<-B> not implemented on filehandles
4654
4655(F) Perl can't peek at the stdio buffer of filehandles when it doesn't
4656know about your kind of stdio. You'll have to use a filename instead.
4657
fc36a67e 4658=item Target of goto is too deeply nested
4659
be771a83
GS
4660(F) You tried to use C<goto> to reach a label that was too deeply nested
4661for Perl to reach. Perl is doing you a favor by refusing.
fc36a67e 4662
abc7ecad
SP
4663=item telldir() attempted on invalid dirhandle %s
4664
4665(W io) The dirhandle you tried to telldir() is either closed or not really
4666a dirhandle. Check your control flow.
4667
c2771421
FC
4668=item tell() on unopened filehandle
4669
4670(W unopened) You tried to use the tell() function on a filehandle that
4671was either never opened or has since been closed.
4672
b82b06b8
FC
4673=item That use of $[ is unsupported
4674
4675(F) Assignment to C<$[> is now strictly circumscribed, and interpreted
4676as a compiler directive. You may say only one of
4677
4678 $[ = 0;
4679 $[ = 1;
4680 ...
4681 local $[ = 0;
4682 local $[ = 1;
4683 ...
4684
4685This is to prevent the problem of one module changing the array base out
4686from under another module inadvertently. See L<perlvar/$[> and L<arybase>.
4687
f86702cc 4688=item The crypt() function is unimplemented due to excessive paranoia
a0d0e21e
LW
4689
4690(F) Configure couldn't find the crypt() function on your machine,
4691probably because your vendor didn't supply it, probably because they
8b1a09fc 4692think the U.S. Government thinks it's a secret, or at least that they
a0d0e21e
LW
4693will continue to pretend that it is. And if you quote me on that, I
4694will deny it.
4695
6df41af2
GS
4696=item The %s function is unimplemented
4697
a4a4c9e2 4698(F) The function indicated isn't implemented on this architecture, according
6df41af2
GS
4699to the probings of Configure.
4700
5e1c7ca2 4701=item The stat preceding %s wasn't an lstat
a0d0e21e 4702
be771a83
GS
4703(F) It makes no sense to test the current stat buffer for symbolic
4704linkhood if the last stat that wrote to the stat buffer already went
4705past the symlink to get to the real file. Use an actual filename
4706instead.
a0d0e21e 4707
371fce9b
DM
4708=item The 'unique' attribute may only be applied to 'our' variables
4709
1108974d 4710(F) This attribute was never supported on C<my> or C<sub> declarations.
371fce9b 4711
437784d6 4712=item This Perl can't reset CRTL environ elements (%s)
f675dbe5
CB
4713
4714=item This Perl can't set CRTL environ elements (%s=%s)
4715
75b44862 4716(W internal) Warnings peculiar to VMS. You tried to change or delete an
be771a83
GS
4717element of the CRTL's internal environ array, but your copy of Perl
4718wasn't built with a CRTL that contained the setenv() function. You'll
4719need to rebuild Perl with a CRTL that does, or redefine
4720F<PERL_ENV_TABLES> (see L<perlvms>) so that the environ array isn't the
4721target of the change to
f675dbe5
CB
4722%ENV which produced the warning.
4723
6b3c7930
JH
4724=item thread failed to start: %s
4725
4447dfc1 4726(W threads)(S) The entry point function of threads->create() failed for some reason.
6b3c7930 4727
a0d0e21e
LW
4728=item times not implemented
4729
be771a83
GS
4730(F) Your version of the C library apparently doesn't do times(). I
4731suspect you're not running on Unix.
a0d0e21e 4732
6d3b25aa
RGS
4733=item "-T" is on the #! line, it must also be used on the command line
4734
b7e4ecc1
FC
4735(X) The #! line (or local equivalent) in a Perl script contains
4736the B<-T> option (or the B<-t> option), but Perl was not invoked with
4737B<-T> in its command line. This is an error because, by the time
4738Perl discovers a B<-T> in a script, it's too late to properly taint
4739everything from the environment. So Perl gives up.
6d3b25aa
RGS
4740
4741If the Perl script is being executed as a command using the #!
b7e4ecc1
FC
4742mechanism (or its local equivalent), this error can usually be
4743fixed by editing the #! line so that the B<-%c> option is a part of
4744Perl's first argument: e.g. change C<perl -n -%c> to C<perl -%c -n>.
6d3b25aa
RGS
4745
4746If the Perl script is being executed as C<perl scriptname>, then the
fe13d51d 4747B<-%c> option must appear on the command line: C<perl -%c scriptname>.
6d3b25aa 4748
3a2263fe
RGS
4749=item To%s: illegal mapping '%s'
4750
4751(F) You tried to define a customized To-mapping for lc(), lcfirst,
4752uc(), or ucfirst() (or their string-inlined versions), but you
4753specified an illegal mapping.
4754See L<perlunicode/"User-Defined Character Properties">.
4755
49704364
WL
4756=item Too deeply nested ()-groups
4757
1a147d38 4758(F) Your template contains ()-groups with a ridiculously deep nesting level.
49704364 4759
a0d0e21e
LW
4760=item Too few args to syscall
4761
4762(F) There has to be at least one argument to syscall() to specify the
4763system call to call, silly dilly.
4764
96ebfdd7
RK
4765=item Too late for "-%s" option
4766
4767(X) The #! line (or local equivalent) in a Perl script contains the
4ba71d51
FC
4768B<-M>, B<-m> or B<-C> option.
4769
6903afa2
FC
4770In the case of B<-M> and B<-m>, this is an error because those options
4771are not intended for use inside scripts. Use the C<use> pragma instead.
4ba71d51 4772
6903afa2
FC
4773The B<-C> option only works if it is specified on the command line as
4774well (with the same sequence of letters or numbers following). Either
4775specify this option on the command line, or, if your system supports
4776it, make your script executable and run it directly instead of passing
4777it to perl.
96ebfdd7 4778
ddda08b7
GS
4779=item Too late to run %s block
4780
4781(W void) A CHECK or INIT block is being defined during run time proper,
4782when the opportunity to run them has already passed. Perhaps you are
be771a83
GS
4783loading a file with C<require> or C<do> when you should be using C<use>
4784instead. Or perhaps you should put the C<require> or C<do> inside a
4785BEGIN block.
ddda08b7 4786
a0d0e21e
LW
4787=item Too many args to syscall
4788
5f05dabc 4789(F) Perl supports a maximum of only 14 args to syscall().
a0d0e21e
LW
4790
4791=item Too many arguments for %s
4792
4793(F) The function requires fewer arguments than you specified.
4794
6df41af2
GS
4795=item Too many )'s
4796
49704364
WL
4797(A) You've accidentally run your script through B<csh> instead of Perl.
4798Check the #! line, or manually feed your script into Perl yourself.
4799
8c40cb74
NC
4800=item Too many ('s
4801
be771a83
GS
4802(A) You've accidentally run your script through B<csh> instead of Perl.
4803Check the #! line, or manually feed your script into Perl yourself.
6df41af2 4804
7253e4e3 4805=item Trailing \ in regex m/%s/
a0d0e21e 4806
be771a83
GS
4807(F) The regular expression ends with an unbackslashed backslash.
4808Backslash it. See L<perlre>.
a0d0e21e 4809
2c268ad5 4810=item Transliteration pattern not terminated
a0d0e21e
LW
4811
4812(F) The lexer couldn't find the interior delimiter of a tr/// or tr[][]
fb73857a 4813or y/// or y[][] construct. Missing the leading C<$> from variables
4814C<$tr> or C<$y> may cause this error.
a0d0e21e 4815
2c268ad5 4816=item Transliteration replacement not terminated
a0d0e21e 4817
6a36df5d
YST
4818(F) The lexer couldn't find the final delimiter of a tr///, tr[][],
4819y/// or y[][] construct.
a0d0e21e 4820
96ebfdd7
RK
4821=item '%s' trapped by operation mask
4822
4823(F) You tried to use an operator from a Safe compartment in which it's
6903afa2 4824disallowed. See L<Safe>.
96ebfdd7 4825
a0d0e21e
LW
4826=item truncate not implemented
4827
4828(F) Your machine doesn't implement a file truncation mechanism that
4829Configure knows about.
4830
19c481f4
FC
4831=item Type of arg %d to &CORE::%s must be %s
4832
4833(F) The subroutine in question in the CORE package requires its argument
4834to be a hard reference to data of the specified type. Overloading is
4835ignored, so a reference to an object that is not the specified type, but
4836nonetheless has overloading to handle it, will still not be accepted.
4837
a0d0e21e
LW
4838=item Type of arg %d to %s must be %s (not %s)
4839
4840(F) This function requires the argument in that position to be of a
8b1a09fc 4841certain type. Arrays must be @NAME or C<@{EXPR}>. Hashes must be
4842%NAME or C<%{EXPR}>. No implicit dereferencing is allowed--use the
a0d0e21e
LW
4843{EXPR} forms as an explicit dereference. See L<perlref>.
4844
7ac5715b 4845=item Type of argument to %s must be unblessed hashref or arrayref
cba5a3b0 4846
7ac5715b
FC
4847(F) You called C<keys>, C<values> or C<each> with a scalar argument that
4848was not a reference to an unblessed hash or array.
cba5a3b0 4849
eec2d3df
GS
4850=item umask not implemented
4851
be771a83
GS
4852(F) Your machine doesn't implement the umask function and you tried to
4853use it to restrict permissions for yourself (EXPR & 0700).
a0d0e21e 4854
4633a7c4
LW
4855=item Unable to create sub named "%s"
4856
4857(F) You attempted to create or access a subroutine with an illegal name.
4858
a0d0e21e
LW
4859=item Unbalanced context: %d more PUSHes than POPs
4860
be771a83
GS
4861(W internal) The exit code detected an internal inconsistency in how
4862many execution contexts were entered and left.
a0d0e21e
LW
4863
4864=item Unbalanced saves: %d more saves than restores
4865
be771a83
GS
4866(W internal) The exit code detected an internal inconsistency in how
4867many values were temporarily localized.
a0d0e21e
LW
4868
4869=item Unbalanced scopes: %d more ENTERs than LEAVEs
4870
be771a83
GS
4871(W internal) The exit code detected an internal inconsistency in how
4872many blocks were entered and left.
a0d0e21e 4873
6651ba0b
FC
4874=item Unbalanced string table refcount: (%d) for "%s"
4875
4876(W internal) On exit, Perl found some strings remaining in the shared
4877string table used for copy on write and for hash keys. The entries
4878should have been freed, so this indicates a bug somewhere.
4879
a0d0e21e
LW
4880=item Unbalanced tmps: %d more allocs than frees
4881
be771a83
GS
4882(W internal) The exit code detected an internal inconsistency in how
4883many mortal scalars were allocated and freed.
a0d0e21e
LW
4884
4885=item Undefined format "%s" called
4886
4887(F) The format indicated doesn't seem to exist. Perhaps it's really in
4888another package? See L<perlform>.
4889
4890=item Undefined sort subroutine "%s" called
4891
be771a83
GS
4892(F) The sort comparison routine specified doesn't seem to exist.
4893Perhaps it's in a different package? See L<perlfunc/sort>.
a0d0e21e
LW
4894
4895=item Undefined subroutine &%s called
4896
be771a83
GS
4897(F) The subroutine indicated hasn't been defined, or if it was, it has
4898since been undefined.
a0d0e21e
LW
4899
4900=item Undefined subroutine called
4901
4902(F) The anonymous subroutine you're trying to call hasn't been defined,
4903or if it was, it has since been undefined.
4904
4905=item Undefined subroutine in sort
4906
be771a83
GS
4907(F) The sort comparison routine specified is declared but doesn't seem
4908to have been defined yet. See L<perlfunc/sort>.
a0d0e21e 4909
4633a7c4
LW
4910=item Undefined top format "%s" called
4911
4912(F) The format indicated doesn't seem to exist. Perhaps it's really in
4913another package? See L<perlform>.
4914
20408e3c
GS
4915=item Undefined value assigned to typeglob
4916
be771a83
GS
4917(W misc) An undefined value was assigned to a typeglob, a la
4918C<*foo = undef>. This does nothing. It's possible that you really mean
4919C<undef *foo>.
20408e3c 4920
6df41af2
GS
4921=item %s: Undefined variable
4922
be771a83
GS
4923(A) You've accidentally run your script through B<csh> instead of Perl.
4924Check the #! line, or manually feed your script into Perl yourself.
6df41af2 4925
a0d0e21e
LW
4926=item unexec of %s into %s failed!
4927
4928(F) The unexec() routine failed for some reason. See your local FSF
4929representative, who probably put it there in the first place.
4930
6651ba0b
FC
4931=item Unexpected constant lvalue entersub entry via type/targ %d:%d
4932
4933(P) When compiling a subroutine call in lvalue context, Perl failed an
4934internal consistency check. It encountered a malformed op tree.
4935
0876b9a0
KW
4936=item Unicode non-character U+%X is illegal for open interchange
4937
8457b38f 4938(W utf8, nonchar) Certain codepoints, such as U+FFFE and U+FFFF, are
6903afa2
FC
4939defined by the Unicode standard to be non-characters. Those are
4940legal codepoints, but are reserved for internal use; so, applications
4941shouldn't attempt to exchange them. If you know what you are doing
4942you can turn off this warning by C<no warnings 'nonchar';>.
b45f050a 4943
c794c51b
FC
4944=item Unicode surrogate U+%X is illegal in UTF-8
4945
8457b38f 4946(W utf8, surrogate) You had a UTF-16 surrogate in a context where they are
c794c51b
FC
4947not considered acceptable. These code points, between U+D800 and
4948U+DFFF (inclusive), are used by Unicode only for UTF-16. However, Perl
4949internally allows all unsigned integer code points (up to the size limit
4950available on your platform), including surrogates. But these can cause
4951problems when being input or output, which is likely where this message
4952came from. If you really really know what you are doing you can turn
8457b38f 4953off this warning by C<no warnings 'surrogate';>.
c794c51b 4954
a0d0e21e
LW
4955=item Unknown BYTEORDER
4956
be771a83
GS
4957(F) There are no byte-swapping functions for a machine with this byte
4958order.
a0d0e21e 4959
04177465
FC
4960=item Unknown error
4961
4962(P) Perl was about to print an error message in C<$@>, but the C<$@> variable
4963did not exist, even after an attempt to create it.
4964
6170680b
IZ
4965=item Unknown open() mode '%s'
4966
437784d6 4967(F) The second argument of 3-argument open() is not among the list
c47ff5f1 4968of valid modes: C<< < >>, C<< > >>, C<<< >> >>>, C<< +< >>,
488dad83 4969C<< +> >>, C<<< +>> >>>, C<-|>, C<|->, C<< <& >>, C<< >& >>.
6170680b 4970
b4581f09
JH
4971=item Unknown PerlIO layer "%s"
4972
4973(W layer) An attempt was made to push an unknown layer onto the Perl I/O
4974system. (Layers take care of transforming data between external and
4975internal representations.) Note that some layers, such as C<mmap>,
4976are not supported in all environments. If your program didn't
4977explicitly request the failing operation, it may be the result of the
4978value of the environment variable PERLIO.
4979
f675dbe5
CB
4980=item Unknown process %x sent message to prime_env_iter: %s
4981
4982(P) An error peculiar to VMS. Perl was reading values for %ENV before
4983iterating over it, and someone else stuck a message in the stream of
4984data Perl expected. Someone's very confused, or perhaps trying to
4985subvert Perl's population of %ENV for nefarious purposes.
a05d7ebb 4986
2f7da168
RK
4987=item Unknown "re" subpragma '%s' (known ones are: %s)
4988
a4a4c9e2 4989(W) You tried to use an unknown subpragma of the "re" pragma.
2f7da168 4990
bcd05b94 4991=item Unknown switch condition (?(%s in regex; marked by <-- HERE in m/%s/
96ebfdd7
RK
4992
4993(F) The condition part of a (?(condition)if-clause|else-clause) construct
6903afa2 4994is not known. The condition must be one of the following:
5fecf430 4995
674f6ed9
FC
4996 (1) (2) ... true if 1st, 2nd, etc., capture matched
4997 (<NAME>) ('NAME') true if named capture matched
4998 (?=...) (?<=...) true if subpattern matches
4999 (?!...) (?<!...) true if subpattern fails to match
5000 (?{ CODE }) true if code returns a true value
5001 (R) true if evaluating inside recursion
5002 (R1) (R2) ... true if directly inside capture group 1, 2, etc.
5003 (R&NAME) true if directly inside named capture
5004 (DEFINE) always false; for defining named subpatterns
96ebfdd7
RK
5005
5006The <-- HERE shows in the regular expression about where the problem was
5007discovered. See L<perlre>.
5008
a05d7ebb
JH
5009=item Unknown Unicode option letter '%c'
5010
a4a4c9e2 5011(F) You specified an unknown Unicode option. See L<perlrun> documentation
a05d7ebb
JH
5012of the C<-C> switch for the list of known options.
5013
5014=item Unknown Unicode option value %x
5015
a4a4c9e2 5016(F) You specified an unknown Unicode option. See L<perlrun> documentation
a05d7ebb 5017of the C<-C> switch for the list of known options.
f675dbe5 5018
e2e6a0f1
YO
5019=item Unknown verb pattern '%s' in regex; marked by <-- HERE in m/%s/
5020
5021(F) You either made a typo or have incorrectly put a C<*> quantifier
5022after an open brace in your pattern. Check the pattern and review
5023L<perlre> for details on legal verb patterns.
5024
c2771421
FC
5025=item Unknown warnings category '%s'
5026
6903afa2 5027(F) An error issued by the C<warnings> pragma. You specified a warnings
c2771421
FC
5028category that is unknown to perl at this point.
5029
14ef4c80
FC
5030Note that if you want to enable a warnings category registered by a
5031module (e.g. C<use warnings 'File::Find'>), you must have loaded this
5032module first.
c2771421 5033
7253e4e3 5034=item unmatched [ in regex; marked by <-- HERE in m/%s/
6df41af2 5035
6903afa2 5036(F) The brackets around a character class must match. If you wish to
be771a83 5037include a closing bracket in a character class, backslash it or put it
6903afa2
FC
5038first. The <-- HERE shows in the regular expression about where the
5039problem was discovered. See L<perlre>.
6df41af2 5040
7253e4e3 5041=item unmatched ( in regex; marked by <-- HERE in m/%s/
a0d0e21e
LW
5042
5043(F) Unbackslashed parentheses must always be balanced in regular
6903afa2
FC
5044expressions. If you're a vi user, the % key is valuable for finding
5045the matching parenthesis. The <-- HERE shows in the regular expression
5046about where the problem was discovered. See L<perlre>.
a0d0e21e 5047
d98d5fff 5048=item Unmatched right %s bracket
a0d0e21e 5049
be771a83
GS
5050(F) The lexer counted more closing curly or square brackets than opening
5051ones, so you're probably missing a matching opening bracket. As a
5052general rule, you'll find the missing one (so to speak) near the place
5053you were last editing.
a0d0e21e 5054
a0d0e21e
LW
5055=item Unquoted string "%s" may clash with future reserved word
5056
be771a83
GS
5057(W reserved) You used a bareword that might someday be claimed as a
5058reserved word. It's best to put such a word in quotes, or capitalize it
5059somehow, or insert an underbar into it. You might also declare it as a
5060subroutine.
a0d0e21e 5061
b1fc3636 5062=item Unrecognized character %s; marked by <-- HERE after %s near column %d
a0d0e21e 5063
54310121 5064(F) The Perl parser has no idea what to do with the specified character
b1fc3636 5065in your Perl script (or eval) near the specified column. Perhaps you tried
356c7adf 5066to run a compressed script, a binary program, or a directory as a Perl program.
a0d0e21e 5067
4a68bf9d 5068=item Unrecognized escape \%c in character class passed through in regex; marked by <-- HERE in m/%s/
6df41af2 5069
be771a83
GS
5070(W regexp) You used a backslash-character combination which is not
5071recognized by Perl inside character classes. The character was
b224edc1 5072understood literally, but this may change in a future version of Perl.
2628b4e0
TS
5073The <-- HERE shows in the regular expression about where the
5074escape was discovered.
6df41af2 5075
4a68bf9d 5076=item Unrecognized escape \%c passed through
2f7da168 5077
2628b4e0 5078(W misc) You used a backslash-character combination which is not
b224edc1
KW
5079recognized by Perl. The character was understood literally, but this may
5080change in a future version of Perl.
2f7da168 5081
216bfc0a 5082=item Unrecognized escape \%s passed through in regex; marked by <-- HERE in m/%s/
6df41af2 5083
be771a83 5084(W regexp) You used a backslash-character combination which is not
b7e4ecc1
FC
5085recognized by Perl. The character(s) were understood literally, but
5086this may change in a future version of Perl. The <-- HERE shows in
5087the regular expression about where the escape was discovered.
6df41af2 5088
a0d0e21e
LW
5089=item Unrecognized signal name "%s"
5090
be771a83
GS
5091(F) You specified a signal name to the kill() function that was not
5092recognized. Say C<kill -l> in your shell to see the valid signal names
5093on your system.
a0d0e21e 5094
90248788 5095=item Unrecognized switch: -%s (-h will show valid options)
a0d0e21e 5096
be771a83
GS
5097(F) You specified an illegal option to Perl. Don't do that. (If you
5098think you didn't do that, check the #! line to see if it's supplying the
5099bad switch on your behalf.)
a0d0e21e
LW
5100
5101=item Unsuccessful %s on filename containing newline
5102
be771a83
GS
5103(W newline) A file operation was attempted on a filename, and that
5104operation failed, PROBABLY because the filename contained a newline,
5b3eff12 5105PROBABLY because you forgot to chomp() it off. See L<perlfunc/chomp>.
a0d0e21e
LW
5106
5107=item Unsupported directory function "%s" called
5108
5109(F) Your machine doesn't support opendir() and readdir().
5110
6df41af2
GS
5111=item Unsupported function %s
5112
5113(F) This machine doesn't implement the indicated function, apparently.
5114At least, Configure doesn't think so.
5115
54310121 5116=item Unsupported function fork
5117
5118(F) Your version of executable does not support forking.
5119
be771a83 5120Note that under some systems, like OS/2, there may be different flavors
6903afa2 5121of Perl executables, some of which may support fork, some not. Try
be771a83 5122changing the name you call Perl by to C<perl_>, C<perl__>, and so on.
54310121 5123
7aa207d6 5124=item Unsupported script encoding %s
b250498f
GS
5125
5126(F) Your program file begins with a Unicode Byte Order Mark (BOM) which
7aa207d6 5127declares it to be in a Unicode encoding that Perl cannot read.
b250498f 5128
a0d0e21e
LW
5129=item Unsupported socket function "%s" called
5130
5131(F) Your machine doesn't support the Berkeley socket mechanism, or at
5132least that's what Configure thought.
5133
6df41af2 5134=item Unterminated attribute list
a0d0e21e 5135
be771a83
GS
5136(F) The lexer found something other than a simple identifier at the
5137start of an attribute, and it wasn't a semicolon or the start of a
5138block. Perhaps you terminated the parameter list of the previous
5139attribute too soon. See L<attributes>.
a0d0e21e 5140
09bef843
SB
5141=item Unterminated attribute parameter in attribute list
5142
be771a83
GS
5143(F) The lexer saw an opening (left) parenthesis character while parsing
5144an attribute list, but the matching closing (right) parenthesis
09bef843
SB
5145character was not found. You may need to add (or remove) a backslash
5146character to get your parentheses to balance. See L<attributes>.
5147
f1991046
GS
5148=item Unterminated compressed integer
5149
5150(F) An argument to unpack("w",...) was incompatible with the BER
5151compressed integer format and could not be converted to an integer.
5152See L<perlfunc/pack>.
5153
2bf803e2
YO
5154=item Unterminated \g{...} pattern in regex; marked by <-- HERE in m/%s/
5155
5156(F) You missed a close brace on a \g{..} pattern (group reference) in
fa816bf3 5157a regular expression. Fix the pattern and retry.
e2e6a0f1 5158
6df41af2 5159=item Unterminated <> operator
09bef843 5160
6df41af2 5161(F) The lexer saw a left angle bracket in a place where it was expecting
be771a83
GS
5162a term, so it's looking for the corresponding right angle bracket, and
5163not finding it. Chances are you left some needed parentheses out
5164earlier in the line, and you really meant a "less than".
09bef843 5165
905fe053
FC
5166=item Unterminated verb pattern argument in regex; marked by <-- HERE in m/%s/
5167
5168(F) You used a pattern of the form C<(*VERB:ARG)> but did not terminate
6903afa2 5169the pattern with a C<)>. Fix the pattern and retry.
905fe053
FC
5170
5171=item Unterminated verb pattern in regex; marked by <-- HERE in m/%s/
5172
5173(F) You used a pattern of the form C<(*VERB)> but did not terminate
6903afa2 5174the pattern with a C<)>. Fix the pattern and retry.
905fe053 5175
6df41af2 5176=item untie attempted while %d inner references still exist
a0d0e21e 5177
be771a83
GS
5178(W untie) A copy of the object returned from C<tie> (or C<tied>) was
5179still valid when C<untie> was called.
a0d0e21e 5180
8e11cd2b
JC
5181=item Usage: POSIX::%s(%s)
5182
5183(F) You called a POSIX function with incorrect arguments.
5184See L<POSIX/FUNCTIONS> for more information.
5185
5186=item Usage: Win32::%s(%s)
5187
5188(F) You called a Win32 function with incorrect arguments.
5189See L<Win32> for more information.
5190
89474f50
FC
5191=item $[ used in %s (did you mean $] ?)
5192
5193(W syntax) You used C<$[> in a comparison, such as:
5194
5195 if ($[ > 5.006) {
5196 ...
5197 }
5198
5199You probably meant to use C<$]> instead. C<$[> is the base for indexing
5200arrays. C<$]> is the Perl version number in decimal.
5201
8fe85e3f
FC
5202=item Useless assignment to a temporary
5203
5204(W misc) You assigned to an lvalue subroutine, but what
5205the subroutine returned was a temporary scalar about to
5206be discarded, so the assignment had no effect.
5207
96ebfdd7 5208=item Useless (?-%s) - don't use /%s modifier in regex; marked by <-- HERE in m/%s/
9d1d55b5 5209
96ebfdd7
RK
5210(W regexp) You have used an internal modifier such as (?-o) that has no
5211meaning unless removed from the entire regexp:
9d1d55b5 5212
96ebfdd7 5213 if ($string =~ /(?-o)$pattern/o) { ... }
9d1d55b5
JP
5214
5215must be written as
5216
96ebfdd7 5217 if ($string =~ /$pattern/) { ... }
9d1d55b5
JP
5218
5219The <-- HERE shows in the regular expression about
6903afa2 5220where the problem was discovered. See L<perlre>.
9d1d55b5 5221
b4581f09
JH
5222=item Useless localization of %s
5223
6903afa2
FC
5224(W syntax) The localization of lvalues such as C<local($x=10)> is legal,
5225but in fact the local() currently has no effect. This may change at
b4581f09
JH
5226some point in the future, but in the meantime such code is discouraged.
5227
96ebfdd7 5228=item Useless (?%s) - use /%s modifier in regex; marked by <-- HERE in m/%s/
9d1d55b5 5229
96ebfdd7
RK
5230(W regexp) You have used an internal modifier such as (?o) that has no
5231meaning unless applied to the entire regexp:
9d1d55b5 5232
96ebfdd7 5233 if ($string =~ /(?o)$pattern/) { ... }
9d1d55b5
JP
5234
5235must be written as
5236
96ebfdd7 5237 if ($string =~ /$pattern/o) { ... }
9d1d55b5
JP
5238
5239The <-- HERE shows in the regular expression about
6903afa2 5240where the problem was discovered. See L<perlre>.
9d1d55b5 5241
b08e453b
RB
5242=item Useless use of /d modifier in transliteration operator
5243
5244(W misc) You have used the /d modifier where the searchlist has the
6903afa2 5245same length as the replacelist. See L<perlop> for more information
b08e453b
RB
5246about the /d modifier.
5247
820438b1
FC
5248=item Useless use of \E
5249
5250(W misc) You have a \E in a double-quotish string without a C<\U>,
5251C<\L> or C<\Q> preceding it.
5252
6df41af2 5253=item Useless use of %s in void context
a0d0e21e 5254
75b44862 5255(W void) You did something without a side effect in a context that does
be771a83
GS
5256nothing with the return value, such as a statement that doesn't return a
5257value from a block, or the left side of a scalar comma operator. Very
5258often this points not to stupidity on your part, but a failure of Perl
5259to parse your program the way you thought it would. For example, you'd
5260get this if you mixed up your C precedence with Python precedence and
5261said
a0d0e21e 5262
6df41af2 5263 $one, $two = 1, 2;
748a9306 5264
6df41af2
GS
5265when you meant to say
5266
5267 ($one, $two) = (1, 2);
5268
5269Another common error is to use ordinary parentheses to construct a list
5270reference when you should be using square or curly brackets, for
5271example, if you say
5272
5273 $array = (1,2);
5274
5275when you should have said
5276
5277 $array = [1,2];
5278
5279The square brackets explicitly turn a list value into a scalar value,
5280while parentheses do not. So when a parenthesized list is evaluated in
5281a scalar context, the comma is treated like C's comma operator, which
5282throws away the left argument, which is not what you want. See
5283L<perlref> for more on this.
5284
65191a1e
BS
5285This warning will not be issued for numerical constants equal to 0 or 1
5286since they are often used in statements like
5287
4358a253 5288 1 while sub_with_side_effects();
65191a1e
BS
5289
5290String constants that would normally evaluate to 0 or 1 are warned
5291about.
5292
6df41af2
GS
5293=item Useless use of "re" pragma
5294
6903afa2 5295(W) You did C<use re;> without any arguments. That isn't very useful.
6df41af2 5296
a801c63c
RGS
5297=item Useless use of sort in scalar context
5298
5299(W void) You used sort in scalar context, as in :
5300
5301 my $x = sort @y;
5302
5303This is not very useful, and perl currently optimizes this away.
5304
de4864e4
JH
5305=item Useless use of %s with no values
5306
f87c3213 5307(W syntax) You used the push() or unshift() function with no arguments
6903afa2
FC
5308apart from the array, like C<push(@x)> or C<unshift(@foo)>. That won't
5309usually have any effect on the array, so is completely useless. It's
de4864e4 5310possible in principle that push(@tied_array) could have some effect
6903afa2 5311if the array is tied to a class which implements a PUSH method. If so,
de4864e4
JH
5312you can write it as C<push(@tied_array,())> to avoid this warning.
5313
6df41af2
GS
5314=item "use" not allowed in expression
5315
be771a83
GS
5316(F) The "use" keyword is recognized and executed at compile time, and
5317returns no useful value. See L<perlmod>.
748a9306 5318
36b2db7e
FC
5319=item Use of assignment to $[ is deprecated
5320
5321(D deprecated) The C<$[> variable (index of the first element in an array)
6903afa2 5322is deprecated. See L<perlvar/"$[">.
36b2db7e 5323
c47ff5f1 5324=item Use of bare << to mean <<"" is deprecated
4633a7c4 5325
8ab8f082 5326(D deprecated) You are now encouraged to use the explicitly quoted
83ce3e12
RGS
5327form if you wish to use an empty line as the terminator of the here-document.
5328
5329=item Use of comma-less variable list is deprecated
5330
8ab8f082 5331(D deprecated) The values you give to a format should be
83ce3e12 5332separated by commas, not just aligned on a line.
4633a7c4 5333
96ebfdd7
RK
5334=item Use of chdir('') or chdir(undef) as chdir() deprecated
5335
5336(D deprecated) chdir() with no arguments is documented to change to
5337$ENV{HOME} or $ENV{LOGDIR}. chdir(undef) and chdir('') share this
5338behavior, but that has been deprecated. In future versions they
5339will simply fail.
5340
5341Be careful to check that what you pass to chdir() is defined and not
5342blank, else you might find yourself in your home directory.
5343
64e578a2
MJD
5344=item Use of /c modifier is meaningless in s///
5345
5346(W regexp) You used the /c modifier in a substitution. The /c
5347modifier is not presently meaningful in substitutions.
5348
4ac733c9
MJD
5349=item Use of /c modifier is meaningless without /g
5350
5351(W regexp) You used the /c modifier with a regex operand, but didn't
5352use the /g modifier. Currently, /c is meaningful only when /g is
5353used. (This may change in the future.)
5354
2dc78664 5355=item Use of := for an empty attribute list is not allowed
036e1e65 5356
2dc78664
NC
5357(F) The construction C<my $x := 42> used to parse as equivalent to
5358C<my $x : = 42> (applying an empty attribute list to C<$x>).
5359This construct was deprecated in 5.12.0, and has now been made a syntax
5360error, so C<:=> can be reclaimed as a new operator in the future.
5361
5362If you need an empty attribute list, for example in a code generator, add
5363a space before the C<=>.
036e1e65 5364
b6c83531 5365=item Use of freed value in iteration
2f7da168 5366
b6c83531
JH
5367(F) Perhaps you modified the iterated array within the loop?
5368This error is typically caused by code like the following:
2f7da168
RK
5369
5370 @a = (3,4);
5371 @a = () for (1,2,@a);
5372
5373You are not supposed to modify arrays while they are being iterated over.
5374For speed and efficiency reasons, Perl internally does not do full
5375reference-counting of iterated items, hence deleting such an item in the
5376middle of an iteration causes Perl to see a freed value.
5377
39b99f21 5378=item Use of *glob{FILEHANDLE} is deprecated
5379
5380(D deprecated) You are now encouraged to use the shorter *glob{IO} form
5381to access the filehandle slot within a typeglob.
5382
96ebfdd7 5383=item Use of /g modifier is meaningless in split
35ae6b54 5384
96ebfdd7
RK
5385(W regexp) You used the /g modifier on the pattern for a C<split>
5386operator. Since C<split> always tries to match the pattern
5387repeatedly, the C</g> has no effect.
35ae6b54 5388
0b98bec9
RGS
5389=item Use of "goto" to jump into a construct is deprecated
5390
5391(D deprecated) Using C<goto> to jump from an outer scope into an inner
5392scope is deprecated and should be avoided.
5393
dc848c6f 5394=item Use of inherited AUTOLOAD for non-method %s() is deprecated
5395
1da25648
FC
5396(D deprecated) As an (ahem) accidental feature, C<AUTOLOAD>
5397subroutines are looked up as methods (using the C<@ISA> hierarchy)
5398even when the subroutines to be autoloaded were called as plain
5399functions (e.g. C<Foo::bar()>), not as methods (e.g. C<< Foo->bar() >> or
5400C<< $obj->bar() >>).
dc848c6f 5401
be771a83
GS
5402This bug will be rectified in future by using method lookup only for
5403methods' C<AUTOLOAD>s. However, there is a significant base of existing
5404code that may be using the old behavior. So, as an interim step, Perl
5405currently issues an optional warning when non-methods use inherited
5406C<AUTOLOAD>s.
dc848c6f 5407
5408The simple rule is: Inheritance will not work when autoloading
be771a83
GS
5409non-methods. The simple fix for old code is: In any module that used
5410to depend on inheriting C<AUTOLOAD> for non-methods from a base class
5411named C<BaseClass>, execute C<*AUTOLOAD = \&BaseClass::AUTOLOAD> during
5412startup.
dc848c6f 5413
be771a83
GS
5414In code that currently says C<use AutoLoader; @ISA = qw(AutoLoader);>
5415you should remove AutoLoader from @ISA and change C<use AutoLoader;> to
7b8d334a 5416C<use AutoLoader 'AUTOLOAD';>.
fb73857a 5417
6df41af2
GS
5418=item Use of %s in printf format not supported
5419
5420(F) You attempted to use a feature of printf that is accessible from
5421only C. This usually means there's a better way to do it in Perl.
5422
6df41af2
GS
5423=item Use of %s is deprecated
5424
75b44862 5425(D deprecated) The construct indicated is no longer recommended for use,
be771a83
GS
5426generally because there's a better way to do it, and also because the
5427old way has bad side effects.
6df41af2 5428
5a7abfcc
FC
5429=item Use of -l on filehandle %s
5430
5431(W io) A filehandle represents an opened file, and when you opened the file
5432it already went past any symlink you are presumably trying to look for.
5433The operation returned C<undef>. Use a filename instead.
5434
7c7df812
FC
5435=item Use of %s on a handle without * is deprecated
5436
22d6fc57 5437(D deprecated) You used C<tie>, C<tied> or C<untie> on a scalar but that scalar
fa816bf3 5438happens to hold a typeglob, which means its filehandle will be tied. If
22d6fc57
FC
5439you mean to tie a handle, use an explicit * as in C<tie *$handle>.
5440
5441This was a long-standing bug that was removed in Perl 5.16, as there was
5442no way to tie the scalar itself when it held a typeglob, and no way to
5443untie a scalar that had had a typeglob assigned to it. If you see this
5444message, you must be using an older version.
7c7df812 5445
905fe053
FC
5446=item Use of ?PATTERN? without explicit operator is deprecated
5447
5448(D deprecated) You have written something like C<?\w?>, for a regular
5449expression that matches only once. Starting this term directly with
5450the question mark delimiter is now deprecated, so that the question mark
5451will be available for use in new operators in the future. Write C<m?\w?>
5452instead, explicitly using the C<m> operator: the question mark delimiter
5453still invokes match-once behaviour.
5454
ea25a9b2
Z
5455=item Use of qw(...) as parentheses is deprecated
5456
5457(D deprecated) You have something like C<foreach $x qw(a b c) {...}>,
5458using a C<qw(...)> list literal where a parenthesised expression is
5459expected. Historically the parser fooled itself into thinking that
5460C<qw(...)> literals were always enclosed in parentheses, and as a result
5461you could sometimes omit parentheses around them. (You could never do
5462the C<foreach qw(a b c) {...}> that you might have expected, though.)
5463The parser no longer lies to itself in this way. Wrap the list literal
5464in parentheses, like C<foreach $x (qw(a b c)) {...}>.
5465
1f1cc344 5466=item Use of reference "%s" as array index
d804643f 5467
77b96956 5468(W misc) You tried to use a reference as an array index; this probably
1f1cc344
JH
5469isn't what you mean, because references in numerical context tend
5470to be huge numbers, and so usually indicates programmer error.
d804643f 5471
64977eb6 5472If you really do mean it, explicitly numify your reference, like so:
1f1cc344 5473C<$array[0+$ref]>. This warning is not given for overloaded objects,
54e0f05c 5474however, because you can overload the numification and stringification
c69ca1d4 5475operators and then you presumably know what you are doing.
d804643f 5476
85b81015
LW
5477=item Use of reserved word "%s" is deprecated
5478
be771a83
GS
5479(D deprecated) The indicated bareword is a reserved word. Future
5480versions of perl may use it as a keyword, so you're better off either
5481explicitly quoting the word in a manner appropriate for its context of
5482use, or using a different name altogether. The warning can be
5483suppressed for subroutine names by either adding a C<&> prefix, or using
5484a package qualifier, e.g. C<&our()>, or C<Foo::our()>.
85b81015 5485
bbd7eb8a
RD
5486=item Use of tainted arguments in %s is deprecated
5487
159f47d9 5488(W taint, deprecated) You have supplied C<system()> or C<exec()> with multiple
bbd7eb8a
RD
5489arguments and at least one of them is tainted. This used to be allowed
5490but will become a fatal error in a future version of perl. Untaint your
5491arguments. See L<perlsec>.
5492
cc95b072 5493=item Use of uninitialized value%s
a0d0e21e 5494
be771a83
GS
5495(W uninitialized) An undefined value was used as if it were already
5496defined. It was interpreted as a "" or a 0, but maybe it was a mistake.
5497To suppress this warning assign a defined value to your variables.
a0d0e21e 5498
6903afa2
FC
5499To help you figure out what was undefined, perl will try to tell you
5500the name of the variable (if any) that was undefined. In some cases
5501it cannot do this, so it also tells you what operation you used the
5502undefined value in. Note, however, that perl optimizes your program
5503anid the operation displayed in the warning may not necessarily appear
5504literally in your program. For example, C<"that $foo"> is usually
5505optimized into C<"that " . $foo>, and the warning will refer to the
5506C<concatenation (.)> operator, even though there is no C<.> in
5507your program.
e5be4a53 5508
a1063b2d
RH
5509=item Using a hash as a reference is deprecated
5510
496a33f5 5511(D deprecated) You tried to use a hash as a reference, as in
1b1f1335 5512C<< %foo->{"bar"} >> or C<< %$ref->{"hello"} >>. Versions of perl <= 5.6.1
6903afa2
FC
5513used to allow this syntax, but shouldn't have. It is now
5514deprecated, and will be removed in a future version.
a1063b2d
RH
5515
5516=item Using an array as a reference is deprecated
5517
496a33f5 5518(D deprecated) You tried to use an array as a reference, as in
1b1f1335 5519C<< @foo->[23] >> or C<< @$ref->[99] >>. Versions of perl <= 5.6.1 used to
6903afa2
FC
5520allow this syntax, but shouldn't have. It is now deprecated,
5521and will be removed in a future version.
a1063b2d 5522
ff3f963a
KW
5523=item Using just the first character returned by \N{} in character class
5524
5525(W) A charnames handler may return a sequence of more than one character.
5526Currently all but the first one are discarded when used in a regular
5527expression pattern bracketed character class.
5528
c794c51b
FC
5529=item Using !~ with %s doesn't make sense
5530
5531(F) Using the C<!~> operator with C<s///r>, C<tr///r> or C<y///r> is
5532currently reserved for future use, as the exact behaviour has not
6903afa2 5533been decided. (Simply returning the boolean opposite of the
c794c51b 5534modified string is usually not particularly useful.)
0876b9a0 5535
949cf498
KW
5536=item UTF-16 surrogate U+%X
5537
8457b38f 5538(W utf8, surrogate) You had a UTF-16 surrogate in a context where they are
949cf498
KW
5539not considered acceptable. These code points, between U+D800 and
5540U+DFFF (inclusive), are used by Unicode only for UTF-16. However, Perl
5541internally allows all unsigned integer code points (up to the size limit
5542available on your platform), including surrogates. But these can cause
5543problems when being input or output, which is likely where this message
5544came from. If you really really know what you are doing you can turn
8457b38f 5545off this warning by C<no warnings 'surrogate';>.
9466bab6 5546
68dc0745 5547=item Value of %s can be "0"; test with defined()
a6006777 5548
75b44862 5549(W misc) In a conditional expression, you used <HANDLE>, <*> (glob),
be771a83
GS
5550C<each()>, or C<readdir()> as a boolean value. Each of these constructs
5551can return a value of "0"; that would make the conditional expression
5552false, which is probably not what you intended. When using these
5553constructs in conditional expressions, test their values with the
5554C<defined> operator.
a6006777 5555
f675dbe5
CB
5556=item Value of CLI symbol "%s" too long
5557
be771a83
GS
5558(W misc) A warning peculiar to VMS. Perl tried to read the value of an
5559%ENV element from a CLI symbol table, and found a resultant string
5560longer than 1024 characters. The return value has been truncated to
55611024 characters.
f675dbe5 5562
b5c19bd7 5563=item Variable "%s" is not available
44a8e56a 5564
b5c19bd7
DM
5565(W closure) During compilation, an inner named subroutine or eval is
5566attempting to capture an outer lexical that is not currently available.
6903afa2 5567This can happen for one of two reasons. First, the outer lexical may be
b5c19bd7
DM
5568declared in an outer anonymous subroutine that has not yet been created.
5569(Remember that named subs are created at compile time, while anonymous
6903afa2 5570subs are created at run-time.) For example,
44a8e56a 5571
b5c19bd7 5572 sub { my $a; sub f { $a } }
44a8e56a 5573
b5c19bd7 5574At the time that f is created, it can't capture the current value of $a,
6903afa2 5575since the anonymous subroutine hasn't been created yet. Conversely,
b5c19bd7
DM
5576the following won't give a warning since the anonymous subroutine has by
5577now been created and is live:
be771a83 5578
b5c19bd7
DM
5579 sub { my $a; eval 'sub f { $a }' }->();
5580
5581The second situation is caused by an eval accessing a variable that has
5582gone out of scope, for example,
5583
5584 sub f {
5585 my $a;
5586 sub { eval '$a' }
5587 }
5588 f()->();
5589
5590Here, when the '$a' in the eval is being compiled, f() is not currently being
5591executed, so its $a is not available for capture.
44a8e56a 5592
b4581f09
JH
5593=item Variable "%s" is not imported%s
5594
413ff9f6
FC
5595(W misc) With "use strict" in effect, you referred to a global variable
5596that you apparently thought was imported from another module, because
b4581f09
JH
5597something else of the same name (usually a subroutine) is exported by
5598that module. It usually means you put the wrong funny character on the
5599front of your variable.
5600
58e23c8d 5601=item Variable length lookbehind not implemented in m/%s/
b4581f09
JH
5602
5603(F) Lookbehind is allowed only for subexpressions whose length is fixed and
58e23c8d 5604known at compile time. See L<perlre>.
b4581f09
JH
5605
5606=item "%s" variable %s masks earlier declaration in same %s
5607
b9cc85ad
FC
5608(W misc) A "my", "our" or "state" variable has been redeclared in the
5609current scope or statement, effectively eliminating all access to the
5610previous instance. This is almost always a typographical error. Note
5611that the earlier variable will still exist until the end of the scope
5612or until all closure referents to it are destroyed.
b4581f09 5613
6df41af2
GS
5614=item Variable syntax
5615
5616(A) You've accidentally run your script through B<csh> instead
5617of Perl. Check the #! line, or manually feed your script into
5618Perl yourself.
5619
44a8e56a 5620=item Variable "%s" will not stay shared
5621
be771a83 5622(W closure) An inner (nested) I<named> subroutine is referencing a
b5c19bd7 5623lexical variable defined in an outer named subroutine.
44a8e56a 5624
b5c19bd7 5625When the inner subroutine is called, it will see the value of
be771a83
GS
5626the outer subroutine's variable as it was before and during the *first*
5627call to the outer subroutine; in this case, after the first call to the
5628outer subroutine is complete, the inner and outer subroutines will no
5629longer share a common value for the variable. In other words, the
5630variable will no longer be shared.
44a8e56a 5631
44a8e56a 5632This problem can usually be solved by making the inner subroutine
5633anonymous, using the C<sub {}> syntax. When inner anonymous subs that
b5c19bd7 5634reference variables in outer subroutines are created, they
be771a83 5635are automatically rebound to the current values of such variables.
44a8e56a 5636
6651ba0b
FC
5637=item vector argument not supported with alpha versions
5638
5639(W internal) The %vd (s)printf format does not support version objects
5640with alpha parts.
5641
e2e6a0f1
YO
5642=item Verb pattern '%s' has a mandatory argument in regex; marked by <-- HERE in m/%s/
5643
6903afa2
FC
5644(F) You used a verb pattern that requires an argument. Supply an
5645argument or check that you are using the right verb.
e2e6a0f1
YO
5646
5647=item Verb pattern '%s' may not have an argument in regex; marked by <-- HERE in m/%s/
5648
6903afa2 5649(F) You used a verb pattern that is not allowed an argument. Remove the
e2e6a0f1
YO
5650argument or check that you are using the right verb.
5651
084610c0
GS
5652=item Version number must be a constant number
5653
5654(P) The attempt to translate a C<use Module n.n LIST> statement into
5655its equivalent C<BEGIN> block found an internal inconsistency with
5656the version number.
5657
808ee47e
SP
5658=item Version string '%s' contains invalid data; ignoring: '%s'
5659
32e998fd
RGS
5660(W misc) The version string contains invalid characters at the end, which
5661are being ignored.
808ee47e 5662
7e1af8bc 5663=item Warning: something's wrong
5f05dabc 5664
5665(W) You passed warn() an empty string (the equivalent of C<warn "">) or
ec8bb14c 5666you called it with no args and C<$@> was empty.
5f05dabc 5667
f86702cc 5668=item Warning: unable to close filehandle %s properly
a0d0e21e 5669
be771a83
GS
5670(S) The implicit close() done by an open() got an error indication on
5671the close(). This usually indicates your file system ran out of disk
5672space.
a0d0e21e 5673
5f05dabc 5674=item Warning: Use of "%s" without parentheses is ambiguous
a0d0e21e 5675
be771a83
GS
5676(S ambiguous) You wrote a unary operator followed by something that
5677looks like a binary operator that could also have been interpreted as a
5678term or unary operator. For instance, if you know that the rand
5679function has a default argument of 1.0, and you write
a0d0e21e
LW
5680
5681 rand + 5;
5682
5683you may THINK you wrote the same thing as
5684
5685 rand() + 5;
5686
5687but in actual fact, you got
5688
5689 rand(+5);
5690
5f05dabc 5691So put in parentheses to say what you really mean.
a0d0e21e 5692
4b3603a4
JH
5693=item Wide character in %s
5694
c8f79457 5695(S utf8) Perl met a wide character (>255) when it wasn't expecting
cd28123a
JH
5696one. This warning is by default on for I/O (like print). The easiest
5697way to quiet this warning is simply to add the C<:utf8> layer to the
5698output, e.g. C<binmode STDOUT, ':utf8'>. Another way to turn off the
5699warning is to add C<no warnings 'utf8';> but that is often closer to
5700cheating. In general, you are supposed to explicitly mark the
5701filehandle with an encoding, see L<open> and L<perlfunc/binmode>.
4b3603a4 5702
49704364
WL
5703=item Within []-length '%c' not allowed
5704
fa816bf3
FC
5705(F) The count in the (un)pack template may be replaced by C<[TEMPLATE]>
5706only if C<TEMPLATE> always matches the same amount of packed bytes that
5707can be determined from the template alone. This is not possible if
5708it contains any of the codes @, /, U, u, w or a *-length. Redesign
5709the template.
49704364 5710
9a7dcd9c 5711=item write() on closed filehandle %s
a0d0e21e 5712
be771a83 5713(W closed) The filehandle you're writing to got itself closed sometime
c289d2f7 5714before now. Check your control flow.
a0d0e21e 5715
9ae3ac1a 5716=item %s "\x%X" does not map to Unicode
b4581f09 5717
a4a4c9e2 5718(F) When reading in different encodings Perl tries to map everything
b4581f09
JH
5719into Unicode characters. The bytes you read in are not legal in
5720this encoding, for example
5721
5722 utf8 "\xE4" does not map to Unicode
5723
5724if you try to read in the a-diaereses Latin-1 as UTF-8.
5725
49704364 5726=item 'X' outside of string
a0d0e21e 5727
49704364
WL
5728(F) You had a (un)pack template that specified a relative position before
5729the beginning of the string being (un)packed. See L<perlfunc/pack>.
a0d0e21e 5730
49704364 5731=item 'x' outside of string in unpack
a0d0e21e
LW
5732
5733(F) You had a pack template that specified a relative position after
5734the end of the string being unpacked. See L<perlfunc/pack>.
5735
a0d0e21e
LW
5736=item YOU HAVEN'T DISABLED SET-ID SCRIPTS IN THE KERNEL YET!
5737
5f05dabc 5738(F) And you probably never will, because you probably don't have the
a0d0e21e 5739sources to your kernel, and your vendor probably doesn't give a rip
1b1f1335 5740about what you want. Your best bet is to put a setuid C wrapper around
496a33f5 5741your script.
a0d0e21e
LW
5742
5743=item You need to quote "%s"
5744
be771a83
GS
5745(W syntax) You assigned a bareword as a signal handler name.
5746Unfortunately, you already have a subroutine of that name declared,
5747which means that Perl 5 will try to call the subroutine when the
5748assignment is executed, which is probably not what you want. (If it IS
5749what you want, put an & in front.)
a0d0e21e 5750
6cfd5ea7
JH
5751=item Your random numbers are not that random
5752
5753(F) When trying to initialise the random seed for hashes, Perl could
5754not get any randomness out of your system. This usually indicates
5755Something Very Wrong.
5756
a0d0e21e
LW
5757=back
5758
00eb3f2b
RGS
5759=head1 SEE ALSO
5760
ed3f9c4f 5761L<warnings>, L<perllexwarn>, L<diagnostics>.
00eb3f2b 5762
56e90b21 5763=cut