compiler.properties revision 3589:b27ce9a1374e
1#
2# Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved.
3# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4#
5# This code is free software; you can redistribute it and/or modify it
6# under the terms of the GNU General Public License version 2 only, as
7# published by the Free Software Foundation.  Oracle designates this
8# particular file as subject to the "Classpath" exception as provided
9# by Oracle in the LICENSE file that accompanied this code.
10#
11# This code is distributed in the hope that it will be useful, but WITHOUT
12# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14# version 2 for more details (a copy is included in the LICENSE file that
15# accompanied this code).
16#
17# You should have received a copy of the GNU General Public License version
18# 2 along with this work; if not, write to the Free Software Foundation,
19# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20#
21# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22# or visit www.oracle.com if you need additional information or have any
23# questions.
24#
25
26# Messages in this file which use "placeholders" for values (e.g. {0}, {1})
27# are preceded by a stylized comment describing the type of the corresponding
28# values.
29# The simple types currently in use are:
30#
31# boolean           true or false
32# diagnostic        a sub-message; see compiler.misc.*
33# fragment          similar to 'message segment', but with more specific type
34# modifier          a Java modifier; e.g. public, private, protected
35# file              a file URL
36# file object       a file URL - similar to 'file' but typically used for source/class files, hence more specific
37# name              a name, typically a Java identifier
38# number            an integer
39# option name       the name of a command line option
40# source version    a source version number, such as 1.5, 1.6, 1.7
41# string            a general string
42# symbol            the name of a declared type
43# symbol kind       the kind of a symbol (i.e. method, variable)
44# kind name         an informative description of the kind of a declaration; see compiler.misc.kindname.*
45# token             the name of a non-terminal in source code; see compiler.misc.token.*
46# type              a Java type; e.g. int, X, X<T>
47# object            a Java object (unspecified)
48# unused            the value is not used in this message
49#
50# The following compound types are also used:
51#
52# list of X         a comma-separated list of items; e.g. list of type
53# set of X          a comma-separated collection of items; e.g. set of modifier
54#
55# These may be composed:
56#
57# list of type or message segment
58#
59# The following type aliases are supported:
60#
61# message segment --> diagnostic or fragment
62# file name --> file or file object
63#
64# Custom comments are supported in parenthesis i.e.
65#
66# number (classfile major version)
67#
68# These comments are used internally in order to generate an enum-like class declaration containing
69# a method/field for each of the diagnostic keys listed here. Those methods/fields can then be used
70# by javac code to build diagnostics in a type-safe fashion.
71#
72# In addition, these comments are verified by the jtreg test test/tools/javac/diags/MessageInfo,
73# using info derived from the collected set of examples in test/tools/javac/diags/examples.
74# MessageInfo can also be run as a standalone utility providing more facilities
75# for manipulating this file. For more details, see MessageInfo.java.
76
77##
78## errors
79##
80
81# 0: symbol
82compiler.err.abstract.cant.be.instantiated=\
83    {0} is abstract; cannot be instantiated
84
85compiler.err.abstract.meth.cant.have.body=\
86    abstract methods cannot have a body
87
88compiler.err.already.annotated=\
89    {0} {1} has already been annotated
90
91# 0: symbol kind, 1: symbol, 2: symbol kind, 3: symbol
92compiler.err.already.defined=\
93    {0} {1} is already defined in {2} {3}
94
95# 0: symbol kind, 1: symbol, 2: symbol kind, 3: symbol kind, 4: symbol
96compiler.err.already.defined.in.clinit=\
97    {0} {1} is already defined in {2} of {3} {4}
98
99# 0: string
100compiler.err.already.defined.single.import=\
101    a type with the same simple name is already defined by the single-type-import of {0}
102
103# 0: string
104compiler.err.already.defined.static.single.import=\
105    a type with the same simple name is already defined by the static single-type-import of {0}
106
107compiler.err.already.defined.this.unit=\
108    {0} is already defined in this compilation unit
109
110# 0: type, 1: list of name
111compiler.err.annotation.missing.default.value=\
112    annotation @{0} is missing a default value for the element ''{1}''
113
114# 0: type, 1: list of name
115compiler.err.annotation.missing.default.value.1=\
116    annotation @{0} is missing default values for elements {1}
117
118# 0: type
119compiler.err.annotation.not.valid.for.type=\
120    annotation not valid for an element of type {0}
121
122compiler.err.annotation.type.not.applicable=\
123    annotation type not applicable to this kind of declaration
124
125# 0: type
126compiler.err.annotation.type.not.applicable.to.type=\
127    annotation @{0} not applicable in this type context
128
129compiler.err.annotation.value.must.be.annotation=\
130    annotation value must be an annotation
131
132compiler.err.annotation.value.must.be.class.literal=\
133    annotation value must be a class literal
134
135compiler.err.annotation.value.must.be.name.value=\
136    annotation values must be of the form ''name=value''
137
138compiler.err.annotation.value.not.allowable.type=\
139    annotation value not of an allowable type
140
141compiler.err.anon.class.impl.intf.no.args=\
142    anonymous class implements interface; cannot have arguments
143
144compiler.err.anon.class.impl.intf.no.typeargs=\
145    anonymous class implements interface; cannot have type arguments
146
147compiler.err.anon.class.impl.intf.no.qual.for.new=\
148    anonymous class implements interface; cannot have qualifier for new
149
150compiler.err.cant.inherit.from.anon=\
151    cannot inherit from anonymous class
152
153# 0: symbol, 1: symbol, 2: symbol
154compiler.err.array.and.varargs=\
155    cannot declare both {0} and {1} in {2}
156
157compiler.err.array.dimension.missing=\
158    array dimension missing
159
160# 0: type
161compiler.err.array.req.but.found=\
162    array required, but {0} found
163
164compiler.err.attribute.value.must.be.constant=\
165    element value must be a constant expression
166
167# 0: string (statement type)
168compiler.err.bad.initializer=\
169    bad initializer for {0}
170
171compiler.err.break.outside.switch.loop=\
172    break outside switch or loop
173
174# 0: name
175compiler.err.call.must.be.first.stmt.in.ctor=\
176    call to {0} must be first statement in constructor
177
178# 0: symbol kind, 1: name, 2: list of type or message segment, 3: list of type or message segment, 4: symbol kind, 5: type, 6: message segment
179compiler.err.cant.apply.symbol=\
180    {0} {1} in {4} {5} cannot be applied to given types;\n\
181    required: {2}\n\
182    found: {3}\n\
183    reason: {6}
184
185# 0: symbol kind, 1: name, 2: list of type
186compiler.err.cant.apply.symbols=\
187    no suitable {0} found for {1}({2})
188
189# 0: symbol kind, 1: name, 2: list of type or message segment, 3: list of type or message segment, 4: symbol kind, 5: type, 6: message segment
190compiler.misc.cant.apply.symbol=\
191    {0} {1} in {4} {5} cannot be applied to given types\n\
192    required: {2}\n\
193    found: {3}\n\
194    reason: {6}
195
196# 0: symbol kind, 1: name, 2: list of type
197compiler.misc.cant.apply.symbols=\
198    no suitable {0} found for {1}({2})
199
200# 0: symbol kind, 1: symbol
201compiler.misc.no.abstracts=\
202    no abstract method found in {0} {1}
203
204# 0: symbol kind, 1: symbol
205compiler.misc.incompatible.abstracts=\
206    multiple non-overriding abstract methods found in {0} {1}
207
208compiler.err.bad.functional.intf.anno=\
209    Unexpected @FunctionalInterface annotation
210
211# 0: message segment
212compiler.err.bad.functional.intf.anno.1=\
213    Unexpected @FunctionalInterface annotation\n\
214    {0}
215
216# 0: message segment
217compiler.err.anonymous.diamond.method.does.not.override.superclass=\
218    method does not override or implement a method from a supertype\n\
219    {0}
220
221# 0: symbol
222compiler.misc.not.a.functional.intf=\
223    {0} is not a functional interface
224
225# 0: symbol, 1: message segment
226compiler.misc.not.a.functional.intf.1=\
227    {0} is not a functional interface\n\
228    {1}
229
230# 0: symbol, 1: symbol kind, 2: symbol
231compiler.misc.invalid.generic.lambda.target=\
232    invalid functional descriptor for lambda expression\n\
233    method {0} in {1} {2} is generic
234
235# 0: symbol kind, 1: symbol
236compiler.misc.incompatible.descs.in.functional.intf=\
237    incompatible function descriptors found in {0} {1}
238
239# 0: name, 1: list of type, 2: type, 3: list of type
240compiler.misc.descriptor=\
241    descriptor: {2} {0}({1})
242
243# 0: name, 1: list of type, 2: type, 3: list of type
244compiler.misc.descriptor.throws=\
245    descriptor: {2} {0}({1}) throws {3}
246
247# 0: type
248compiler.misc.no.suitable.functional.intf.inst=\
249    cannot infer functional interface descriptor for {0}
250
251# 0: message segment
252compiler.misc.bad.intersection.target.for.functional.expr=\
253    bad intersection type target for lambda or method reference\n\
254    {0}
255
256# 0: symbol or type
257compiler.misc.not.an.intf.component=\
258    component type {0} is not an interface
259
260# 0: symbol kind, 1: message segment
261compiler.err.invalid.mref=\
262    invalid {0} reference\n\
263    {1}
264
265# 0: symbol kind, 1: message segment
266compiler.misc.invalid.mref=\
267    invalid {0} reference\n\
268    {1}
269
270compiler.misc.static.mref.with.targs=\
271    parameterized qualifier on static method reference
272
273# 0: symbol
274compiler.err.cant.assign.val.to.final.var=\
275    cannot assign a value to final variable {0}
276
277compiler.err.cant.assign.val.to.this=\
278    cannot assign to ''this''
279
280# 0: symbol, 1: message segment
281compiler.err.cant.ref.non.effectively.final.var=\
282    local variables referenced from {1} must be final or effectively final
283
284compiler.err.try.with.resources.expr.needs.var=\
285    the try-with-resources resource must either be a variable declaration or an expression denoting \
286a reference to a final or effectively final variable
287
288# 0: symbol
289compiler.err.try.with.resources.expr.effectively.final.var=\
290    variable {0} used as a try-with-resources resource neither final nor effectively final
291
292
293compiler.misc.lambda=\
294    a lambda expression
295
296compiler.misc.inner.cls=\
297    an inner class
298
299# 0: type
300compiler.err.cant.deref=\
301    {0} cannot be dereferenced
302
303compiler.err.cant.extend.intf.annotation=\
304    ''extends'' not allowed for @interfaces
305
306# 0: symbol
307compiler.err.cant.inherit.from.final=\
308    cannot inherit from final {0}
309
310# 0: symbol
311compiler.err.cant.ref.before.ctor.called=\
312    cannot reference {0} before supertype constructor has been called
313
314compiler.err.cant.select.static.class.from.param.type=\
315    cannot select a static class from a parameterized type
316
317# 0: symbol, 1: string, 2: string
318compiler.err.cant.inherit.diff.arg=\
319    {0} cannot be inherited with different arguments: <{1}> and <{2}>
320
321compiler.err.catch.without.try=\
322    ''catch'' without ''try''
323
324# 0: symbol kind, 1: symbol
325compiler.err.clash.with.pkg.of.same.name=\
326    {0} {1} clashes with package of same name
327
328compiler.err.class.not.allowed=\
329    class, interface or enum declaration not allowed here
330
331compiler.err.const.expr.req=\
332    constant expression required
333
334compiler.err.cont.outside.loop=\
335    continue outside of loop
336
337# 0: symbol
338compiler.err.cyclic.inheritance=\
339    cyclic inheritance involving {0}
340
341# 0: symbol
342compiler.err.cyclic.annotation.element=\
343    type of element {0} is cyclic
344
345# 0: unused
346compiler.err.call.to.super.not.allowed.in.enum.ctor=\
347    call to super not allowed in enum constructor
348
349# 0: type
350compiler.err.no.superclass=\
351    {0} has no superclass.
352
353# 0: symbol, 1: type, 2: symbol, 3: type, 4: unused
354compiler.err.concrete.inheritance.conflict=\
355    methods {0} from {1} and {2} from {3} are inherited with the same signature
356
357compiler.err.default.allowed.in.intf.annotation.member=\
358    default value only allowed in an annotation type declaration
359
360# 0: symbol
361compiler.err.doesnt.exist=\
362    package {0} does not exist
363
364# 0: type
365compiler.err.duplicate.annotation.invalid.repeated=\
366    annotation {0} is not a valid repeatable annotation
367
368# 0: name, 1: type
369compiler.err.duplicate.annotation.member.value=\
370    duplicate element ''{0}'' in annotation @{1}.
371
372# 0: name, 1: unused
373compiler.err.duplicate.annotation.missing.container=\
374    {0} is not a repeatable annotation type
375
376# 0: type, 1: unused
377compiler.err.invalid.repeatable.annotation=\
378    duplicate annotation: {0} is annotated with an invalid @Repeatable annotation
379
380# 0: symbol or type
381compiler.err.invalid.repeatable.annotation.no.value=\
382    {0} is not a valid @Repeatable, no value element method declared
383
384# 0: type, 1: number
385compiler.err.invalid.repeatable.annotation.multiple.values=\
386    {0} is not a valid @Repeatable, {1} element methods named ''value'' declared
387
388# 0: type
389compiler.err.invalid.repeatable.annotation.invalid.value=\
390    {0} is not a valid @Repeatable: invalid value element
391
392# 0: symbol or type, 1: unused, 2: type
393compiler.err.invalid.repeatable.annotation.value.return=\
394    containing annotation type ({0}) must declare an element named ''value'' of type {2}
395
396# 0: symbol or type, 1: symbol
397compiler.err.invalid.repeatable.annotation.elem.nondefault=\
398    containing annotation type ({0}) does not have a default value for element {1}
399
400# 0: symbol, 1: unused, 2: symbol, 3: unused
401compiler.err.invalid.repeatable.annotation.retention=\
402    retention of containing annotation type ({0}) is shorter than the retention of repeatable annotation type ({2})
403
404# 0: symbol, 1: symbol
405compiler.err.invalid.repeatable.annotation.not.documented=\
406    repeatable annotation type ({1}) is @Documented while containing annotation type ({0}) is not
407
408# 0: symbol, 1: symbol
409compiler.err.invalid.repeatable.annotation.not.inherited=\
410    repeatable annotation type ({1}) is @Inherited while containing annotation type ({0}) is not
411
412# 0: symbol, 1: symbol
413compiler.err.invalid.repeatable.annotation.incompatible.target=\
414    containing annotation type ({0}) is applicable to more targets than repeatable annotation type ({1})
415
416# 0: symbol
417compiler.err.invalid.repeatable.annotation.repeated.and.container.present=\
418    container {0} must not be present at the same time as the element it contains
419
420# 0: type, 1: symbol
421compiler.err.invalid.repeatable.annotation.not.applicable=\
422    container {0} is not applicable to element {1}
423
424# 0: type
425compiler.err.invalid.repeatable.annotation.not.applicable.in.context=\
426    container {0} is not applicable in this type context
427
428# 0: name
429compiler.err.duplicate.class=\
430    duplicate class: {0}
431
432compiler.err.duplicate.case.label=\
433    duplicate case label
434
435compiler.err.duplicate.default.label=\
436    duplicate default label
437
438compiler.err.else.without.if=\
439    ''else'' without ''if''
440
441compiler.err.empty.char.lit=\
442    empty character literal
443
444# 0: symbol
445compiler.err.encl.class.required=\
446    an enclosing instance that contains {0} is required
447
448compiler.err.enum.annotation.must.be.enum.constant=\
449    an enum annotation value must be an enum constant
450
451compiler.err.enum.cant.be.instantiated=\
452    enum types may not be instantiated
453
454compiler.err.enum.label.must.be.unqualified.enum=\
455    an enum switch case label must be the unqualified name of an enumeration constant
456
457compiler.err.enum.no.subclassing=\
458    classes cannot directly extend java.lang.Enum
459
460compiler.err.enum.types.not.extensible=\
461    enum types are not extensible
462
463compiler.err.enum.no.finalize=\
464    enums cannot have finalize methods
465
466# 0: file name, 1: string
467compiler.err.error.reading.file=\
468    error reading {0}; {1}
469
470# 0: type
471compiler.err.except.already.caught=\
472    exception {0} has already been caught
473
474# 0: type
475compiler.err.except.never.thrown.in.try=\
476    exception {0} is never thrown in body of corresponding try statement
477
478# 0: symbol
479compiler.err.final.parameter.may.not.be.assigned=\
480    final parameter {0} may not be assigned
481
482# 0: symbol
483compiler.err.try.resource.may.not.be.assigned=\
484    auto-closeable resource {0} may not be assigned
485
486# 0: symbol
487compiler.err.multicatch.parameter.may.not.be.assigned=\
488    multi-catch parameter {0} may not be assigned
489
490# 0: type, 1: type
491compiler.err.multicatch.types.must.be.disjoint=\
492    Alternatives in a multi-catch statement cannot be related by subclassing\n\
493    Alternative {0} is a subclass of alternative {1}
494
495compiler.err.finally.without.try=\
496    ''finally'' without ''try''
497
498# 0: type, 1: message segment
499compiler.err.foreach.not.applicable.to.type=\
500    for-each not applicable to expression type\n\
501    required: {1}\n\
502    found:    {0}
503
504compiler.err.fp.number.too.large=\
505    floating point number too large
506
507compiler.err.fp.number.too.small=\
508    floating point number too small
509
510compiler.err.generic.array.creation=\
511    generic array creation
512
513compiler.err.generic.throwable=\
514    a generic class may not extend java.lang.Throwable
515
516# 0: symbol
517compiler.err.icls.cant.have.static.decl=\
518    Illegal static declaration in inner class {0}\n\
519    modifier \''static\'' is only allowed in constant variable declarations
520
521# 0: string
522compiler.err.illegal.char=\
523    illegal character: ''{0}''
524
525# 0: string, 1: string
526compiler.err.illegal.char.for.encoding=\
527    unmappable character (0x{0}) for encoding {1}
528
529# 0: set of modifier, 1: set of modifier
530compiler.err.illegal.combination.of.modifiers=\
531    illegal combination of modifiers: {0} and {1}
532
533compiler.err.illegal.enum.static.ref=\
534    illegal reference to static field from initializer
535
536compiler.err.illegal.esc.char=\
537    illegal escape character
538
539compiler.err.illegal.forward.ref=\
540    illegal forward reference
541
542# 0: symbol, 1: string
543compiler.err.not.in.profile=\
544    {0} is not available in profile ''{1}''
545
546# 0: symbol
547compiler.warn.forward.ref=\
548    reference to variable ''{0}'' before it has been initialized
549
550compiler.err.illegal.self.ref=\
551    self-reference in initializer
552
553# 0: symbol
554compiler.warn.self.ref=\
555    self-reference in initializer of variable ''{0}''
556
557compiler.err.illegal.generic.type.for.instof=\
558    illegal generic type for instanceof
559
560# 0: type
561compiler.err.illegal.initializer.for.type=\
562    illegal initializer for {0}
563
564compiler.err.illegal.line.end.in.char.lit=\
565    illegal line end in character literal
566
567compiler.err.illegal.nonascii.digit=\
568    illegal non-ASCII digit
569
570compiler.err.illegal.underscore=\
571    illegal underscore
572
573compiler.err.illegal.dot=\
574    illegal ''.''
575
576# 0: symbol
577compiler.err.illegal.qual.not.icls=\
578    illegal qualifier; {0} is not an inner class
579
580compiler.err.illegal.start.of.expr=\
581    illegal start of expression
582
583compiler.err.illegal.start.of.stmt=\
584    illegal start of statement
585
586compiler.err.illegal.start.of.type=\
587    illegal start of type
588
589compiler.err.illegal.unicode.esc=\
590    illegal unicode escape
591
592# 0: symbol
593compiler.err.import.requires.canonical=\
594    import requires canonical name for {0}
595
596compiler.err.improperly.formed.type.param.missing=\
597    improperly formed type, some parameters are missing
598
599compiler.err.improperly.formed.type.inner.raw.param=\
600    improperly formed type, type arguments given on a raw type
601
602# 0: type, 1: type
603compiler.err.incomparable.types=\
604    incomparable types: {0} and {1}
605
606# 0: number
607compiler.err.int.number.too.large=\
608    integer number too large: {0}
609
610compiler.err.intf.annotation.members.cant.have.params=\
611    elements in annotation type declarations cannot declare formal parameters
612
613# 0: symbol
614compiler.err.intf.annotation.cant.have.type.params=\
615    annotation type {0} cannot be generic
616
617compiler.err.intf.annotation.members.cant.have.type.params=\
618    elements in annotation type declarations cannot be generic methods
619
620# 0: symbol, 1: type
621compiler.err.intf.annotation.member.clash=\
622    annotation type {1} declares an element with the same name as method {0}
623
624compiler.err.intf.expected.here=\
625    interface expected here
626
627compiler.err.intf.meth.cant.have.body=\
628    interface abstract methods cannot have body
629
630# 0: symbol
631compiler.err.invalid.annotation.member.type=\
632    invalid type for element {0} of annotation type
633
634compiler.err.invalid.binary.number=\
635    binary numbers must contain at least one binary digit
636
637compiler.err.invalid.hex.number=\
638    hexadecimal numbers must contain at least one hexadecimal digit
639
640compiler.err.invalid.meth.decl.ret.type.req=\
641    invalid method declaration; return type required
642
643compiler.err.varargs.and.old.array.syntax=\
644    legacy array notation not allowed on variable-arity parameter
645
646compiler.err.varargs.and.receiver =\
647    varargs notation not allowed on receiver parameter
648
649compiler.err.varargs.must.be.last =\
650    varargs parameter must be the last parameter
651
652compiler.err.array.and.receiver =\
653    legacy array notation not allowed on receiver parameter
654
655compiler.err.variable.not.allowed=\
656    variable declaration not allowed here
657
658# 0: name
659compiler.err.label.already.in.use=\
660    label {0} already in use
661
662# 0: symbol
663compiler.err.local.var.accessed.from.icls.needs.final=\
664    local variable {0} is accessed from within inner class; needs to be declared final
665
666compiler.err.local.enum=\
667    enum types must not be local
668
669compiler.err.cannot.create.array.with.type.arguments=\
670    cannot create array with type arguments
671
672compiler.err.cannot.create.array.with.diamond=\
673    cannot create array with ''<>''
674
675compiler.err.invalid.module.directive=\
676  module directive keyword or ''}'' expected
677
678#
679# limits.  We don't give the limits in the diagnostic because we expect
680# them to change, yet we want to use the same diagnostic.  These are all
681# detected during code generation.
682#
683compiler.err.limit.code=\
684    code too large
685
686compiler.err.limit.code.too.large.for.try.stmt=\
687    code too large for try statement
688
689compiler.err.limit.dimensions=\
690    array type has too many dimensions
691
692compiler.err.limit.locals=\
693    too many local variables
694
695compiler.err.limit.parameters=\
696    too many parameters
697
698compiler.err.limit.pool=\
699    too many constants
700
701compiler.err.limit.pool.in.class=\
702    too many constants in class {0}
703
704compiler.err.limit.stack=\
705    code requires too much stack
706
707compiler.err.limit.string=\
708    constant string too long
709
710compiler.err.limit.string.overflow=\
711    UTF8 representation for string \"{0}...\" is too long for the constant pool
712
713compiler.err.malformed.fp.lit=\
714    malformed floating point literal
715
716compiler.err.method.does.not.override.superclass=\
717    method does not override or implement a method from a supertype
718
719compiler.err.missing.meth.body.or.decl.abstract=\
720    missing method body, or declare abstract
721
722compiler.err.missing.ret.stmt=\
723    missing return statement
724
725# 0: unused
726compiler.misc.missing.ret.val=\
727    missing return value
728
729compiler.misc.unexpected.ret.val=\
730    unexpected return value
731
732# 0: set of modifier
733compiler.err.mod.not.allowed.here=\
734    modifier {0} not allowed here
735
736compiler.err.intf.not.allowed.here=\
737    interface not allowed here
738
739compiler.err.enums.must.be.static=\
740    enum declarations allowed only in static contexts
741
742# 0: symbol, 1: symbol
743compiler.err.name.clash.same.erasure=\
744    name clash: {0} and {1} have the same erasure
745
746# 0: symbol, 1: symbol, 2: symbol, 3: symbol, 4: unused, 5: unused
747compiler.err.name.clash.same.erasure.no.override=\
748    name clash: {0} in {1} and {2} in {3} have the same erasure, yet neither overrides the other
749
750# 0: symbol, 1: symbol, 2: symbol, 3: symbol, 4: symbol, 5: symbol
751compiler.err.name.clash.same.erasure.no.override.1=\
752    name clash: {0} in {1} overrides a method whose erasure is the same as another method, yet neither overrides the other\n\
753    first method:  {2} in {3}\n\
754    second method: {4} in {5}
755
756# 0: symbol, 1: symbol, 2: symbol, 3: symbol
757compiler.err.name.clash.same.erasure.no.hide=\
758    name clash: {0} in {1} and {2} in {3} have the same erasure, yet neither hides the other
759
760compiler.err.name.reserved.for.internal.use=\
761    {0} is reserved for internal use
762
763compiler.err.native.meth.cant.have.body=\
764    native methods cannot have a body
765
766# 0: type, 1: type
767compiler.err.neither.conditional.subtype=\
768    incompatible types for ?: neither is a subtype of the other\n\
769    second operand: {0}\n\
770    third operand : {1}
771
772
773# 0: message segment
774compiler.misc.incompatible.type.in.conditional=\
775    bad type in conditional expression\n\
776    {0}
777
778compiler.misc.conditional.target.cant.be.void=\
779    target-type for conditional expression cannot be void
780
781# 0: type
782compiler.misc.incompatible.ret.type.in.lambda=\
783    bad return type in lambda expression\n\
784    {0}
785
786compiler.misc.stat.expr.expected=\
787    lambda body is not compatible with a void functional interface\n\
788    (consider using a block lambda body, or use a statement expression instead)
789
790# 0: type
791compiler.misc.incompatible.ret.type.in.mref=\
792    bad return type in method reference\n\
793    {0}
794
795compiler.err.lambda.body.neither.value.nor.void.compatible=\
796    lambda body is neither value nor void compatible
797
798# 0: list of type
799compiler.err.incompatible.thrown.types.in.mref=\
800    incompatible thrown types {0} in method reference
801
802compiler.misc.incompatible.arg.types.in.lambda=\
803    incompatible parameter types in lambda expression
804
805compiler.misc.incompatible.arg.types.in.mref=\
806    incompatible parameter types in method reference
807
808compiler.err.new.not.allowed.in.annotation=\
809    ''new'' not allowed in an annotation
810
811compiler.err.no.annotation.member=\
812    no annotation member {0} in {1}
813
814compiler.err.no.encl.instance.of.type.in.scope=\
815    no enclosing instance of type {0} is in scope
816
817compiler.err.no.intf.expected.here=\
818    no interface expected here
819
820compiler.err.no.match.entry=\
821    {0} has no match in entry in {1}; required {2}
822
823compiler.err.not.annotation.type=\
824    {0} is not an annotation type
825
826# 0: symbol, 1: symbol
827compiler.err.not.def.access.package.cant.access=\
828    {0} is not visible because package {1} is not visible
829
830# 0: symbol, 1: symbol
831compiler.err.not.def.access.class.intf.cant.access=\
832    {0} in {1} is defined in an inaccessible class or interface
833
834# 0: symbol, 1: symbol
835compiler.misc.not.def.access.class.intf.cant.access=\
836    {0} in {1} is defined in an inaccessible class or interface
837
838# 0: symbol, 1: list of type, 2: type
839compiler.misc.cant.access.inner.cls.constr=\
840    cannot access constructor {0}({1})\n\
841    an enclosing instance of type {2} is not in scope
842
843# 0: symbol, 1: symbol
844compiler.err.not.def.public.cant.access=\
845    {0} is not public in {1}; cannot be accessed from outside package
846
847# 0: symbol, 1: symbol
848compiler.misc.not.def.public.cant.access=\
849    {0} is not public in {1}; cannot be accessed from outside package
850
851# 0: name
852compiler.err.not.loop.label=\
853    not a loop label: {0}
854
855compiler.err.not.stmt=\
856    not a statement
857
858# 0: symbol
859compiler.err.not.encl.class=\
860    not an enclosing class: {0}
861
862# 0: name, 1: type
863compiler.err.operator.cant.be.applied=\
864    bad operand type {1} for unary operator ''{0}''
865
866# 0: name, 1: type, 2: type
867compiler.err.operator.cant.be.applied.1=\
868    bad operand types for binary operator ''{0}''\n\
869    first type:  {1}\n\
870    second type: {2}
871
872compiler.err.pkg.annotations.sb.in.package-info.java=\
873    package annotations should be in file package-info.java
874
875# 0: symbol
876compiler.err.pkg.clashes.with.class.of.same.name=\
877    package {0} clashes with class of same name
878
879compiler.err.warnings.and.werror=\
880    warnings found and -Werror specified
881
882# Errors related to annotation processing
883
884# 0: symbol, 1: string, 2: string (stack-trace)
885compiler.err.proc.cant.access=\
886    cannot access {0}\n\
887    {1}\n\
888    Consult the following stack trace for details.\n\
889    {2}
890
891# 0: symbol, 1: string
892compiler.err.proc.cant.access.1=\
893    cannot access {0}\n\
894    {1}
895
896# 0: string
897compiler.err.proc.cant.find.class=\
898    Could not find class file for ''{0}''.
899
900# Print a client-generated error message; assumed to be localized, no translation required
901# 0: string
902compiler.err.proc.messager=\
903    {0}
904
905# 0: list of string
906compiler.err.proc.no.explicit.annotation.processing.requested=\
907    Class names, ''{0}'', are only accepted if annotation processing is explicitly requested
908
909compiler.err.proc.no.service=\
910    A ServiceLoader was not usable and is required for annotation processing.
911
912compiler.err.proc.processor.bad.option.name=\
913    Bad option name ''{0}'' provided by processor ''{1}''
914
915# 0: string
916compiler.err.proc.processor.cant.instantiate=\
917    Could not instantiate an instance of processor ''{0}''
918
919# 0: string
920compiler.err.proc.processor.not.found=\
921    Annotation processor ''{0}'' not found
922
923# 0: string
924compiler.err.proc.processor.wrong.type=\
925    Annotation processor ''{0}'' does not implement javax.annotation.processing.Processor
926
927compiler.err.proc.service.problem=\
928    Error creating a service loader to load Processors.
929
930compiler.err.proc.bad.config.file=\
931    Bad service configuration file, or exception thrown while constructing Processor object: {0}
932
933compiler.err.proc.cant.create.loader=\
934    Could not create class loader for annotation processors: {0}
935
936# 0: unused
937compiler.err.qualified.new.of.static.class=\
938    qualified new of static class
939
940compiler.err.recursive.ctor.invocation=\
941    recursive constructor invocation
942
943# 0: name, 1: symbol kind, 2: symbol, 3: symbol, 4: symbol kind, 5: symbol, 6: symbol
944compiler.err.ref.ambiguous=\
945    reference to {0} is ambiguous\n\
946    both {1} {2} in {3} and {4} {5} in {6} match
947
948# 0: name, 1: symbol kind, 2: symbol, 3: symbol, 4: symbol kind, 5: symbol, 6: symbol
949compiler.misc.ref.ambiguous=\
950    reference to {0} is ambiguous\n\
951    both {1} {2} in {3} and {4} {5} in {6} match
952
953compiler.err.repeated.annotation.target=\
954    repeated annotation target
955
956compiler.err.repeated.interface=\
957    repeated interface
958
959compiler.err.repeated.modifier=\
960    repeated modifier
961
962# 0: symbol, 1: set of modifier, 2: symbol
963compiler.err.report.access=\
964    {0} has {1} access in {2}
965
966# 0: symbol, 1: set of modifier, 2: symbol
967compiler.misc.report.access=\
968    {0} has {1} access in {2}
969
970compiler.err.ret.outside.meth=\
971    return outside method
972
973compiler.err.signature.doesnt.match.supertype=\
974    signature does not match {0}; incompatible supertype
975
976compiler.err.signature.doesnt.match.intf=\
977    signature does not match {0}; incompatible interfaces
978
979# 0: number, 1: number
980compiler.err.method.invoked.with.incorrect.number.arguments=\
981    method invoked with incorrect number of arguments; expected {0}, found {1}
982
983# 0: symbol, 1: symbol, 2: symbol
984compiler.err.does.not.override.abstract=\
985    {0} is not abstract and does not override abstract method {1} in {2}
986
987compiler.err.source.cant.overwrite.input.file=\
988    error writing source; cannot overwrite input file {0}
989
990compiler.err.stack.sim.error=\
991    Internal error: stack sim error on {0}
992
993compiler.err.static.imp.only.classes.and.interfaces=\
994    static import only from classes and interfaces
995
996compiler.err.string.const.req=\
997    constant string expression required
998
999# 0: symbol, 1: symbol
1000compiler.err.synthetic.name.conflict=\
1001    the symbol {0} conflicts with a compiler-synthesized symbol in {1}
1002
1003compiler.err.throws.not.allowed.in.intf.annotation=\
1004    throws clause not allowed in @interface members
1005
1006compiler.err.try.without.catch.or.finally=\
1007    ''try'' without ''catch'' or ''finally''
1008
1009compiler.err.try.without.catch.finally.or.resource.decls=\
1010    ''try'' without ''catch'', ''finally'' or resource declarations
1011
1012# 0: symbol
1013compiler.err.type.doesnt.take.params=\
1014    type {0} does not take parameters
1015
1016compiler.err.type.var.cant.be.deref=\
1017    cannot select from a type variable
1018
1019compiler.err.type.var.may.not.be.followed.by.other.bounds=\
1020    a type variable may not be followed by other bounds
1021
1022compiler.err.type.var.more.than.once=\
1023    type variable {0} occurs more than once in result type of {1}; cannot be left uninstantiated
1024
1025compiler.err.type.var.more.than.once.in.result=\
1026    type variable {0} occurs more than once in type of {1}; cannot be left uninstantiated
1027
1028# 0: type, 1: type, 2: string
1029compiler.err.types.incompatible.diff.ret=\
1030    types {0} and {1} are incompatible; both define {2}, but with unrelated return types
1031
1032# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
1033compiler.err.types.incompatible.unrelated.defaults=\
1034    {0} {1} inherits unrelated defaults for {2}({3}) from types {4} and {5}
1035
1036# 0: kind name, 1: type, 2: name, 3: list of type, 4: symbol, 5: symbol
1037compiler.err.types.incompatible.abstract.default=\
1038    {0} {1} inherits abstract and default for {2}({3}) from types {4} and {5}
1039
1040# 0: name, 1: kind name, 2: symbol
1041compiler.err.default.overrides.object.member=\
1042    default method {0} in {1} {2} overrides a member of java.lang.Object
1043
1044# 0: type
1045compiler.err.illegal.static.intf.meth.call=\
1046    illegal static interface method call\n\
1047    the receiver expression should be replaced with the type qualifier ''{0}''
1048
1049# 0: type, 1: message segment
1050compiler.err.illegal.default.super.call=\
1051    bad type qualifier {0} in default super call\n\
1052    {1}
1053
1054# 0: symbol, 1: type
1055compiler.misc.overridden.default=\
1056    method {0} is overridden in {1}
1057
1058# 0: symbol, 1: type or symbol
1059compiler.misc.redundant.supertype=\
1060    redundant interface {0} is extended by {1}
1061
1062compiler.err.unclosed.char.lit=\
1063    unclosed character literal
1064
1065compiler.err.unclosed.comment=\
1066    unclosed comment
1067
1068compiler.err.unclosed.str.lit=\
1069    unclosed string literal
1070
1071# 0: name
1072compiler.err.unsupported.encoding=\
1073    unsupported encoding: {0}
1074
1075compiler.err.io.exception=\
1076    error reading source file: {0}
1077
1078# 0: name
1079compiler.err.undef.label=\
1080    undefined label: {0}
1081
1082# 0: message segment, 1: unused
1083compiler.err.cant.apply.diamond=\
1084    cannot infer type arguments for {0}
1085
1086# 0: message segment or type, 1: message segment
1087compiler.err.cant.apply.diamond.1=\
1088    cannot infer type arguments for {0}\n\
1089    reason: {1}
1090
1091# 0: message segment or type, 1: message segment
1092compiler.misc.cant.apply.diamond.1=\
1093    cannot infer type arguments for {0}\n\
1094    reason: {1}
1095
1096compiler.err.unreachable.stmt=\
1097    unreachable statement
1098
1099compiler.err.initializer.must.be.able.to.complete.normally=\
1100    initializer must be able to complete normally
1101
1102compiler.err.initializer.not.allowed=\
1103    initializers not allowed in interfaces
1104
1105# 0: type
1106compiler.err.unreported.exception.need.to.catch.or.throw=\
1107    unreported exception {0}; must be caught or declared to be thrown
1108
1109# 0: type
1110compiler.err.unreported.exception.default.constructor=\
1111    unreported exception {0} in default constructor
1112
1113# 0: type, 1: name
1114compiler.err.unreported.exception.implicit.close=\
1115    unreported exception {0}; must be caught or declared to be thrown\n\
1116    exception thrown from implicit call to close() on resource variable ''{1}''
1117
1118compiler.err.unsupported.cross.fp.lit=\
1119    hexadecimal floating-point literals are not supported on this VM
1120
1121compiler.err.void.not.allowed.here=\
1122    ''void'' type not allowed here
1123
1124# 0: string
1125compiler.err.wrong.number.type.args=\
1126    wrong number of type arguments; required {0}
1127
1128# 0: symbol
1129compiler.err.var.might.already.be.assigned=\
1130    variable {0} might already have been assigned
1131
1132# 0: symbol
1133compiler.err.var.might.not.have.been.initialized=\
1134    variable {0} might not have been initialized
1135
1136# 0: symbol
1137compiler.err.var.not.initialized.in.default.constructor=\
1138    variable {0} not initialized in the default constructor
1139
1140# 0: symbol
1141compiler.err.var.might.be.assigned.in.loop=\
1142    variable {0} might be assigned in loop
1143
1144# 0: symbol, 1: message segment
1145compiler.err.varargs.invalid.trustme.anno=\
1146    Invalid {0} annotation. {1}
1147
1148# 0: type
1149compiler.misc.varargs.trustme.on.reifiable.varargs=\
1150    Varargs element type {0} is reifiable.
1151
1152# 0: symbol
1153compiler.misc.varargs.trustme.on.non.varargs.meth=\
1154    Method {0} is not a varargs method.
1155
1156# 0: symbol
1157compiler.misc.varargs.trustme.on.virtual.varargs=\
1158    Instance method {0} is neither final nor private.
1159
1160# 0: symbol
1161compiler.misc.varargs.trustme.on.virtual.varargs.final.only=\
1162    Instance method {0} is not final.
1163
1164# 0: type, 1: symbol kind, 2: symbol
1165compiler.misc.inaccessible.varargs.type=\
1166    formal varargs element type {0} is not accessible from {1} {2}
1167
1168# In the following string, {1} will always be the detail message from
1169# java.io.IOException.
1170# 0: symbol, 1: string
1171compiler.err.class.cant.write=\
1172    error while writing {0}: {1}
1173
1174# In the following string, {0} is the name of the class in the Java source.
1175# It really should be used two times..
1176# 0: name
1177compiler.err.class.public.should.be.in.file=\
1178    class {0} is public, should be declared in a file named {0}.java
1179
1180## All errors which do not refer to a particular line in the source code are
1181## preceded by this string.
1182compiler.err.error=\
1183    error:\u0020
1184
1185# The following error messages do not refer to a line in the source code.
1186compiler.err.cant.read.file=\
1187    cannot read: {0}
1188
1189# 0: string
1190compiler.err.plugin.not.found=\
1191    plug-in not found: {0}
1192
1193# 0: path
1194compiler.warn.locn.unknown.file.on.module.path=\
1195    unknown file on module path: {0}
1196
1197
1198# 0: path
1199compiler.err.locn.bad.module-info=\
1200    problem reading module-info.class in {0}
1201
1202# 0: path
1203compiler.err.locn.cant.read.directory=\
1204    cannot read directory {0}
1205
1206# 0: path
1207compiler.err.locn.cant.read.file=\
1208    cannot read file {0}
1209
1210# 0: path
1211compiler.err.locn.cant.get.module.name.for.jar=\
1212    cannot determine module name for {0}
1213
1214# 0: path
1215compiler.err.multi-module.outdir.cannot.be.exploded.module=\
1216    in multi-module mode, the output directory cannot be an exploded module: {0}
1217
1218# 0: path
1219compiler.warn.outdir.is.in.exploded.module=\
1220    the output directory is within an exploded module: {0}
1221
1222# 0: path
1223compiler.err.locn.module-info.not.allowed.on.patch.path=\
1224    module-info.class not allowed on patch path: {0}
1225
1226# 0: string
1227compiler.err.locn.invalid.arg.for.xpatch=\
1228    invalid argument for --patch-module option: {0}
1229
1230#####
1231
1232# Fatal Errors
1233
1234compiler.misc.fatal.err.no.java.lang=\
1235    Fatal Error: Unable to find package java.lang in classpath or bootclasspath
1236
1237compiler.misc.fatal.err.cant.locate.meth=\
1238    Fatal Error: Unable to find method {0}
1239
1240compiler.misc.fatal.err.cant.locate.field=\
1241    Fatal Error: Unable to find field {0}
1242
1243compiler.misc.fatal.err.cant.locate.ctor=\
1244    Fatal Error: Unable to find constructor for {0}
1245
1246compiler.misc.fatal.err.cant.close=\
1247    Fatal Error: Cannot close compiler resources
1248
1249#####
1250
1251##
1252## miscellaneous strings
1253##
1254
1255compiler.misc.diamond.anonymous.methods.implicitly.override=\
1256    (due to <>, every non-private method declared in this anonymous class must override or implement a method from a supertype)
1257
1258compiler.misc.source.unavailable=\
1259    (source unavailable)
1260
1261compiler.misc.base.membership=\
1262    all your base class are belong to us
1263
1264# 0: string, 1: string, 2: boolean
1265compiler.misc.x.print.processor.info=\
1266    Processor {0} matches {1} and returns {2}.
1267
1268# 0: number, 1: string, 2: set of symbol, 3: boolean
1269compiler.misc.x.print.rounds=\
1270    Round {0}:\n\tinput files: {1}\n\tannotations: {2}\n\tlast round: {3}
1271
1272# 0: file name
1273compiler.warn.file.from.future=\
1274    Modification date is in the future for file {0}
1275
1276#####
1277
1278## The following string will appear before all messages keyed as:
1279## "compiler.note".
1280
1281compiler.note.compressed.diags=\
1282    Some messages have been simplified; recompile with -Xdiags:verbose to get full output
1283
1284# 0: boolean, 1: symbol
1285compiler.note.lambda.stat=\
1286    Translating lambda expression\n\
1287    alternate metafactory = {0}\n\
1288    synthetic method = {1}
1289
1290# 0: boolean, 1: unused
1291compiler.note.mref.stat=\
1292    Translating method reference\n\
1293    alternate metafactory = {0}\n\
1294
1295# 0: boolean, 1: symbol
1296compiler.note.mref.stat.1=\
1297    Translating method reference\n\
1298    alternate metafactory = {0}\n\
1299    bridge method = {1}
1300
1301compiler.note.note=\
1302    Note:\u0020
1303
1304# 0: file name
1305compiler.note.deprecated.filename=\
1306    {0} uses or overrides a deprecated API.
1307
1308compiler.note.deprecated.plural=\
1309    Some input files use or override a deprecated API.
1310
1311# The following string may appear after one of the above deprecation
1312# messages.
1313compiler.note.deprecated.recompile=\
1314    Recompile with -Xlint:deprecation for details.
1315
1316# 0: file name
1317compiler.note.deprecated.filename.additional=\
1318    {0} has additional uses or overrides of a deprecated API.
1319
1320compiler.note.deprecated.plural.additional=\
1321    Some input files additionally use or override a deprecated API.
1322
1323# 0: file name
1324compiler.note.unchecked.filename=\
1325    {0} uses unchecked or unsafe operations.
1326
1327compiler.note.unchecked.plural=\
1328    Some input files use unchecked or unsafe operations.
1329
1330# The following string may appear after one of the above deprecation
1331# messages.
1332compiler.note.unchecked.recompile=\
1333    Recompile with -Xlint:unchecked for details.
1334
1335# 0: file name
1336compiler.note.unchecked.filename.additional=\
1337    {0} has additional unchecked or unsafe operations.
1338
1339compiler.note.unchecked.plural.additional=\
1340    Some input files additionally use unchecked or unsafe operations.
1341
1342# Notes related to annotation processing
1343
1344# Print a client-generated note; assumed to be localized, no translation required
1345# 0: string
1346compiler.note.proc.messager=\
1347    {0}
1348
1349#####
1350
1351# 0: number
1352compiler.misc.count.error=\
1353    {0} error
1354
1355# 0: number
1356compiler.misc.count.error.plural=\
1357    {0} errors
1358
1359# 0: number
1360compiler.misc.count.warn=\
1361    {0} warning
1362
1363# 0: number
1364compiler.misc.count.warn.plural=\
1365    {0} warnings
1366
1367compiler.misc.version.not.available=\
1368    (version info not available)
1369
1370## extra output when using -verbose (JavaCompiler)
1371
1372# 0: symbol
1373compiler.misc.verbose.checking.attribution=\
1374    [checking {0}]
1375
1376# 0: string
1377compiler.misc.verbose.parsing.done=\
1378    [parsing completed {0}ms]
1379
1380# 0: file name
1381compiler.misc.verbose.parsing.started=\
1382    [parsing started {0}]
1383
1384# 0: string
1385compiler.misc.verbose.total=\
1386    [total {0}ms]
1387
1388# 0: file name
1389compiler.misc.verbose.wrote.file=\
1390    [wrote {0}]
1391
1392## extra output when using -verbose (code/ClassReader)
1393# 0: string
1394compiler.misc.verbose.loading=\
1395    [loading {0}]
1396
1397# 0: string
1398compiler.misc.verbose.sourcepath=\
1399    [search path for source files: {0}]
1400
1401# 0: string
1402compiler.misc.verbose.classpath=\
1403    [search path for class files: {0}]
1404
1405## extra output when using -prompt (util/Log)
1406compiler.misc.resume.abort=\
1407    R)esume, A)bort>
1408
1409#####
1410
1411##
1412## warnings
1413##
1414
1415## All warning messages are preceded by the following string.
1416compiler.warn.warning=\
1417    warning:\u0020
1418
1419## Warning messages may also include the following prefix to identify a
1420## lint option
1421# 0: option name
1422compiler.warn.lintOption=\
1423    [{0}]\u0020
1424
1425# 0: symbol
1426compiler.warn.constant.SVUID=\
1427    serialVersionUID must be constant in class {0}
1428
1429# 0: file name
1430compiler.warn.dir.path.element.not.found=\
1431    bad path element "{0}": no such directory
1432
1433# 0: file name
1434compiler.warn.dir.path.element.not.directory=\
1435    bad path element "{0}": not a directory
1436
1437compiler.warn.finally.cannot.complete=\
1438    finally clause cannot complete normally
1439
1440# 0: symbol, 1: symbol
1441compiler.warn.has.been.deprecated=\
1442    {0} in {1} has been deprecated
1443
1444# 0: symbol
1445compiler.warn.sun.proprietary=\
1446    {0} is internal proprietary API and may be removed in a future release
1447
1448compiler.warn.illegal.char.for.encoding=\
1449    unmappable character for encoding {0}
1450
1451# 0: symbol
1452compiler.warn.improper.SVUID=\
1453    serialVersionUID must be declared static final in class {0}
1454
1455# 0: type, 1: type
1456compiler.warn.inexact.non-varargs.call=\
1457    non-varargs call of varargs method with inexact argument type for last parameter;\n\
1458    cast to {0} for a varargs call\n\
1459    cast to {1} for a non-varargs call and to suppress this warning
1460
1461# 0: list of type
1462compiler.warn.unreachable.catch=\
1463    unreachable catch clause\n\
1464    thrown type {0} has already been caught
1465
1466# 0: list of type
1467compiler.warn.unreachable.catch.1=\
1468    unreachable catch clause\n\
1469    thrown types {0} have already been caught
1470
1471# 0: symbol
1472compiler.warn.long.SVUID=\
1473    serialVersionUID must be of type long in class {0}
1474
1475# 0: symbol
1476compiler.warn.missing.SVUID=\
1477    serializable class {0} has no definition of serialVersionUID
1478
1479# 0: symbol, 1: symbol, 2: symbol, 3: symbol
1480compiler.warn.potentially.ambiguous.overload=\
1481    {0} in {1} is potentially ambiguous with {2} in {3}
1482
1483# 0: message segment
1484compiler.warn.override.varargs.missing=\
1485    {0}; overridden method has no ''...''
1486
1487# 0: message segment
1488compiler.warn.override.varargs.extra=\
1489    {0}; overriding method is missing ''...''
1490
1491compiler.warn.override.bridge=\
1492    {0}; overridden method is a bridge method
1493
1494# 0: symbol
1495compiler.warn.pkg-info.already.seen=\
1496    a package-info.java file has already been seen for package {0}
1497
1498# 0: file name
1499compiler.warn.path.element.not.found=\
1500    bad path element "{0}": no such file or directory
1501
1502compiler.warn.possible.fall-through.into.case=\
1503    possible fall-through into case
1504
1505# 0: type
1506compiler.warn.redundant.cast=\
1507    redundant cast to {0}
1508
1509# 0: number
1510compiler.warn.position.overflow=\
1511    Position encoding overflows at line {0}
1512
1513# 0: file name, 1: number, 2: number
1514compiler.warn.big.major.version=\
1515    {0}: major version {1} is newer than {2}, the highest major version supported by this compiler.\n\
1516    It is recommended that the compiler be upgraded.
1517
1518# 0: symbol kind, 1: symbol
1519compiler.warn.static.not.qualified.by.type=\
1520    static {0} should be qualified by type name, {1}, instead of by an expression
1521
1522# 0: string
1523compiler.warn.source.no.bootclasspath=\
1524    bootstrap class path not set in conjunction with -source {0}
1525
1526# 0: string
1527compiler.warn.option.obsolete.source=\
1528    source value {0} is obsolete and will be removed in a future release
1529
1530# 0: string
1531compiler.warn.option.obsolete.target=\
1532    target value {0} is obsolete and will be removed in a future release
1533
1534# 0: string, 1: string
1535compiler.err.option.removed.source=\
1536    Source option {0} is no longer supported. Use {1} or later.
1537
1538# 0: string, 1: string
1539compiler.err.option.removed.target=\
1540    Target option {0} is no longer supported. Use {1} or later.
1541
1542compiler.warn.option.obsolete.suppression=\
1543    To suppress warnings about obsolete options, use -Xlint:-options.
1544
1545# 0: name, 1: number, 2: number, 3: number, 4: number
1546compiler.warn.future.attr=\
1547    {0} attribute introduced in version {1}.{2} class files is ignored in version {3}.{4} class files
1548
1549# Warnings related to annotation processing
1550# 0: string
1551compiler.warn.proc.package.does.not.exist=\
1552    package {0} does not exist
1553
1554# 0: name
1555compiler.warn.proc.file.reopening=\
1556    Attempt to create a file for ''{0}'' multiple times
1557
1558# 0: name
1559compiler.warn.proc.type.already.exists=\
1560    A file for type ''{0}'' already exists on the sourcepath or classpath
1561
1562# 0: name
1563compiler.warn.proc.type.recreate=\
1564    Attempt to create a file for type ''{0}'' multiple times
1565
1566# 0: string
1567compiler.warn.proc.illegal.file.name=\
1568    Cannot create file for illegal name ''{0}''.
1569
1570# 0: string, 1: string
1571compiler.warn.proc.suspicious.class.name=\
1572    Creating file for a type whose name ends in {1}: ''{0}''
1573
1574# 0: name
1575compiler.warn.proc.file.create.last.round=\
1576    File for type ''{0}'' created in the last round will not be subject to annotation processing.
1577
1578# 0: string, 1: string
1579compiler.warn.proc.malformed.supported.string=\
1580    Malformed string ''{0}'' for a supported annotation type returned by processor ''{1}''
1581
1582# 0: set of string
1583compiler.warn.proc.annotations.without.processors=\
1584    No processor claimed any of these annotations: {0}
1585
1586# 0: source version, 1: string, 2: string
1587compiler.warn.proc.processor.incompatible.source.version=\
1588    Supported source version ''{0}'' from annotation processor ''{1}'' less than -source ''{2}''
1589
1590compiler.warn.proc.proc-only.requested.no.procs=\
1591    Annotation processing without compilation requested but no processors were found.
1592
1593compiler.warn.proc.use.implicit=\
1594    Implicitly compiled files were not subject to annotation processing.\n\
1595    Use -implicit to specify a policy for implicit compilation.
1596
1597compiler.warn.proc.use.proc.or.implicit=\
1598    Implicitly compiled files were not subject to annotation processing.\n\
1599    Use -proc:none to disable annotation processing or -implicit to specify a policy for implicit compilation.
1600
1601# Print a client-generated warning; assumed to be localized, no translation required
1602# 0: string
1603compiler.warn.proc.messager=\
1604    {0}
1605
1606# 0: set of name
1607compiler.warn.proc.unclosed.type.files=\
1608    Unclosed files for the types ''{0}''; these types will not undergo annotation processing
1609
1610# 0: string
1611compiler.warn.proc.unmatched.processor.options=\
1612    The following options were not recognized by any processor: ''{0}''
1613
1614compiler.warn.try.explicit.close.call=\
1615    explicit call to close() on an auto-closeable resource
1616
1617# 0: symbol
1618compiler.warn.try.resource.not.referenced=\
1619    auto-closeable resource {0} is never referenced in body of corresponding try statement
1620
1621# 0: type
1622compiler.warn.try.resource.throws.interrupted.exc=\
1623    auto-closeable resource {0} has a member method close() that could throw InterruptedException
1624
1625compiler.warn.unchecked.assign=\
1626    unchecked assignment: {0} to {1}
1627
1628# 0: symbol, 1: type
1629compiler.warn.unchecked.assign.to.var=\
1630    unchecked assignment to variable {0} as member of raw type {1}
1631
1632# 0: symbol, 1: type
1633compiler.warn.unchecked.call.mbr.of.raw.type=\
1634    unchecked call to {0} as a member of the raw type {1}
1635
1636compiler.warn.unchecked.cast.to.type=\
1637    unchecked cast to type {0}
1638
1639# 0: symbol kind, 1: name, 2: list of type, 3: list of type, 4: symbol kind, 5: symbol
1640compiler.warn.unchecked.meth.invocation.applied=\
1641    unchecked method invocation: {0} {1} in {4} {5} is applied to given types\n\
1642    required: {2}\n\
1643    found: {3}
1644
1645# 0: type
1646compiler.warn.unchecked.generic.array.creation=\
1647    unchecked generic array creation for varargs parameter of type {0}
1648
1649# 0: type
1650compiler.warn.unchecked.varargs.non.reifiable.type=\
1651    Possible heap pollution from parameterized vararg type {0}
1652
1653# 0: symbol
1654compiler.warn.varargs.unsafe.use.varargs.param=\
1655    Varargs method could cause heap pollution from non-reifiable varargs parameter {0}
1656
1657compiler.warn.missing.deprecated.annotation=\
1658    deprecated item is not annotated with @Deprecated
1659
1660# 0: symbol kind
1661compiler.warn.deprecated.annotation.has.no.effect=\
1662    @Deprecated annotation has no effect on this {0} declaration
1663
1664compiler.warn.invalid.archive.file=\
1665    Unexpected file on path: {0}
1666
1667compiler.warn.unexpected.archive.file=\
1668    Unexpected extension for archive file: {0}
1669
1670compiler.warn.div.zero=\
1671    division by zero
1672
1673compiler.warn.empty.if=\
1674    empty statement after if
1675
1676compiler.warn.annotation.method.not.found=\
1677    Cannot find annotation method ''{1}()'' in type ''{0}''
1678
1679compiler.warn.annotation.method.not.found.reason=\
1680    Cannot find annotation method ''{1}()'' in type ''{0}'': {2}
1681
1682# 0: symbol, 1: name
1683compiler.warn.unknown.enum.constant=\
1684    unknown enum constant {1}.{2}
1685
1686# 0: symbol, 1: name, 2: message segment
1687compiler.warn.unknown.enum.constant.reason=\
1688    unknown enum constant {1}.{2}\n\
1689    reason: {3}
1690
1691# 0: type, 1: type
1692compiler.warn.raw.class.use=\
1693    found raw type: {0}\n\
1694    missing type arguments for generic class {1}
1695
1696# 0: unused, 1: unused
1697compiler.warn.diamond.redundant.args=\
1698    Redundant type arguments in new expression (use diamond operator instead).
1699
1700compiler.warn.potential.lambda.found=\
1701    This anonymous inner class creation can be turned into a lambda expression.
1702
1703compiler.warn.method.redundant.typeargs=\
1704    Redundant type arguments in method call.
1705
1706# 0: symbol, 1: message segment
1707compiler.warn.varargs.redundant.trustme.anno=\
1708    Redundant {0} annotation. {1}
1709
1710# 0: symbol
1711compiler.warn.access.to.sensitive.member.from.serializable.element=\
1712    access to sensitive member {0} from serializable element can be publicly accessible to untrusted code
1713
1714#####
1715
1716## The following are tokens which are non-terminals in the language. They should
1717## be named as JLS3 calls them when translated to the appropriate language.
1718compiler.misc.token.identifier=\
1719    <identifier>
1720
1721compiler.misc.token.character=\
1722    <character>
1723
1724compiler.misc.token.string=\
1725    <string>
1726
1727compiler.misc.token.integer=\
1728    <integer>
1729
1730compiler.misc.token.long-integer=\
1731    <long integer>
1732
1733compiler.misc.token.float=\
1734    <float>
1735
1736compiler.misc.token.double=\
1737    <double>
1738
1739compiler.misc.token.bad-symbol=\
1740    <bad symbol>
1741
1742compiler.misc.token.end-of-input=\
1743    <end of input>
1744
1745## The argument to the following string will always be one of the following:
1746## 1. one of the above non-terminals
1747## 2. a keyword (JLS1.8)
1748## 3. a boolean literal (JLS3.10.3)
1749## 4. the null literal (JLS3.10.7)
1750## 5. a Java separator (JLS3.11)
1751## 6. an operator (JLS3.12)
1752##
1753## This is the only place these tokens will be used.
1754# 0: token
1755compiler.err.expected=\
1756    {0} expected
1757
1758# 0: token, 1: token
1759compiler.err.expected2=\
1760    {0} or {1} expected
1761
1762# 0: token, 1: token, 2: token
1763compiler.err.expected3=\
1764    {0}, {1}, or {2} expected
1765
1766compiler.err.premature.eof=\
1767    reached end of file while parsing
1768
1769## The following are related in form, but do not easily fit the above paradigm.
1770compiler.err.dot.class.expected=\
1771    ''.class'' expected
1772
1773## The argument to this string will always be either 'case' or 'default'.
1774# 0: token
1775compiler.err.orphaned=\
1776    orphaned {0}
1777
1778# 0: name
1779compiler.misc.anonymous.class=\
1780    <anonymous {0}>
1781
1782# 0: name, 1: type
1783compiler.misc.type.captureof=\
1784    capture#{0} of {1}
1785
1786compiler.misc.type.captureof.1=\
1787    capture#{0}
1788
1789compiler.misc.type.none=\
1790    <none>
1791
1792compiler.misc.unnamed.package=\
1793    unnamed package
1794
1795compiler.misc.unnamed.module=\
1796    unnamed module
1797
1798#####
1799
1800# 0: symbol, 1: message segment
1801compiler.err.cant.access=\
1802    cannot access {0}\n\
1803    {1}
1804
1805# 0: name
1806compiler.misc.bad.class.file=\
1807    class file is invalid for class {0}
1808
1809# 0: file name, 1: string (expected constant pool entry type), 2: number (constant pool index)
1810compiler.misc.bad.const.pool.entry=\
1811    bad constant pool entry in {0}\n\
1812    expected {1} at index {2}
1813
1814# 0: file name, 1: message segment
1815compiler.misc.bad.class.file.header=\
1816    bad class file: {0}\n\
1817    {1}\n\
1818    Please remove or make sure it appears in the correct subdirectory of the classpath.
1819
1820# 0: file name, 1: message segment
1821compiler.misc.bad.source.file.header=\
1822    bad source file: {0}\n\
1823    {1}\n\
1824    Please remove or make sure it appears in the correct subdirectory of the sourcepath.
1825
1826## The following are all possible strings for the second argument ({1}) of the
1827## above strings.
1828compiler.misc.bad.class.signature=\
1829    bad class signature: {0}
1830
1831#0: symbol, 1: symbol
1832compiler.misc.bad.enclosing.class=\
1833    bad enclosing class for {0}: {1}
1834
1835# 0: symbol
1836compiler.misc.bad.enclosing.method=\
1837    bad enclosing method attribute for class {0}
1838
1839compiler.misc.bad.runtime.invisible.param.annotations=\
1840    bad RuntimeInvisibleParameterAnnotations attribute: {0}
1841
1842compiler.misc.bad.const.pool.tag=\
1843    bad constant pool tag: {0}
1844
1845compiler.misc.bad.const.pool.tag.at=\
1846    bad constant pool tag: {0} at {1}
1847
1848compiler.misc.bad.signature=\
1849    bad signature: {0}
1850
1851compiler.misc.bad.type.annotation.value=\
1852    bad type annotation target type value: {0}
1853
1854compiler.misc.bad.module-info.name=\
1855    bad class name
1856
1857compiler.misc.class.file.wrong.class=\
1858    class file contains wrong class: {0}
1859
1860compiler.misc.module.info.invalid.super.class=\
1861    module-info with invalid super class
1862
1863compiler.misc.class.file.not.found=\
1864    class file for {0} not found
1865
1866# 0: string (classfile major version), 1: string (classfile minor version)
1867compiler.misc.invalid.default.interface=\
1868    default method found in version {0}.{1} classfile
1869
1870# 0: string (classfile major version), 1: string (classfile minor version)
1871compiler.misc.invalid.static.interface=\
1872    static method found in version {0}.{1} classfile
1873
1874# 0: string (classfile major version), 1: string (classfile minor version)
1875compiler.misc.anachronistic.module.info=\
1876    module declaration found in version {0}.{1} classfile
1877
1878# 0: name
1879compiler.misc.file.doesnt.contain.class=\
1880    file does not contain class {0}
1881
1882compiler.misc.file.does.not.contain.package=\
1883    file does not contain package {0}
1884
1885compiler.misc.file.does.not.contain.module=\
1886    file does not contain module declaration
1887
1888compiler.misc.illegal.start.of.class.file=\
1889    illegal start of class file
1890
1891compiler.misc.unable.to.access.file=\
1892    unable to access file: {0}
1893
1894compiler.misc.unicode.str.not.supported=\
1895    unicode string in class file not supported
1896
1897compiler.misc.undecl.type.var=\
1898    undeclared type variable: {0}
1899
1900compiler.misc.malformed.vararg.method=\
1901    class file contains malformed variable arity method: {0}
1902
1903compiler.misc.wrong.version=\
1904    class file has wrong version {0}.{1}, should be {2}.{3}
1905
1906#####
1907
1908# 0: type, 1: type or symbol
1909compiler.err.not.within.bounds=\
1910    type argument {0} is not within bounds of type-variable {1}
1911
1912## The following are all possible strings for the second argument ({1}) of the
1913## above string.
1914
1915## none yet...
1916
1917#####
1918
1919# 0: message segment
1920compiler.err.prob.found.req=\
1921    incompatible types: {0}
1922
1923# 0: message segment
1924compiler.misc.prob.found.req=\
1925    incompatible types: {0}
1926
1927# 0: message segment, 1: type, 2: type
1928compiler.warn.prob.found.req=\
1929    {0}\n\
1930    required: {2}\n\
1931    found:    {1}
1932
1933# 0: type, 1: type
1934compiler.misc.inconvertible.types=\
1935    {0} cannot be converted to {1}
1936
1937# 0: type, 1: type
1938compiler.misc.possible.loss.of.precision=\
1939    possible lossy conversion from {0} to {1}
1940
1941compiler.misc.unchecked.assign=\
1942    unchecked conversion
1943
1944# compiler.misc.storecheck=\
1945#     assignment might cause later store checks to fail
1946# compiler.misc.unchecked=\
1947#     assigned array cannot dynamically check its stores
1948compiler.misc.unchecked.cast.to.type=\
1949    unchecked cast
1950
1951# compiler.err.star.expected=\
1952#     ''*'' expected
1953# compiler.err.no.elem.type=\
1954#     \[\*\] cannot have a type
1955
1956# 0: type
1957compiler.misc.try.not.applicable.to.type=\
1958    try-with-resources not applicable to variable type\n\
1959    ({0})
1960
1961#####
1962
1963# 0: message segment or type, 1: message segment
1964compiler.err.type.found.req=\
1965    unexpected type\n\
1966    required: {1}\n\
1967    found:    {0}
1968
1969## The following are all possible strings for the first argument ({0}) of the
1970## above string.
1971compiler.misc.type.req.class=\
1972    class
1973
1974compiler.misc.type.req.class.array=\
1975    class or array
1976
1977compiler.misc.type.req.array.or.iterable=\
1978    array or java.lang.Iterable
1979
1980compiler.misc.type.req.ref=\
1981    reference
1982
1983compiler.misc.type.req.exact=\
1984    class or interface without bounds
1985
1986# 0: type
1987compiler.misc.type.parameter=\
1988    type parameter {0}
1989
1990#####
1991
1992## The following are all possible strings for the last argument of all those
1993## diagnostics whose key ends in ".1"
1994
1995# 0: type, 1: list of type
1996compiler.misc.no.unique.maximal.instance.exists=\
1997    no unique maximal instance exists for type variable {0} with upper bounds {1}
1998
1999compiler.misc.no.unique.minimal.instance.exists=\
2000    no unique minimal instance exists for type variable {0} with lower bounds {1}
2001
2002# 0: type, 1: list of type
2003compiler.misc.incompatible.upper.bounds=\
2004    inference variable {0} has incompatible upper bounds {1}
2005
2006# 0: type, 1: list of type
2007compiler.misc.incompatible.eq.bounds=\
2008    inference variable {0} has incompatible equality constraints {1}
2009
2010# 0: type, 1: list of type, 2: list of type
2011compiler.misc.incompatible.eq.upper.bounds=\
2012    inference variable {0} has incompatible bounds\n\
2013    equality constraints: {1}\n\
2014    upper bounds: {2}
2015
2016# 0: type, 1: list of type, 2: list of type
2017compiler.misc.incompatible.upper.lower.bounds=\
2018    inference variable {0} has incompatible bounds\n\
2019    upper bounds: {1}\n\
2020    lower bounds: {2}
2021
2022# 0: type, 1: list of type, 2: list of type
2023compiler.misc.incompatible.eq.lower.bounds=\
2024    inference variable {0} has incompatible bounds\n\
2025    equality constraints: {1}\n\
2026    lower bounds: {2}
2027
2028# 0: list of type, 1: type, 2: type
2029compiler.misc.infer.no.conforming.instance.exists=\
2030    no instance(s) of type variable(s) {0} exist so that {1} conforms to {2}
2031
2032# 0: list of type, 1: message segment
2033compiler.misc.infer.no.conforming.assignment.exists=\
2034    cannot infer type-variable(s) {0}\n\
2035    (argument mismatch; {1})
2036
2037# 0: list of type
2038compiler.misc.infer.arg.length.mismatch=\
2039    cannot infer type-variable(s) {0}\n\
2040    (actual and formal argument lists differ in length)
2041
2042# 0: list of type, 1: message segment
2043compiler.misc.infer.varargs.argument.mismatch=\
2044    cannot infer type-variable(s) {0}\n\
2045    (varargs mismatch; {1})
2046
2047# 0: type, 1: list of type
2048compiler.misc.inferred.do.not.conform.to.upper.bounds=\
2049    inferred type does not conform to upper bound(s)\n\
2050    inferred: {0}\n\
2051    upper bound(s): {1}
2052
2053# 0: type, 1: list of type
2054compiler.misc.inferred.do.not.conform.to.lower.bounds=\
2055    inferred type does not conform to lower bound(s)\n\
2056    inferred: {0}\n\
2057    lower bound(s): {1}
2058
2059# 0: type, 1: list of type
2060compiler.misc.inferred.do.not.conform.to.eq.bounds=\
2061    inferred type does not conform to equality constraint(s)\n\
2062    inferred: {0}\n\
2063    equality constraints(s): {1}
2064
2065# 0: symbol
2066compiler.misc.diamond=\
2067    {0}<>
2068
2069# 0: type
2070compiler.misc.diamond.non.generic=\
2071    cannot use ''<>'' with non-generic class {0}
2072
2073# 0: list of type, 1: message segment
2074compiler.misc.diamond.invalid.arg=\
2075    type argument {0} inferred for {1} is not allowed in this context\n\
2076    inferred argument is not expressible in the Signature attribute
2077
2078# 0: list of type, 1: message segment
2079compiler.misc.diamond.invalid.args=\
2080    type arguments {0} inferred for {1} are not allowed in this context\n\
2081    inferred arguments are not expressible in the Signature attribute
2082
2083# 0: unused
2084compiler.misc.diamond.and.explicit.params=\
2085    cannot use ''<>'' with explicit type parameters for constructor
2086
2087# 0: unused
2088compiler.misc.mref.infer.and.explicit.params=\
2089    cannot use raw constructor reference with explicit type parameters for constructor
2090
2091# 0: type, 1: list of type
2092compiler.misc.explicit.param.do.not.conform.to.bounds=\
2093    explicit type argument {0} does not conform to declared bound(s) {1}
2094
2095compiler.misc.arg.length.mismatch=\
2096    actual and formal argument lists differ in length
2097
2098# 0: message segment
2099compiler.misc.no.conforming.assignment.exists=\
2100    argument mismatch; {0}
2101
2102# 0: message segment
2103compiler.misc.varargs.argument.mismatch=\
2104    varargs mismatch; {0}
2105
2106#####
2107
2108# 0: symbol or type, 1: file name
2109compiler.warn.auxiliary.class.accessed.from.outside.of.its.source.file=\
2110    auxiliary class {0} in {1} should not be accessed from outside its own source file
2111
2112## The first argument ({0}) is a "kindname".
2113# 0: symbol kind, 1: symbol, 2: symbol
2114compiler.err.abstract.cant.be.accessed.directly=\
2115    abstract {0} {1} in {2} cannot be accessed directly
2116
2117## The first argument ({0}) is a "kindname".
2118# 0: symbol kind, 1: symbol
2119compiler.err.non-static.cant.be.ref=\
2120    non-static {0} {1} cannot be referenced from a static context
2121
2122# 0: symbol kind, 1: symbol
2123compiler.misc.bad.static.method.in.unbound.lookup=\
2124    unexpected static {0} {1} found in unbound lookup
2125
2126# 0: symbol kind, 1: symbol
2127compiler.misc.bad.instance.method.in.unbound.lookup=\
2128    unexpected instance {0} {1} found in unbound lookup
2129
2130# 0: symbol kind, 1: symbol
2131compiler.misc.bad.static.method.in.bound.lookup=\
2132    unexpected static {0} {1} found in bound lookup
2133
2134## Both arguments ({0}, {1}) are "kindname"s.  {0} is a comma-separated list
2135## of kindnames (the list should be identical to that provided in source.
2136compiler.err.unexpected.type=\
2137    unexpected type\n\
2138    required: {0}\n\
2139    found:    {1}
2140
2141compiler.err.unexpected.lambda=\
2142   lambda expression not expected here
2143
2144compiler.err.unexpected.mref=\
2145   method reference not expected here
2146
2147## The first argument {0} is a "kindname" (e.g. 'constructor', 'field', etc.)
2148## The second argument {1} is the non-resolved symbol
2149## The third argument {2} is a list of type parameters (non-empty if {1} is a method)
2150## The fourth argument {3} is a list of argument types (non-empty if {1} is a method)
2151# 0: symbol kind, 1: name, 2: unused, 3: unused
2152compiler.err.cant.resolve=\
2153    cannot find symbol\n\
2154    symbol: {0} {1}
2155
2156# 0: symbol kind, 1: name, 2: unused, 3: list of type
2157compiler.err.cant.resolve.args=\
2158    cannot find symbol\n\
2159    symbol: {0} {1}({3})
2160
2161# 0: symbol kind, 1: name, 2: list of type, 3: list of type
2162compiler.err.cant.resolve.args.params=\
2163    cannot find symbol\n\
2164    symbol: {0} <{2}>{1}({3})
2165
2166## arguments from {0} to {3} have the same meaning as above
2167## The fifth argument {4} is a location subdiagnostic (see below)
2168# 0: symbol kind, 1: name, 2: unused, 3: unused, 4: message segment
2169compiler.err.cant.resolve.location=\
2170    cannot find symbol\n\
2171    symbol:   {0} {1}\n\
2172    location: {4}
2173
2174# 0: symbol kind, 1: name, 2: unused, 3: list of type, 4: message segment
2175compiler.err.cant.resolve.location.args=\
2176    cannot find symbol\n\
2177    symbol:   {0} {1}({3})\n\
2178    location: {4}
2179
2180# 0: symbol kind, 1: name, 2: list of type, 3: list, 4: message segment
2181compiler.err.cant.resolve.location.args.params=\
2182    cannot find symbol\n\
2183    symbol:   {0} <{2}>{1}({3})\n\
2184    location: {4}
2185
2186### Following are replicated/used for method reference diagnostics
2187
2188# 0: symbol kind, 1: name, 2: unused, 3: list of type, 4: message segment
2189compiler.misc.cant.resolve.location.args=\
2190    cannot find symbol\n\
2191    symbol:   {0} {1}({3})\n\
2192    location: {4}
2193
2194# 0: symbol kind, 1: name, 2: list of type, 3: list, 4: message segment
2195compiler.misc.cant.resolve.location.args.params=\
2196    cannot find symbol\n\
2197    symbol:   {0} <{2}>{1}({3})\n\
2198    location: {4}
2199
2200##a location subdiagnostic is composed as follows:
2201## The first argument {0} is the location "kindname" (e.g. 'constructor', 'field', etc.)
2202## The second argument {1} is the location name
2203## The third argument {2} is the location type (only when {1} is a variable name)
2204
2205# 0: symbol kind, 1: type or symbol, 2: unused
2206compiler.misc.location=\
2207    {0} {1}
2208
2209# 0: symbol kind, 1: symbol, 2: type
2210compiler.misc.location.1=\
2211    {0} {1} of type {2}
2212
2213## The following are all possible string for "kindname".
2214## They should be called whatever the JLS calls them after it been translated
2215## to the appropriate language.
2216# compiler.misc.kindname.constructor=\
2217#     static member
2218compiler.misc.kindname.annotation=\
2219    @interface
2220
2221compiler.misc.kindname.constructor=\
2222    constructor
2223
2224compiler.misc.kindname.enum=\
2225    enum
2226
2227compiler.misc.kindname.interface=\
2228    interface
2229
2230compiler.misc.kindname.static=\
2231    static
2232
2233compiler.misc.kindname.type.variable=\
2234    type variable
2235
2236compiler.misc.kindname.type.variable.bound=\
2237    bound of type variable
2238
2239compiler.misc.kindname.variable=\
2240    variable
2241
2242compiler.misc.kindname.value=\
2243    value
2244
2245compiler.misc.kindname.method=\
2246    method
2247
2248compiler.misc.kindname.class=\
2249    class
2250
2251compiler.misc.kindname.package=\
2252    package
2253
2254compiler.misc.kindname.module=\
2255    module
2256
2257compiler.misc.kindname.static.init=\
2258    static initializer
2259
2260compiler.misc.kindname.instance.init=\
2261    instance initializer
2262
2263#####
2264
2265compiler.misc.no.args=\
2266    no arguments
2267
2268# 0: message segment
2269compiler.err.override.static=\
2270    {0}\n\
2271    overriding method is static
2272
2273# 0: message segment, 1: set of modifier
2274compiler.err.override.meth=\
2275    {0}\n\
2276    overridden method is {1}
2277
2278# 0: message segment, 1: type
2279compiler.err.override.meth.doesnt.throw=\
2280    {0}\n\
2281    overridden method does not throw {1}
2282
2283# In the following string {1} is a space separated list of Java Keywords, as
2284# they would have been declared in the source code
2285# 0: message segment, 1: set of modifier
2286compiler.err.override.weaker.access=\
2287    {0}\n\
2288    attempting to assign weaker access privileges; was {1}
2289
2290# 0: message segment, 1: type, 2: type
2291compiler.err.override.incompatible.ret=\
2292    {0}\n\
2293    return type {1} is not compatible with {2}
2294
2295# 0: message segment, 1: type, 2: type
2296compiler.warn.override.unchecked.ret=\
2297    {0}\n\
2298    return type requires unchecked conversion from {1} to {2}
2299
2300# 0: message segment, 1: type
2301compiler.warn.override.unchecked.thrown=\
2302    {0}\n\
2303    overridden method does not throw {1}
2304
2305# 0: symbol
2306compiler.warn.override.equals.but.not.hashcode=\
2307    Class {0} overrides equals, but neither it nor any superclass overrides hashCode method
2308
2309## The following are all possible strings for the first argument ({0}) of the
2310## above strings.
2311# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2312compiler.misc.cant.override=\
2313    {0} in {1} cannot override {2} in {3}
2314
2315# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2316compiler.misc.cant.hide=\
2317    {0} in {1} cannot hide {2} in {3}
2318
2319# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2320compiler.misc.cant.implement=\
2321    {0} in {1} cannot implement {2} in {3}
2322
2323# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2324compiler.misc.clashes.with=\
2325    {0} in {1} clashes with {2} in {3}
2326
2327# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2328compiler.misc.unchecked.override=\
2329    {0} in {1} overrides {2} in {3}
2330
2331# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2332compiler.misc.unchecked.implement=\
2333    {0} in {1} implements {2} in {3}
2334
2335# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2336compiler.misc.unchecked.clash.with=\
2337    {0} in {1} overrides {2} in {3}
2338
2339# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2340compiler.misc.varargs.override=\
2341    {0} in {1} overrides {2} in {3}
2342
2343# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2344compiler.misc.varargs.implement=\
2345    {0} in {1} implements {2} in {3}
2346
2347# 0: symbol, 1: symbol, 2: symbol, 3: symbol
2348compiler.misc.varargs.clash.with=\
2349    {0} in {1} overrides {2} in {3}
2350
2351# 0: symbol kind, 1: symbol, 2: symbol, 3: message segment
2352compiler.misc.inapplicable.method=\
2353    {0} {1}.{2} is not applicable\n\
2354    ({3})
2355
2356########################################
2357# Diagnostics for language feature changes
2358########################################
2359
2360# 0: string
2361compiler.err.modules.not.supported.in.source=\
2362   modules are not supported in -source {0}\n\
2363    (use -source 9 or higher to enable modules)
2364
2365# 0: string
2366compiler.misc.diamond.and.anon.class.not.supported.in.source=\
2367    cannot use ''<>'' with anonymous inner classes in -source {0}\n\
2368    (use -source 9 or higher to enable ''<>'' with anonymous inner classes)
2369
2370# 0: string
2371compiler.err.unsupported.binary.lit=\
2372    binary literals are not supported in -source {0}\n\
2373    (use -source 7 or higher to enable binary literals)
2374
2375# 0: string
2376compiler.err.unsupported.underscore.lit=\
2377    underscores in literals are not supported in -source {0}\n\
2378    (use -source 7 or higher to enable underscores in literals)
2379
2380# 0: string
2381compiler.err.try.with.resources.not.supported.in.source=\
2382    try-with-resources is not supported in -source {0}\n\
2383    (use -source 7 or higher to enable try-with-resources)
2384
2385# 0: string
2386compiler.err.var.in.try.with.resources.not.supported.in.source=\
2387    variables in try-with-resources not supported in -source {0}\n\
2388    (use -source 9 or higher to enable variables in try-with-resources)
2389
2390compiler.warn.underscore.as.identifier=\
2391    as of release 9, ''_'' is a keyword, and may not be used as an identifier
2392
2393compiler.err.underscore.as.identifier=\
2394    as of release 9, ''_'' is a keyword, and may not be used as an identifier
2395
2396compiler.err.underscore.as.identifier.in.lambda=\
2397    ''_'' used as an identifier\n\
2398    (use of ''_'' as an identifier is forbidden for lambda parameters)
2399
2400compiler.err.enum.as.identifier=\
2401    as of release 5, ''enum'' is a keyword, and may not be used as an identifier
2402
2403compiler.err.assert.as.identifier=\
2404    as of release 1.4, ''assert'' is a keyword, and may not be used as an identifier
2405
2406# TODO 308: make a better error message
2407compiler.err.this.as.identifier=\
2408    as of release 8, ''this'' is allowed as the parameter name for the receiver type only, which has to be the first parameter
2409
2410# 0: symbol
2411compiler.err.receiver.parameter.not.applicable.constructor.toplevel.class=\
2412    receiver parameter not applicable for constructor of top-level class
2413
2414# TODO 308: make a better error message
2415# 0: symbol
2416compiler.err.cant.type.annotate.scoping.1=\
2417    scoping construct cannot be annotated with type-use annotation: {0}
2418
2419# TODO 308: make a better error message
2420# 0: list of symbol
2421compiler.err.cant.type.annotate.scoping=\
2422    scoping construct cannot be annotated with type-use annotations: {0}
2423
2424# 0: type, 1: type
2425compiler.err.incorrect.receiver.name=\
2426    the receiver name does not match the enclosing class type\n\
2427    required: {0}\n\
2428    found: {1}
2429
2430# 0: type, 1: type
2431compiler.err.incorrect.receiver.type=\
2432    the receiver type does not match the enclosing class type\n\
2433    required: {0}\n\
2434    found: {1}
2435
2436# 0: type, 1: type
2437compiler.err.incorrect.constructor.receiver.type=\
2438    the receiver type does not match the enclosing outer class type\n\
2439    required: {0}\n\
2440    found: {1}
2441
2442# 0: type, 1: type
2443compiler.err.incorrect.constructor.receiver.name=\
2444    the receiver name does not match the enclosing outer class type\n\
2445    required: {0}\n\
2446    found: {1}
2447
2448compiler.err.no.annotations.on.dot.class=\
2449    no annotations are allowed in the type of a class literal
2450
2451# 0: string
2452compiler.err.type.annotations.not.supported.in.source=\
2453    type annotations are not supported in -source {0}\n\
2454(use -source 8 or higher to enable type annotations)
2455
2456# 0: string
2457compiler.err.annotations.after.type.params.not.supported.in.source=\
2458    annotations after method type parameters are not supported in -source {0}\n\
2459(use -source 8 or higher to enable annotations after method type parameters)
2460
2461# 0: string
2462compiler.err.repeatable.annotations.not.supported.in.source=\
2463    repeated annotations are not supported in -source {0}\n\
2464(use -source 8 or higher to enable repeated annotations)
2465
2466# 0: string
2467compiler.err.diamond.not.supported.in.source=\
2468    diamond operator is not supported in -source {0}\n\
2469    (use -source 7 or higher to enable diamond operator)
2470
2471# 0: string
2472compiler.err.multicatch.not.supported.in.source=\
2473    multi-catch statement is not supported in -source {0}\n\
2474    (use -source 7 or higher to enable multi-catch statement)
2475
2476# 0: string
2477compiler.err.string.switch.not.supported.in.source=\
2478    strings in switch are not supported in -source {0}\n\
2479    (use -source 7 or higher to enable strings in switch)
2480
2481# 0: string
2482compiler.err.lambda.not.supported.in.source=\
2483    lambda expressions are not supported in -source {0}\n\
2484    (use -source 8 or higher to enable lambda expressions)
2485
2486# 0: string
2487compiler.err.method.references.not.supported.in.source=\
2488    method references are not supported in -source {0}\n\
2489    (use -source 8 or higher to enable method references)
2490
2491# 0: string
2492compiler.err.default.methods.not.supported.in.source=\
2493    default methods are not supported in -source {0}\n\
2494    (use -source 8 or higher to enable default methods)
2495
2496# 0: string
2497compiler.err.intersection.types.in.cast.not.supported.in.source=\
2498    intersection types in cast are not supported in -source {0}\n\
2499    (use -source 8 or higher to enable default methods)
2500
2501# 0: string
2502compiler.err.static.intf.methods.not.supported.in.source=\
2503    static interface methods are not supported in -source {0}\n\
2504    (use -source 8 or higher to enable static interface methods)
2505
2506# 0: string
2507compiler.err.static.intf.method.invoke.not.supported.in.source=\
2508    static interface method invocations are not supported in -source {0}\n\
2509    (use -source 8 or higher to enable static interface method invocations)
2510
2511# 0: string
2512compiler.err.private.intf.methods.not.supported.in.source=\
2513    private interface methods are not supported in -source {0}\n\
2514    (use -source 9 or higher to enable private interface methods)
2515
2516########################################
2517# Diagnostics for verbose resolution
2518# used by Resolve (debug only)
2519########################################
2520
2521# 0: number, 1: symbol, 2: unused
2522compiler.misc.applicable.method.found=\
2523    #{0} applicable method found: {1}
2524
2525# 0: number, 1: symbol, 2: message segment
2526compiler.misc.applicable.method.found.1=\
2527    #{0} applicable method found: {1}\n\
2528    ({2})
2529
2530# 0: number, 1: symbol, 2: message segment
2531compiler.misc.not.applicable.method.found=\
2532    #{0} not applicable method found: {1}\n\
2533    ({2})
2534
2535# 0: type
2536compiler.misc.partial.inst.sig=\
2537    partially instantiated to: {0}
2538
2539# 0: name, 1: symbol, 2: number, 3: string (method resolution phase), 4: list of type or message segment, 5: list of type or message segment
2540compiler.note.verbose.resolve.multi=\
2541    resolving method {0} in type {1} to candidate {2}\n\
2542    phase: {3}\n\
2543    with actuals: {4}\n\
2544    with type-args: {5}\n\
2545    candidates:
2546
2547# 0: name, 1: symbol, 2: unused, 3: string (method resolution phase), 4: list of type or message segment, 5: list of type or message segment
2548compiler.note.verbose.resolve.multi.1=\
2549    erroneous resolution for method {0} in type {1}\n\
2550    phase: {3}\n\
2551    with actuals: {4}\n\
2552    with type-args: {5}\n\
2553    candidates:
2554
2555# 0: symbol, 1: type, 2: type
2556compiler.note.deferred.method.inst=\
2557    Deferred instantiation of method {0}\n\
2558    instantiated signature: {1}\n\
2559    target-type: {2}
2560
2561########################################
2562# Diagnostics for where clause implementation
2563# used by the RichDiagnosticFormatter.
2564########################################
2565
2566compiler.misc.type.null=\
2567    <null>
2568
2569# X#n (where n is an int id) is disambiguated tvar name
2570# 0: name, 1: number
2571compiler.misc.type.var=\
2572    {0}#{1}
2573
2574# CAP#n (where n is an int id) is an abbreviation for 'captured type'
2575# 0: number
2576compiler.misc.captured.type=\
2577    CAP#{0}
2578
2579# <INT#n> (where n is an int id) is an abbreviation for 'intersection type'
2580# 0: number
2581compiler.misc.intersection.type=\
2582    INT#{0}
2583
2584# where clause for captured type: contains upper ('extends {1}') and lower
2585# ('super {2}') bound along with the wildcard that generated this captured type ({3})
2586# 0: type, 1: type, 2: type, 3: type
2587compiler.misc.where.captured=\
2588    {0} extends {1} super: {2} from capture of {3}
2589
2590# compact where clause for captured type: contains upper ('extends {1}') along
2591# with the wildcard that generated this captured type ({3})
2592# 0: type, 1: type, 2: unused, 3: type
2593compiler.misc.where.captured.1=\
2594    {0} extends {1} from capture of {3}
2595
2596# where clause for type variable: contains upper bound(s) ('extends {1}') along with
2597# the kindname ({2}) and location ({3}) in which the typevar has been declared
2598# 0: type, 1: list of type, 2: symbol kind, 3: symbol
2599compiler.misc.where.typevar=\
2600    {0} extends {1} declared in {2} {3}
2601
2602# compact where clause for type variable: contains the kindname ({2}) and location ({3})
2603# in which the typevar has been declared
2604# 0: type, 1: list of type, 2: symbol kind, 3: symbol
2605compiler.misc.where.typevar.1=\
2606    {0} declared in {2} {3}
2607
2608# where clause for fresh type variable: contains upper bound(s) ('extends {1}').
2609# Since a fresh type-variable is synthetic - there's no location/kindname here.
2610# 0: type, 1: list of type
2611compiler.misc.where.fresh.typevar=\
2612    {0} extends {1}
2613
2614# where clause for type variable: contains all the upper bound(s) ('extends {1}')
2615# of this intersection type
2616# 0: type, 1: list of type
2617compiler.misc.where.intersection=\
2618    {0} extends {1}
2619
2620### Where clause headers ###
2621compiler.misc.where.description.captured=\
2622    where {0} is a fresh type-variable:
2623
2624# 0: set of type
2625compiler.misc.where.description.typevar=\
2626    where {0} is a type-variable:
2627
2628# 0: set of type
2629compiler.misc.where.description.intersection=\
2630    where {0} is an intersection type:
2631
2632# 0: set of type
2633compiler.misc.where.description.captured.1=\
2634    where {0} are fresh type-variables:
2635
2636# 0: set of type
2637compiler.misc.where.description.typevar.1=\
2638    where {0} are type-variables:
2639
2640# 0: set of type
2641compiler.misc.where.description.intersection.1=\
2642    where {0} are intersection types:
2643
2644###
2645# errors related to doc comments
2646
2647compiler.err.dc.bad.entity=\
2648    bad HTML entity
2649
2650compiler.err.dc.bad.gt=\
2651    bad use of ''>''
2652
2653compiler.err.dc.bad.inline.tag=\
2654    incorrect use of inline tag
2655
2656compiler.err.dc.identifier.expected=\
2657    identifier expected
2658
2659compiler.err.dc.malformed.html=\
2660    malformed HTML
2661
2662compiler.err.dc.missing.semicolon=\
2663    semicolon missing
2664
2665compiler.err.dc.no.content=\
2666    no content
2667
2668compiler.err.dc.no.tag.name=\
2669    no tag name after '@'
2670
2671compiler.err.dc.gt.expected=\
2672    ''>'' expected
2673
2674compiler.err.dc.ref.bad.parens=\
2675    '')'' missing in reference
2676
2677compiler.err.dc.ref.syntax.error=\
2678    syntax error in reference
2679
2680compiler.err.dc.ref.unexpected.input=\
2681    unexpected text
2682
2683compiler.err.dc.unexpected.content=\
2684    unexpected content
2685
2686compiler.err.dc.unterminated.inline.tag=\
2687    unterminated inline tag
2688
2689compiler.err.dc.unterminated.signature=\
2690    unterminated signature
2691
2692compiler.err.dc.unterminated.string=\
2693    unterminated string
2694
2695###
2696# errors related to modules
2697
2698compiler.err.expected.module=\
2699    expected ''module''
2700
2701# 0: symbol
2702compiler.err.module.not.found=\
2703    module not found: {0}
2704
2705compiler.err.too.many.modules=\
2706    too many module declarations found
2707
2708# 0: symbol
2709compiler.err.duplicate.module=\
2710    duplicate module: {0}
2711
2712# 0: symbol
2713compiler.err.duplicate.requires=\
2714    duplicate requires: {0}
2715
2716# 0: symbol
2717compiler.err.duplicate.exports=\
2718    duplicate export: {0}
2719
2720# 0: symbol, 1: symbol
2721compiler.err.duplicate.provides=\
2722    duplicate provides: service {0}, implementation {1}
2723
2724# 0: symbol
2725compiler.err.duplicate.uses=\
2726    duplicate uses: {0}
2727
2728# 0: symbol
2729compiler.err.service.implementation.is.abstract=\
2730    the service implementation is an abstract class: {0}
2731
2732compiler.err.service.implementation.must.be.subtype.of.service.interface=\
2733    the service implementation type must be a subtype of the service interface type
2734
2735# 0: symbol
2736compiler.err.service.implementation.is.inner=\
2737    the service implementation is an inner class: {0}
2738
2739# 0: symbol
2740compiler.err.service.definition.is.inner=\
2741    the service definition is an inner class: {0}
2742
2743# 0: symbol
2744compiler.err.service.definition.is.enum=\
2745    the service definition is an enum: {0}
2746
2747# 0: symbol
2748compiler.err.service.implementation.doesnt.have.a.no.args.constructor=\
2749    the service implementation does not have a default constructor: {0}
2750
2751# 0: symbol
2752compiler.err.service.implementation.no.args.constructor.not.public=\
2753    the no arguments constructor of the service implementation is not public: {0}
2754
2755# 0: symbol
2756compiler.err.package.empty.or.not.found=\
2757    package is empty or does not exist: {0}
2758
2759compiler.err.no.output.dir=\
2760    no class output directory specified
2761
2762compiler.err.unnamed.pkg.not.allowed.named.modules=\
2763    unnamed package is not allowed in named modules
2764
2765# 0: name, 1: name
2766compiler.err.module.name.mismatch=\
2767    module name {0} does not match expected name {1}
2768
2769compiler.err.module.decl.sb.in.module-info.java=\
2770    module declarations should be in a file named module-info.java
2771
2772compiler.err.module-info.with.xmodule.sourcepath=\
2773    illegal combination of -Xmodule and module-info on sourcepath
2774
2775compiler.err.module-info.with.xmodule.classpath=\
2776    illegal combination of -Xmodule and module-info on classpath
2777
2778compiler.err.xmodule.no.module.sourcepath=\
2779    illegal combination of -Xmodule and -modulesourcepath
2780
2781compiler.err.processorpath.no.processormodulepath=\
2782    illegal combination of -processorpath and -processormodulepath
2783
2784# 0: symbol
2785compiler.err.package.in.other.module=\
2786    package exists in another module: {0}
2787
2788# 0: symbol, 1: name, 2: symbol, 3: symbol
2789compiler.err.package.clash.from.requires=\
2790    module {0} reads package {1} from both {2} and {3}
2791
2792# 0: string
2793compiler.err.module.not.found.in.module.source.path=\
2794    module {0} not found in module source path
2795
2796compiler.err.output.dir.must.be.specified.with.dash.m.option=\
2797    class output directory must be specified if -m option is used
2798
2799compiler.err.modulesourcepath.must.be.specified.with.dash.m.option=\
2800    module source path must be specified if -m option is used
2801
2802# 0: symbol
2803compiler.err.service.implementation.not.in.right.module=\
2804    service implementation must be defined in the same module as the provides directive
2805
2806# 0: symbol
2807compiler.err.cyclic.requires=\
2808    cyclic dependence involving {0}
2809
2810# 0: fragment, 1: name
2811compiler.err.duplicate.module.on.path=\
2812    duplicate module on {0}\nmodule in {1}
2813
2814# 0:  string
2815compiler.err.xaddexports.malformed.entry=\
2816    bad value for -XaddExports: {0}
2817
2818# 0: string
2819compiler.err.xaddexports.too.many=\
2820    multiple -XaddExports options for {0}
2821
2822# 0:  string
2823compiler.err.xaddreads.malformed.entry=\
2824    bad value for -XaddReads: {0}
2825
2826# 0: string
2827compiler.err.xaddreads.too.many=\
2828    multiple -XaddReads options for {0}
2829
2830compiler.err.addmods.all.module.path.invalid=\
2831    -addmods ALL-MODULE-PATH can only be used when compiling the unnamed module
2832
2833compiler.misc.locn.module_source_path=\
2834    module source path
2835
2836compiler.misc.locn.upgrade_module_path=\
2837    upgrade module path
2838
2839compiler.misc.locn.system_modules=\
2840    system modules
2841
2842compiler.misc.locn.module_path=\
2843    application module path
2844
2845compiler.misc.cant.resolve.modules=\
2846    cannot resolve modules
2847
2848# 0: symbol
2849compiler.err.cant.find.module=\
2850    cannot find module: {0}
2851
2852# 0: string
2853compiler.err.invalid.module.specifier=\
2854    module specifier not allowed: {0}
2855
2856# 0: symbol
2857compiler.warn.service.provided.but.not.exported.or.used=\
2858    service interface provided but not exported or used
2859
2860###
2861# errors related to options
2862
2863# 0: string, 1: string
2864compiler.err.illegal.argument.for.option=\
2865    illegal argument for {0}: {1}
2866