001    /*
002     * Copyright 2010-2015 JetBrains s.r.o.
003     *
004     * Licensed under the Apache License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.apache.org/licenses/LICENSE-2.0
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    
017    package org.jetbrains.kotlin.diagnostics.rendering;
018    
019    import com.intellij.openapi.extensions.ExtensionPointName;
020    import kotlin.Unit;
021    import kotlin.jvm.functions.Function1;
022    import org.jetbrains.annotations.NotNull;
023    import org.jetbrains.annotations.Nullable;
024    import org.jetbrains.annotations.TestOnly;
025    import org.jetbrains.kotlin.diagnostics.Diagnostic;
026    import org.jetbrains.kotlin.diagnostics.DiagnosticFactory;
027    import org.jetbrains.kotlin.diagnostics.Errors;
028    import org.jetbrains.kotlin.psi.JetExpression;
029    import org.jetbrains.kotlin.psi.JetSimpleNameExpression;
030    import org.jetbrains.kotlin.psi.JetTypeConstraint;
031    import org.jetbrains.kotlin.renderer.DescriptorRenderer;
032    import org.jetbrains.kotlin.renderer.DescriptorRendererOptions;
033    import org.jetbrains.kotlin.renderer.MultiRenderer;
034    import org.jetbrains.kotlin.renderer.Renderer;
035    import org.jetbrains.kotlin.resolve.varianceChecker.VarianceChecker.VarianceConflictDiagnosticData;
036    import org.jetbrains.kotlin.types.JetType;
037    import org.jetbrains.kotlin.types.expressions.OperatorConventions;
038    import org.jetbrains.kotlin.util.MappedExtensionProvider;
039    
040    import java.lang.reflect.Field;
041    import java.lang.reflect.Modifier;
042    import java.util.ArrayList;
043    import java.util.List;
044    
045    import static org.jetbrains.kotlin.diagnostics.Errors.*;
046    import static org.jetbrains.kotlin.diagnostics.rendering.Renderers.*;
047    import static org.jetbrains.kotlin.renderer.DescriptorRenderer.*;
048    
049    public class DefaultErrorMessages {
050    
051        public interface Extension {
052            ExtensionPointName<Extension> EP_NAME = ExtensionPointName.create("org.jetbrains.kotlin.defaultErrorMessages");
053    
054            @NotNull
055            DiagnosticFactoryToRendererMap getMap();
056        }
057    
058        private static final DiagnosticFactoryToRendererMap MAP = new DiagnosticFactoryToRendererMap();
059        private static final MappedExtensionProvider<Extension, List<DiagnosticFactoryToRendererMap>> RENDERER_MAPS = MappedExtensionProvider.create(
060                Extension.EP_NAME,
061                new Function1<List<? extends Extension>, List<DiagnosticFactoryToRendererMap>>() {
062                    @Override
063                    public List<DiagnosticFactoryToRendererMap> invoke(List<? extends Extension> extensions) {
064                        List<DiagnosticFactoryToRendererMap> result = new ArrayList<DiagnosticFactoryToRendererMap>(extensions.size() + 1);
065                        for (Extension extension : extensions) {
066                            result.add(extension.getMap());
067                        }
068                        result.add(MAP);
069                        return result;
070                    }
071                });
072    
073        @NotNull
074        public static String render(@NotNull Diagnostic diagnostic) {
075            for (DiagnosticFactoryToRendererMap map : RENDERER_MAPS.get()) {
076                DiagnosticRenderer renderer = map.get(diagnostic.getFactory());
077                if (renderer != null) {
078                    //noinspection unchecked
079                    return renderer.render(diagnostic);
080                }
081            }
082            throw new IllegalArgumentException("Don't know how to render diagnostic of type " + diagnostic.getFactory().getName());
083        }
084    
085        @TestOnly
086        @Nullable
087        public static DiagnosticRenderer getRendererForDiagnostic(@NotNull Diagnostic diagnostic) {
088            for (DiagnosticFactoryToRendererMap map : RENDERER_MAPS.get()) {
089                DiagnosticRenderer renderer = map.get(diagnostic.getFactory());
090    
091                if (renderer != null) return renderer;
092            }
093    
094            return null;
095        }
096    
097        public static final DescriptorRenderer DEPRECATION_RENDERER = DescriptorRenderer.ONLY_NAMES_WITH_SHORT_TYPES.withOptions(
098                new Function1<DescriptorRendererOptions, Unit>() {
099                    @Override
100                    public Unit invoke(DescriptorRendererOptions options) {
101                        options.setWithoutTypeParameters(false);
102                        options.setReceiverAfterName(false);
103                        options.setRenderAccessors(true);
104                        return Unit.INSTANCE$;
105                    }
106                }
107        );
108    
109        static {
110            MAP.put(UNRESOLVED_REFERENCE, "Unresolved reference: {0}", ELEMENT_TEXT);
111    
112            MAP.put(INVISIBLE_REFERENCE, "Cannot access ''{0}'': it is ''{1}'' in ''{2}''", NAME, TO_STRING, NAME);
113            MAP.put(INVISIBLE_MEMBER, "Cannot access ''{0}'': it is ''{1}'' in ''{2}''", NAME, TO_STRING, NAME);
114    
115            MAP.put(REDECLARATION, "Redeclaration: {0}", STRING);
116            MAP.put(NAME_SHADOWING, "Name shadowed: {0}", STRING);
117            MAP.put(ACCESSOR_PARAMETER_NAME_SHADOWING, "Accessor parameter name 'field' is shadowed by backing field variable");
118    
119            MAP.put(TYPE_MISMATCH, "Type mismatch: inferred type is {1} but {0} was expected", RENDER_TYPE, RENDER_TYPE);
120            MAP.put(INCOMPATIBLE_MODIFIERS, "Modifier ''{0}'' is incompatible with ''{1}''", TO_STRING, TO_STRING);
121            MAP.put(DEPRECATED_MODIFIER_PAIR, "Modifier ''{0}'' is deprecated in presense of ''{1}''", TO_STRING, TO_STRING);
122            MAP.put(REPEATED_MODIFIER, "Repeated ''{0}''", TO_STRING);
123            MAP.put(WRONG_MODIFIER_TARGET, "Modifier ''{0}'' is not applicable to ''{1}''", TO_STRING, TO_STRING);
124            MAP.put(REDUNDANT_MODIFIER_FOR_TARGET, "Modifier ''{0}'' is redundant for ''{1}''", TO_STRING, TO_STRING);
125            MAP.put(WRONG_MODIFIER_CONTAINING_DECLARATION, "Modifier ''{0}'' is not applicable inside ''{1}''", TO_STRING, TO_STRING);
126            MAP.put(DEPRECATED_MODIFIER_CONTAINING_DECLARATION, "Modifier ''{0}'' is deprecated inside ''{1}''", TO_STRING, TO_STRING);
127            MAP.put(WRONG_ANNOTATION_TARGET, "This annotation is not applicable to target ''{0}''", TO_STRING);
128            MAP.put(WRONG_ANNOTATION_TARGET_WITH_USE_SITE_TARGET, "This annotation is not applicable to target ''{0}'' and use site target ''@{1}''", TO_STRING, TO_STRING);
129            MAP.put(REPEATED_ANNOTATION, "This annotation is not repeatable");
130            MAP.put(NON_SOURCE_ANNOTATION_ON_INLINED_FUNCTION_LITERAL, "Function literal here is an inlined argument so this annotation cannot be stored anywhere");
131    
132            MAP.put(INAPPLICABLE_TARGET_ON_PROPERTY, "''@{0}'' annotations could be applied only to property declarations", TO_STRING);
133            MAP.put(INAPPLICABLE_FIELD_TARGET_NO_BACKING_FIELD, "Property has neither a backing field nor a delegate");
134            MAP.put(INAPPLICABLE_TARGET_PROPERTY_IMMUTABLE, "Property must be mutable");
135            MAP.put(INAPPLICABLE_RECEIVER_TARGET, "''@receiver:'' annotations could be applied only to extension function or extension property declarations");
136            MAP.put(INAPPLICABLE_PARAM_TARGET, "''@param:'' annotations could be applied only to primary constructor parameters");
137            MAP.put(REDUNDANT_ANNOTATION_TARGET, "Redundant annotation target ''{0}''", STRING);
138    
139            MAP.put(REDUNDANT_MODIFIER, "Modifier ''{0}'' is redundant because ''{1}'' is present", TO_STRING, TO_STRING);
140            MAP.put(ABSTRACT_MODIFIER_IN_TRAIT, "Modifier ''abstract'' is redundant in interface");
141            MAP.put(REDUNDANT_MODIFIER_IN_GETTER, "Visibility modifiers are redundant in getter");
142            MAP.put(TYPE_PARAMETERS_IN_ENUM, "Enum class cannot have type parameters");
143            MAP.put(TYPECHECKER_HAS_RUN_INTO_RECURSIVE_PROBLEM,
144                    "Type checking has run into a recursive problem. Easiest workaround: specify types of your declarations explicitly"); // TODO: message
145            MAP.put(RETURN_NOT_ALLOWED, "'return' is not allowed here");
146            MAP.put(PROJECTION_IN_IMMEDIATE_ARGUMENT_TO_SUPERTYPE, "Projections are not allowed for immediate arguments of a supertype");
147            MAP.put(LABEL_NAME_CLASH, "There is more than one label with such a name in this scope");
148            MAP.put(EXPRESSION_EXPECTED_PACKAGE_FOUND, "Expression expected, but a package name found");
149    
150            MAP.put(CANNOT_IMPORT_MEMBERS_FROM_SINGLETON, "Cannot import members from object ''{0}''", NAME);
151            MAP.put(CANNOT_BE_IMPORTED, "Cannot import ''{0}'', functions and properties can be imported only from packages", TO_STRING);
152            MAP.put(PACKAGE_CANNOT_BE_IMPORTED, "Packages cannot be imported");
153            MAP.put(CONFLICTING_IMPORT, "Conflicting import, imported name ''{0}'' is ambiguous", STRING);
154            MAP.put(PLATFORM_CLASS_MAPPED_TO_KOTLIN, "This class shouldn''t be used in Kotlin. Use {0} instead.", CLASSES_OR_SEPARATED);
155    
156            MAP.put(CANNOT_INFER_PARAMETER_TYPE, "Cannot infer a type for this parameter. Please specify it explicitly.");
157    
158            MAP.put(NO_BACKING_FIELD_ABSTRACT_PROPERTY, "This property doesn't have a backing field, because it's abstract");
159            MAP.put(NO_BACKING_FIELD_CUSTOM_ACCESSORS,
160                    "This property doesn't have a backing field, because it has custom accessors without reference to the backing field");
161            MAP.put(INACCESSIBLE_BACKING_FIELD, "The backing field is not accessible here");
162            MAP.put(NOT_PROPERTY_BACKING_FIELD, "The referenced variable is not a property and doesn't have backing field");
163    
164            MAP.put(BACKING_FIELD_SYNTAX_DEPRECATED, "This backing field syntax is deprecated, use 'field' instead");
165            MAP.put(BACKING_FIELD_USAGE_DEPRECATED, "Backing field usage is deprecated here, soon it will be possible only in property accessors");
166    
167            MAP.put(MIXING_NAMED_AND_POSITIONED_ARGUMENTS, "Mixing named and positioned arguments is not allowed");
168            MAP.put(ARGUMENT_PASSED_TWICE, "An argument is already passed for this parameter");
169            MAP.put(NAMED_PARAMETER_NOT_FOUND, "Cannot find a parameter with this name: {0}", ELEMENT_TEXT);
170            MAP.put(NAMED_ARGUMENTS_NOT_ALLOWED, "Named arguments are not allowed for {0}", new Renderer<BadNamedArgumentsTarget>() {
171                @NotNull
172                @Override
173                public String render(@NotNull BadNamedArgumentsTarget target) {
174                    switch (target) {
175                        case NON_KOTLIN_FUNCTION:
176                            return "non-Kotlin functions";
177                        case INVOKE_ON_FUNCTION_TYPE:
178                            return "function types";
179                        default:
180                            throw new AssertionError(target);
181                    }
182                }
183            });
184    
185            MAP.put(VARARG_OUTSIDE_PARENTHESES, "Passing value as a vararg is only allowed inside a parenthesized argument list");
186            MAP.put(NON_VARARG_SPREAD, "The spread operator (*foo) may only be applied in a vararg position");
187    
188            MAP.put(MANY_FUNCTION_LITERAL_ARGUMENTS, "Only one function literal is allowed outside a parenthesized argument list");
189            MAP.put(PROPERTY_WITH_NO_TYPE_NO_INITIALIZER, "This property must either have a type annotation, be initialized or be delegated");
190            MAP.put(VARIABLE_WITH_NO_TYPE_NO_INITIALIZER, "This variable must either have a type annotation or be initialized");
191    
192            MAP.put(INITIALIZER_REQUIRED_FOR_MULTIDECLARATION, "Initializer required for multi-declaration");
193            MAP.put(COMPONENT_FUNCTION_MISSING, "Multi-declaration initializer of type {1} must have a ''{0}()'' function", TO_STRING, RENDER_TYPE);
194            MAP.put(COMPONENT_FUNCTION_AMBIGUITY, "Function ''{0}()'' is ambiguous for this expression: {1}", TO_STRING, AMBIGUOUS_CALLS);
195            MAP.put(COMPONENT_FUNCTION_RETURN_TYPE_MISMATCH, "''{0}()'' function returns ''{1}'', but ''{2}'' is expected",
196                                                                                        TO_STRING, RENDER_TYPE, RENDER_TYPE);
197    
198            MAP.put(ABSTRACT_PROPERTY_IN_PRIMARY_CONSTRUCTOR_PARAMETERS, "This property cannot be declared abstract");
199            MAP.put(ABSTRACT_PROPERTY_WITH_INITIALIZER, "Property with initializer cannot be abstract");
200            MAP.put(ABSTRACT_PROPERTY_WITH_GETTER, "Property with getter implementation cannot be abstract");
201            MAP.put(ABSTRACT_PROPERTY_WITH_SETTER, "Property with setter implementation cannot be abstract");
202    
203            MAP.put(ABSTRACT_DELEGATED_PROPERTY, "Delegated property cannot be abstract");
204            MAP.put(ACCESSOR_FOR_DELEGATED_PROPERTY, "Delegated property cannot have accessors with non-default implementations");
205            MAP.put(DELEGATED_PROPERTY_IN_TRAIT, "Delegated properties are not allowed in interfaces");
206            MAP.put(LOCAL_VARIABLE_WITH_DELEGATE, "Local variables are not allowed to have delegates");
207    
208            MAP.put(INAPPLICABLE_LATEINIT_MODIFIER, "''lateinit'' modifier is allowed only on member properties with a backing field");
209            MAP.put(INAPPLICABLE_LATEINIT_MODIFIER_IMMUTABLE, "''lateinit'' modifier is allowed only on mutable properties");
210            MAP.put(INAPPLICABLE_LATEINIT_MODIFIER_ABSTRACT_PROPERTY, "''lateinit'' modifier is not allowed on abstract properties");
211            MAP.put(INAPPLICABLE_LATEINIT_MODIFIER_PRIMARY_CONSTRUCTOR_PARAMETER, "''lateinit'' modifier is not allowed on primary constructor parameters");
212            MAP.put(INAPPLICABLE_LATEINIT_MODIFIER_NULLABLE, "''lateinit'' modifier is not allowed on nullable properties");
213    
214            MAP.put(GETTER_VISIBILITY_DIFFERS_FROM_PROPERTY_VISIBILITY, "Getter visibility must be the same as property visibility");
215            MAP.put(BACKING_FIELD_IN_TRAIT, "Property in an interface cannot have a backing field");
216            MAP.put(MUST_BE_INITIALIZED, "Property must be initialized");
217            MAP.put(MUST_BE_INITIALIZED_OR_BE_ABSTRACT, "Property must be initialized or be abstract");
218            MAP.put(PROPERTY_INITIALIZER_IN_TRAIT, "Property initializers are not allowed in interfaces");
219            MAP.put(FINAL_PROPERTY_IN_TRAIT, "Abstract property in an interface cannot be final");
220            MAP.put(EXTENSION_PROPERTY_WITH_BACKING_FIELD, "Extension property cannot be initialized because it has no backing field");
221            MAP.put(PROPERTY_INITIALIZER_NO_BACKING_FIELD, "Initializer is not allowed here because this property has no backing field");
222            MAP.put(ABSTRACT_PROPERTY_IN_NON_ABSTRACT_CLASS, "Abstract property ''{0}'' in non-abstract class ''{1}''", STRING, NAME);
223            MAP.put(ABSTRACT_FUNCTION_IN_NON_ABSTRACT_CLASS, "Abstract function ''{0}'' in non-abstract class ''{1}''", STRING, NAME);
224            MAP.put(ABSTRACT_FUNCTION_WITH_BODY, "A function ''{0}'' with body cannot be abstract", NAME);
225            MAP.put(NON_ABSTRACT_FUNCTION_WITH_NO_BODY, "Function ''{0}'' without a body must be abstract", NAME);
226            MAP.put(FINAL_FUNCTION_WITH_NO_BODY, "Function ''{0}'' without body cannot be final", NAME);
227    
228            MAP.put(NON_MEMBER_FUNCTION_NO_BODY, "Function ''{0}'' must have a body", NAME);
229            MAP.put(FUNCTION_DECLARATION_WITH_NO_NAME, "Function declaration must have a name");
230            MAP.put(FUNCTION_EXPRESSION_WITH_NAME, "Function expressions with names are prohibited");
231            MAP.put(NON_FINAL_MEMBER_IN_FINAL_CLASS, "\"open\" has no effect in a final class");
232    
233            MAP.put(FUNCTION_EXPRESSION_PARAMETER_WITH_DEFAULT_VALUE, "A function expression is not allowed to specify default values for its parameters");
234            MAP.put(USELESS_VARARG_ON_PARAMETER, "Vararg on this parameter is useless");
235    
236            MAP.put(PROJECTION_ON_NON_CLASS_TYPE_ARGUMENT, "Projections are not allowed on type arguments of functions and properties");
237            MAP.put(SUPERTYPE_NOT_INITIALIZED, "This type has a constructor, and thus must be initialized here");
238            MAP.put(NOTHING_TO_OVERRIDE, "''{0}'' overrides nothing", NAME);
239            MAP.put(VIRTUAL_MEMBER_HIDDEN, "''{0}'' hides member of supertype ''{2}'' and needs ''override'' modifier", NAME, NAME, NAME);
240    
241            MAP.put(DATA_CLASS_OVERRIDE_CONFLICT, "Function ''{0}'' generated for the data class conflicts with member of supertype ''{1}''", NAME, NAME);
242    
243            MAP.put(CANNOT_OVERRIDE_INVISIBLE_MEMBER, "''{0}'' has no access to ''{1}'', so it cannot override it", FQ_NAMES_IN_TYPES,
244                    FQ_NAMES_IN_TYPES);
245            MAP.put(CANNOT_INFER_VISIBILITY, "Cannot infer visibility for ''{0}''. Please specify it explicitly", COMPACT);
246    
247            MAP.put(ENUM_ENTRY_SHOULD_BE_INITIALIZED, "Enum has no default constructor, use 'entry(parameters)'");
248    
249            MAP.put(UNINITIALIZED_VARIABLE, "Variable ''{0}'' must be initialized", NAME);
250            MAP.put(UNINITIALIZED_PARAMETER, "Parameter ''{0}'' is uninitialized here", NAME);
251            MAP.put(UNUSED_VARIABLE, "Variable ''{0}'' is never used", NAME);
252            MAP.put(UNUSED_PARAMETER, "Parameter ''{0}'' is never used", NAME);
253            MAP.put(ASSIGNED_BUT_NEVER_ACCESSED_VARIABLE, "Variable ''{0}'' is assigned but never accessed", NAME);
254            MAP.put(VARIABLE_WITH_REDUNDANT_INITIALIZER, "Variable ''{0}'' initializer is redundant", NAME);
255            MAP.put(UNUSED_VALUE, "The value ''{0}'' assigned to ''{1}'' is never used", ELEMENT_TEXT, FQ_NAMES_IN_TYPES);
256            MAP.put(UNUSED_CHANGED_VALUE, "The value changed at ''{0}'' is never used", ELEMENT_TEXT);
257            MAP.put(UNUSED_EXPRESSION, "The expression is unused");
258            MAP.put(UNUSED_FUNCTION_LITERAL, "The function literal is unused. If you mean block, you can use 'run { ... }'");
259    
260            MAP.put(VAL_REASSIGNMENT, "Val cannot be reassigned", NAME);
261            MAP.put(SETTER_PROJECTED_OUT, "Setter for ''{0}'' is removed by type projection", NAME);
262            MAP.put(INVISIBLE_SETTER, "Cannot assign to ''{0}'': the setter is ''{1}'' in ''{2}''", NAME, TO_STRING, NAME);
263            MAP.put(INITIALIZATION_BEFORE_DECLARATION, "Variable cannot be initialized before declaration", NAME);
264            MAP.put(VARIABLE_EXPECTED, "Variable expected");
265    
266            MAP.put(VAL_OR_VAR_ON_LOOP_PARAMETER, "''{0}'' on loop parameter is not allowed", TO_STRING);
267            MAP.put(VAL_OR_VAR_ON_FUN_PARAMETER, "''{0}'' on function parameter is not allowed", TO_STRING);
268            MAP.put(VAL_OR_VAR_ON_CATCH_PARAMETER, "''{0}'' on catch parameter is not allowed", TO_STRING);
269            MAP.put(VAL_OR_VAR_ON_SECONDARY_CONSTRUCTOR_PARAMETER, "''{0}'' on secondary constructor parameter is not allowed", TO_STRING);
270    
271            MAP.put(INITIALIZATION_USING_BACKING_FIELD_CUSTOM_SETTER,
272                    "This property has a custom setter, so initialization using backing field required", NAME);
273            MAP.put(INITIALIZATION_USING_BACKING_FIELD_OPEN_SETTER,
274                    "Setter of this property can be overridden, so initialization using backing field required", NAME);
275    
276            MAP.put(UNREACHABLE_CODE, "Unreachable code", TO_STRING);
277    
278            MAP.put(MANY_COMPANION_OBJECTS, "Only one companion object is allowed per class");
279    
280            MAP.put(DEPRECATED_SYMBOL, "''{0}'' is deprecated.", DEPRECATION_RENDERER);
281            MAP.put(DEPRECATED_SYMBOL_WITH_MESSAGE, "''{0}'' is deprecated. {1}", DEPRECATION_RENDERER, STRING);
282    
283            MAP.put(LOCAL_OBJECT_NOT_ALLOWED, "Named object ''{0}'' is a singleton and cannot be local. Try to use anonymous object instead", NAME);
284            MAP.put(ENUM_CLASS_CONSTRUCTOR_CALL, "Enum types cannot be instantiated");
285            MAP.put(SEALED_CLASS_CONSTRUCTOR_CALL, "Sealed types cannot be instantiated");
286    
287            MAP.put(DELEGATION_IN_TRAIT, "Interfaces cannot use delegation");
288            MAP.put(DELEGATION_NOT_TO_TRAIT, "Only interfaces can be delegated to");
289            MAP.put(NO_CONSTRUCTOR, "This class does not have a constructor");
290            MAP.put(NOT_A_CLASS, "Not a class");
291            MAP.put(ILLEGAL_ESCAPE_SEQUENCE, "Illegal escape sequence");
292    
293            MAP.put(LOCAL_EXTENSION_PROPERTY, "Local extension properties are not allowed");
294            MAP.put(LOCAL_VARIABLE_WITH_GETTER, "Local variables are not allowed to have getters");
295            MAP.put(LOCAL_VARIABLE_WITH_SETTER, "Local variables are not allowed to have setters");
296            MAP.put(VAL_WITH_SETTER, "A 'val'-property cannot have a setter");
297    
298            MAP.put(NO_GET_METHOD, "No get method providing array access");
299            MAP.put(NO_SET_METHOD, "No set method providing array access");
300    
301            MAP.put(INC_DEC_SHOULD_NOT_RETURN_UNIT, "Functions inc(), dec() shouldn't return Unit to be used by operators ++, --");
302            MAP.put(ASSIGNMENT_OPERATOR_SHOULD_RETURN_UNIT, "Function ''{0}'' should return Unit to be used by corresponding operator ''{1}''",
303                    NAME, ELEMENT_TEXT);
304            MAP.put(ASSIGN_OPERATOR_AMBIGUITY, "Assignment operators ambiguity: {0}", AMBIGUOUS_CALLS);
305    
306            MAP.put(EQUALS_MISSING, "No method 'equals(kotlin.Any?): kotlin.Boolean' available");
307            MAP.put(ASSIGNMENT_IN_EXPRESSION_CONTEXT, "Assignments are not expressions, and only expressions are allowed in this context");
308            MAP.put(PACKAGE_IS_NOT_AN_EXPRESSION, "'package' is not an expression, it can only be used on the left-hand side of a dot ('.')");
309            MAP.put(SUPER_IS_NOT_AN_EXPRESSION, "''{0}'' is not an expression, it can only be used on the left-hand side of a dot ('.')", STRING);
310            MAP.put(SUPER_CANT_BE_EXTENSION_RECEIVER, "''{0}'' is not an expression, it can not be used as a receiver for extension functions", STRING);
311            MAP.put(DECLARATION_IN_ILLEGAL_CONTEXT, "Declarations are not allowed in this position");
312            MAP.put(SETTER_PARAMETER_WITH_DEFAULT_VALUE, "Setter parameters cannot have default values");
313            MAP.put(NO_THIS, "'this' is not defined in this context");
314            MAP.put(SUPER_NOT_AVAILABLE, "No supertypes are accessible in this context");
315            MAP.put(SUPERCLASS_NOT_ACCESSIBLE_FROM_TRAIT, "Superclass is not accessible from interface");
316            MAP.put(AMBIGUOUS_SUPER, "Many supertypes available, please specify the one you mean in angle brackets, e.g. 'super<Foo>'");
317            MAP.put(ABSTRACT_SUPER_CALL, "Abstract member cannot be accessed directly");
318            MAP.put(NOT_A_SUPERTYPE, "Not a supertype");
319            MAP.put(TYPE_ARGUMENTS_REDUNDANT_IN_SUPER_QUALIFIER, "Type arguments do not need to be specified in a 'super' qualifier");
320            MAP.put(DEPRECATED_STATIC_ASSERT, "Static type assertions are deprecated, consider using a cast instead");
321            MAP.put(USELESS_CAST, "No cast needed");
322            MAP.put(CAST_NEVER_SUCCEEDS, "This cast can never succeed");
323            MAP.put(DYNAMIC_NOT_ALLOWED, "Dynamic types are not allowed in this position");
324            MAP.put(IS_ENUM_ENTRY, "'is' over enum entry is not allowed, use comparison instead");
325            MAP.put(USELESS_NULLABLE_CHECK, "Non-null type is checked for instance of nullable type");
326            MAP.put(WRONG_SETTER_PARAMETER_TYPE, "Setter parameter type must be equal to the type of the property, i.e. ''{0}''", RENDER_TYPE, RENDER_TYPE);
327            MAP.put(WRONG_GETTER_RETURN_TYPE, "Getter return type must be equal to the type of the property, i.e. ''{0}''", RENDER_TYPE, RENDER_TYPE);
328            MAP.put(NO_COMPANION_OBJECT, "Please specify constructor invocation; classifier ''{0}'' does not have a companion object", NAME);
329            MAP.put(TYPE_PARAMETER_IS_NOT_AN_EXPRESSION, "Type parameter ''{0}'' is not an expression", NAME);
330            MAP.put(TYPE_PARAMETER_ON_LHS_OF_DOT, "Type parameter ''{0}'' cannot have or inherit a companion object, so it cannot be on the left hand side of dot", NAME);
331            MAP.put(NO_GENERICS_IN_SUPERTYPE_SPECIFIER, "Generic arguments of the base type must be specified");
332            MAP.put(NESTED_CLASS_ACCESSED_VIA_INSTANCE_REFERENCE, "Nested {0} accessed via instance reference", RENDER_CLASS_OR_OBJECT_NAME);
333            MAP.put(NESTED_CLASS_SHOULD_BE_QUALIFIED, "Nested {0} should be qualified as ''{1}''", RENDER_CLASS_OR_OBJECT_NAME, TO_STRING);
334    
335            MAP.put(INACCESSIBLE_OUTER_CLASS_EXPRESSION, "Expression is inaccessible from a nested class ''{0}'', use ''inner'' keyword to make the class inner", NAME);
336            MAP.put(NESTED_CLASS_NOT_ALLOWED, "Nested class is not allowed here, use ''inner'' keyword to make the class inner");
337    
338            MAP.put(HAS_NEXT_MISSING, "hasNext() cannot be called on iterator() of type ''{0}''", RENDER_TYPE);
339            MAP.put(HAS_NEXT_FUNCTION_AMBIGUITY, "hasNext() is ambiguous for iterator() of type ''{0}''", RENDER_TYPE);
340            MAP.put(HAS_NEXT_FUNCTION_NONE_APPLICABLE, "None of the hasNext() functions is applicable for iterator() of type ''{0}''", RENDER_TYPE);
341            MAP.put(HAS_NEXT_FUNCTION_TYPE_MISMATCH, "The ''iterator().hasNext()'' function of the loop range must return kotlin.Boolean, but returns {0}", RENDER_TYPE);
342    
343            MAP.put(NEXT_MISSING, "next() cannot be called on iterator() of type ''{0}''", RENDER_TYPE);
344            MAP.put(NEXT_AMBIGUITY, "next() is ambiguous for iterator() of type ''{0}''", RENDER_TYPE);
345            MAP.put(NEXT_NONE_APPLICABLE, "None of the next() functions is applicable for iterator() of type ''{0}''", RENDER_TYPE);
346    
347            MAP.put(ITERATOR_MISSING, "For-loop range must have an iterator() method");
348            MAP.put(ITERATOR_AMBIGUITY, "Method ''iterator()'' is ambiguous for this expression: {0}", AMBIGUOUS_CALLS);
349    
350            MAP.put(DELEGATE_SPECIAL_FUNCTION_MISSING, "Missing ''{0}'' method on delegate of type ''{1}''", STRING, RENDER_TYPE);
351            MAP.put(DELEGATE_SPECIAL_FUNCTION_AMBIGUITY, "Overload resolution ambiguity on method ''{0}'': {1}",  STRING, AMBIGUOUS_CALLS);
352            MAP.put(DELEGATE_SPECIAL_FUNCTION_NONE_APPLICABLE, "Property delegate must have a ''{0}'' method. None of the following functions is suitable: {1}",
353                    STRING, AMBIGUOUS_CALLS);
354            MAP.put(DELEGATE_SPECIAL_FUNCTION_RETURN_TYPE_MISMATCH, "The ''{0}'' function of property delegate is expected to return ''{1}'', but returns ''{2}''",
355                    STRING, RENDER_TYPE, RENDER_TYPE);
356            MAP.put(DELEGATE_PD_METHOD_NONE_APPLICABLE, "''{0}'' method may be missing. None of the following functions will be called: {1}", STRING, AMBIGUOUS_CALLS);
357    
358            MAP.put(COMPARE_TO_TYPE_MISMATCH, "''compareTo()'' must return kotlin.Int, but returns {0}", RENDER_TYPE);
359    
360            MAP.put(UNDESCORE_IS_DEPRECATED, "Names _, __, ___, ..., are deprecated");
361    
362            MAP.put(INAPPLICABLE_OPERATOR_MODIFIER, "'operator' modifier is inapplicable on this function");
363    
364            MAP.put(OPERATOR_MODIFIER_REQUIRED, "'operator' modifier is required on ''{0}'' in ''{1}''", NAME, STRING);
365    
366            MAP.put(RETURN_IN_FUNCTION_WITH_EXPRESSION_BODY,
367                    "Returns are not allowed for functions with expression body. Use block body in '{...}'");
368            MAP.put(NO_RETURN_IN_FUNCTION_WITH_BLOCK_BODY, "A 'return' expression required in a function with a block body ('{...}')");
369            MAP.put(RETURN_TYPE_MISMATCH, "This function must return a value of type {0}", RENDER_TYPE);
370            MAP.put(EXPECTED_TYPE_MISMATCH, "Expected a value of type {0}", RENDER_TYPE);
371            MAP.put(ASSIGNMENT_TYPE_MISMATCH,
372                    "Expected a value of type {0}. Assignment operation is not an expression, so it does not return any value", RENDER_TYPE);
373    
374            MAP.put(EXPECTED_PARAMETER_TYPE_MISMATCH, "Expected parameter of type {0}", RENDER_TYPE);
375            MAP.put(EXPECTED_PARAMETERS_NUMBER_MISMATCH, "Expected {0,choice,0#no parameters|1#one parameter of type|1<{0,number,integer} parameters of types} {1}", null, RENDER_COLLECTION_OF_TYPES);
376    
377            MAP.put(IMPLICIT_CAST_TO_UNIT_OR_ANY, "Type is cast to ''{0}''. Please specify ''{0}'' as expected type, if you mean such cast",
378                    RENDER_TYPE);
379            MAP.put(EXPRESSION_EXPECTED, "{0} is not an expression, and only expressions are allowed here", new Renderer<JetExpression>() {
380                @NotNull
381                @Override
382                public String render(@NotNull JetExpression expression) {
383                    String expressionType = expression.toString();
384                    return expressionType.substring(0, 1) +
385                           expressionType.substring(1).toLowerCase();
386                }
387            });
388    
389            MAP.put(UPPER_BOUND_VIOLATED, "Type argument is not within its bounds: should be subtype of ''{0}''", RENDER_TYPE, RENDER_TYPE);
390            MAP.put(FINAL_UPPER_BOUND, "''{0}'' is a final type, and thus a value of the type parameter is predetermined", RENDER_TYPE);
391            MAP.put(DYNAMIC_UPPER_BOUND, "Dynamic type can not be used as an upper bound");
392            MAP.put(USELESS_ELVIS, "Elvis operator (?:) always returns the left operand of non-nullable type {0}", RENDER_TYPE);
393            MAP.put(USELESS_ELVIS_ON_FUNCTION_LITERAL, "Left operand of elvis operator (?:) is function literal");
394            MAP.put(CONFLICTING_UPPER_BOUNDS, "Upper bounds of {0} have empty intersection", NAME);
395    
396            MAP.put(TOO_MANY_ARGUMENTS, "Too many arguments for {0}", FQ_NAMES_IN_TYPES);
397    
398            MAP.put(CONSTANT_EXPECTED_TYPE_MISMATCH, "An {0} literal does not conform to the expected type {1}", STRING, RENDER_TYPE);
399            MAP.put(DIVISION_BY_ZERO, "Division by zero");
400            MAP.put(INTEGER_OVERFLOW, "This operation has led to an overflow");
401            MAP.put(INT_LITERAL_OUT_OF_RANGE, "The value is out of range");
402            MAP.put(WRONG_LONG_SUFFIX, "Use 'L' instead of 'l'");
403            MAP.put(FLOAT_LITERAL_OUT_OF_RANGE, "The value is out of range");
404            MAP.put(INCORRECT_CHARACTER_LITERAL, "Incorrect character literal");
405            MAP.put(EMPTY_CHARACTER_LITERAL, "Empty character literal");
406            MAP.put(TOO_MANY_CHARACTERS_IN_CHARACTER_LITERAL, "Too many characters in a character literal ''{0}''", ELEMENT_TEXT);
407            MAP.put(ILLEGAL_ESCAPE, "Illegal escape: ''{0}''", ELEMENT_TEXT);
408            MAP.put(NULL_FOR_NONNULL_TYPE, "Null can not be a value of a non-null type {0}", RENDER_TYPE);
409    
410            MAP.put(ELSE_MISPLACED_IN_WHEN, "'else' entry must be the last one in a when-expression");
411    
412            MAP.put(NO_ELSE_IN_WHEN, "'when' expression must contain 'else' branch");
413            MAP.put(NON_EXHAUSTIVE_WHEN, "'when' expression contains only some variants and no 'else' branch");
414    
415            MAP.put(TYPE_MISMATCH_IN_RANGE, "Type mismatch: incompatible types of range and element checked in it");
416            MAP.put(CYCLIC_INHERITANCE_HIERARCHY, "There's a cycle in the inheritance hierarchy for this type");
417            MAP.put(CYCLIC_GENERIC_UPPER_BOUND, "Type parameter has itself as an upper bound");
418    
419            MAP.put(MANY_CLASSES_IN_SUPERTYPE_LIST, "Only one class may appear in a supertype list");
420            MAP.put(SUPERTYPE_NOT_A_CLASS_OR_TRAIT, "Only classes and interfaces may serve as supertypes");
421            MAP.put(SUPERTYPE_INITIALIZED_IN_TRAIT, "Interfaces cannot initialize supertypes");
422            MAP.put(CLASS_IN_SUPERTYPE_FOR_ENUM, "Enum class cannot inherit from classes");
423            MAP.put(CONSTRUCTOR_IN_TRAIT, "An interface may not have a constructor");
424            MAP.put(TRAIT_WITH_SUPERCLASS, "An interface cannot inherit from a class");
425            MAP.put(SUPERTYPE_APPEARS_TWICE, "A supertype appears twice");
426            MAP.put(FINAL_SUPERTYPE, "This type is final, so it cannot be inherited from");
427            MAP.put(DATA_CLASS_CANNOT_HAVE_CLASS_SUPERTYPES, "Data class inheritance from other classes is deprecated");
428            MAP.put(SEALED_SUPERTYPE, "This type is sealed, so it can be inherited by only its own nested classes or objects");
429            MAP.put(SEALED_SUPERTYPE_IN_LOCAL_CLASS, "Local class cannot extend a sealed class");
430            MAP.put(SINGLETON_IN_SUPERTYPE, "Cannot inherit from a singleton");
431    
432            MAP.put(CYCLIC_CONSTRUCTOR_DELEGATION_CALL, "There's a cycle in the delegation calls chain");
433            MAP.put(CONSTRUCTOR_IN_OBJECT, "Constructors are not allowed for objects");
434            MAP.put(SUPERTYPE_INITIALIZED_WITHOUT_PRIMARY_CONSTRUCTOR, "Supertype initialization is impossible without primary constructor");
435            MAP.put(PRIMARY_CONSTRUCTOR_DELEGATION_CALL_EXPECTED, "Primary constructor call expected");
436            MAP.put(DELEGATION_SUPER_CALL_IN_ENUM_CONSTRUCTOR, "Call to super is not allowed in enum constructor");
437            MAP.put(PRIMARY_CONSTRUCTOR_REQUIRED_FOR_DATA_CLASS, "Primary constructor required for data class");
438            MAP.put(EXPLICIT_DELEGATION_CALL_REQUIRED,
439                    "Explicit 'this' or 'super' call is required. There is no constructor in superclass that can be called without arguments");
440    
441            MAP.put(INSTANCE_ACCESS_BEFORE_SUPER_CALL, "Cannot access ''{0}'' before superclass constructor has been called", NAME);
442    
443            MAP.put(ILLEGAL_SELECTOR, "Expression ''{0}'' cannot be a selector (occur after a dot)", STRING);
444    
445            MAP.put(SAFE_CALL_IN_QUALIFIER, "Safe call is not allowed for qualifier");
446    
447            MAP.put(NO_TAIL_CALLS_FOUND, "A function is marked as tail-recursive but no tail calls are found");
448            MAP.put(VALUE_PARAMETER_WITH_NO_TYPE_ANNOTATION, "A type annotation is required on a value parameter");
449            MAP.put(BREAK_OR_CONTINUE_OUTSIDE_A_LOOP, "'break' and 'continue' are only allowed inside a loop");
450            MAP.put(BREAK_OR_CONTINUE_IN_WHEN, "'break' and 'continue' are not allowed in 'when' statements. Consider using labels to continue/break from the outer loop");
451            MAP.put(BREAK_OR_CONTINUE_JUMPS_ACROSS_FUNCTION_BOUNDARY, "'break' or 'continue' jumps across a function boundary");
452            MAP.put(NOT_A_LOOP_LABEL, "The label ''{0}'' does not denote a loop", STRING);
453            MAP.put(NOT_A_RETURN_LABEL, "The label ''{0}'' does not reference to a context from which we can return", STRING);
454    
455            MAP.put(ANONYMOUS_INITIALIZER_IN_TRAIT, "Anonymous initializers are not allowed in interfaces");
456            MAP.put(NULLABLE_SUPERTYPE, "A supertype cannot be nullable");
457            MAP.put(DYNAMIC_SUPERTYPE, "A supertype cannot be dynamic");
458            MAP.put(REDUNDANT_NULLABLE, "Redundant '?'");
459            MAP.put(BASE_WITH_NULLABLE_UPPER_BOUND, "''{0}'' has a nullable upper bound. " +
460                                                    "This means that a value of this type may be null. " +
461                                                    "Using ''{0}?'' is likely to mislead the reader", RENDER_TYPE);
462            MAP.put(UNSAFE_CALL, "Only safe (?.) or non-null asserted (!!.) calls are allowed on a nullable receiver of type {0}", RENDER_TYPE);
463            MAP.put(AMBIGUOUS_LABEL, "Ambiguous label");
464            MAP.put(UNSUPPORTED, "Unsupported [{0}]", STRING);
465            MAP.put(EXCEPTION_FROM_ANALYZER, "Internal Error occurred while analyzing this expression:\n{0}", THROWABLE);
466            MAP.put(UNNECESSARY_SAFE_CALL, "Unnecessary safe call on a non-null receiver of type {0}", RENDER_TYPE);
467            MAP.put(UNNECESSARY_NOT_NULL_ASSERTION, "Unnecessary non-null assertion (!!) on a non-null receiver of type {0}", RENDER_TYPE);
468            MAP.put(NOT_NULL_ASSERTION_ON_FUNCTION_LITERAL, "Non-null assertion (!!) is called on function literal");
469            MAP.put(NAME_IN_CONSTRAINT_IS_NOT_A_TYPE_PARAMETER, "{0} does not refer to a type parameter of {1}", new Renderer<JetTypeConstraint>() {
470                @NotNull
471                @Override
472                public String render(@NotNull JetTypeConstraint typeConstraint) {
473                    //noinspection ConstantConditions
474                    return typeConstraint.getSubjectTypeParameterName().getReferencedName();
475                }
476            }, DECLARATION_NAME);
477            MAP.put(SMARTCAST_IMPOSSIBLE,
478                    "Smart cast to ''{0}'' is impossible, because ''{1}'' could have changed since the is-check", RENDER_TYPE, STRING);
479    
480            MAP.put(MISSING_CONSTRUCTOR_KEYWORD, "Use 'constructor' keyword after modifiers of primary constructor");
481    
482            MAP.put(VARIANCE_ON_TYPE_PARAMETER_OF_FUNCTION_OR_PROPERTY, "Variance annotations are only allowed for type parameters of classes and interfaces");
483            MAP.put(TYPE_VARIANCE_CONFLICT, "Type parameter {0} is declared as ''{1}'' but occurs in ''{2}'' position in type {3}",
484                    new MultiRenderer<VarianceConflictDiagnosticData>() {
485                        @NotNull
486                        @Override
487                        public String[] render(@NotNull VarianceConflictDiagnosticData data) {
488                            return new String[] {
489                                NAME.render(data.getTypeParameter()),
490                                RENDER_POSITION_VARIANCE.render(data.getTypeParameter().getVariance()),
491                                RENDER_POSITION_VARIANCE.render(data.getOccurrencePosition()),
492                                RENDER_TYPE.render(data.getContainingType())
493                            };
494                        }
495                    });
496    
497            MAP.put(REDUNDANT_PROJECTION, "Projection is redundant: the corresponding type parameter of {0} has the same variance", NAME);
498            MAP.put(CONFLICTING_PROJECTION, "Projection is conflicting with variance of the corresponding type parameter of {0}. Remove the projection or replace it with ''*''", NAME);
499    
500            MAP.put(TYPE_MISMATCH_IN_FOR_LOOP, "The loop iterates over values of type {0} but the parameter is declared to be {1}", RENDER_TYPE,
501                    RENDER_TYPE);
502            MAP.put(TYPE_MISMATCH_IN_CONDITION, "Condition must be of type kotlin.Boolean, but is of type {0}", RENDER_TYPE);
503            MAP.put(INCOMPATIBLE_TYPES, "Incompatible types: {0} and {1}", RENDER_TYPE, RENDER_TYPE);
504            MAP.put(EXPECTED_CONDITION, "Expected condition of type kotlin.Boolean");
505    
506            MAP.put(CANNOT_CHECK_FOR_ERASED, "Cannot check for instance of erased type: {0}", RENDER_TYPE);
507            MAP.put(UNCHECKED_CAST, "Unchecked cast: {0} to {1}", RENDER_TYPE, RENDER_TYPE);
508    
509            MAP.put(INCONSISTENT_TYPE_PARAMETER_VALUES, "Type parameter {0} of ''{1}'' has inconsistent values: {2}", NAME, NAME, RENDER_COLLECTION_OF_TYPES);
510    
511            MAP.put(EQUALITY_NOT_APPLICABLE, "Operator ''{0}'' cannot be applied to ''{1}'' and ''{2}''", new Renderer<JetSimpleNameExpression>() {
512                @NotNull
513                @Override
514                public String render(@NotNull JetSimpleNameExpression nameExpression) {
515                    //noinspection ConstantConditions
516                    return nameExpression.getReferencedName();
517                }
518            }, RENDER_TYPE, RENDER_TYPE);
519    
520            MAP.put(SENSELESS_COMPARISON, "Condition ''{0}'' is always ''{1}''", ELEMENT_TEXT, TO_STRING);
521            MAP.put(SENSELESS_NULL_IN_WHEN, "Expression under 'when' is never equal to null");
522    
523            MAP.put(OVERRIDING_FINAL_MEMBER, "''{0}'' in ''{1}'' is final and cannot be overridden", NAME, NAME);
524            MAP.put(CANNOT_WEAKEN_ACCESS_PRIVILEGE, "Cannot weaken access privilege ''{0}'' for ''{1}'' in ''{2}''", TO_STRING, NAME, NAME);
525            MAP.put(CANNOT_CHANGE_ACCESS_PRIVILEGE, "Cannot change access privilege ''{0}'' for ''{1}'' in ''{2}''", TO_STRING, NAME, NAME);
526    
527            MAP.put(RETURN_TYPE_MISMATCH_ON_OVERRIDE, "Return type of ''{0}'' is not a subtype of the return type of the overridden member ''{1}''",
528                    NAME, FQ_NAMES_IN_TYPES);
529    
530            MAP.put(PROPERTY_TYPE_MISMATCH_ON_OVERRIDE, "Type of ''{0}'' doesn''t match the type of the overridden var-property ''{1}''",
531                    NAME, FQ_NAMES_IN_TYPES);
532    
533            MAP.put(VAR_OVERRIDDEN_BY_VAL, "Var-property {0} cannot be overridden by val-property {1}", FQ_NAMES_IN_TYPES, FQ_NAMES_IN_TYPES);
534    
535            MAP.put(ABSTRACT_MEMBER_NOT_IMPLEMENTED, "{0} must be declared abstract or implement abstract member {1}", RENDER_CLASS_OR_OBJECT,
536                    FQ_NAMES_IN_TYPES);
537    
538            MAP.put(MANY_IMPL_MEMBER_NOT_IMPLEMENTED, "{0} must override {1} because it inherits many implementations of it",
539                    RENDER_CLASS_OR_OBJECT, FQ_NAMES_IN_TYPES);
540    
541            MAP.put(CONFLICTING_OVERLOADS, "''{0}'' is already defined in {1}", COMPACT_WITH_MODIFIERS, STRING);
542    
543            MAP.put(FUNCTION_EXPECTED, "Expression ''{0}''{1} cannot be invoked as a function. " +
544                                       "The function '" + OperatorConventions.INVOKE.asString() + "()' is not found",
545                    ELEMENT_TEXT, new Renderer<JetType>() {
546                        @NotNull
547                        @Override
548                        public String render(@NotNull JetType type) {
549                            if (type.isError()) return "";
550                            return " of type '" + RENDER_TYPE.render(type) + "'";
551                        }
552                    });
553            MAP.put(FUNCTION_CALL_EXPECTED, "Function invocation ''{0}({1})'' expected", ELEMENT_TEXT, new Renderer<Boolean>() {
554                @NotNull
555                @Override
556                public String render(@NotNull Boolean hasValueParameters) {
557                    return hasValueParameters ? "..." : "";
558                }
559            });
560            MAP.put(NON_TAIL_RECURSIVE_CALL, "Recursive call is not a tail call");
561            MAP.put(TAIL_RECURSION_IN_TRY_IS_NOT_SUPPORTED, "Tail recursion optimization inside try/catch/finally is not supported");
562    
563            MAP.put(RESULT_TYPE_MISMATCH, "{0} must return {1} but returns {2}", STRING, RENDER_TYPE, RENDER_TYPE);
564            MAP.put(UNSAFE_INFIX_CALL,
565                    "Infix call corresponds to a dot-qualified call ''{0}.{1}({2})'' which is not allowed on a nullable receiver ''{0}''. " +
566                    "Use '?.'-qualified call instead",
567                    STRING, STRING, STRING);
568    
569            MAP.put(OVERLOAD_RESOLUTION_AMBIGUITY, "Overload resolution ambiguity: {0}", AMBIGUOUS_CALLS);
570            MAP.put(NONE_APPLICABLE, "None of the following functions can be called with the arguments supplied: {0}", AMBIGUOUS_CALLS);
571            MAP.put(CANNOT_COMPLETE_RESOLVE, "Cannot choose among the following candidates without completing type inference: {0}", AMBIGUOUS_CALLS);
572            MAP.put(UNRESOLVED_REFERENCE_WRONG_RECEIVER, "Unresolved reference. None of the following candidates is applicable because of receiver type mismatch: {0}", AMBIGUOUS_CALLS);
573    
574            MAP.put(NO_VALUE_FOR_PARAMETER, "No value passed for parameter {0}", NAME);
575            MAP.put(MISSING_RECEIVER, "A receiver of type {0} is required", RENDER_TYPE);
576            MAP.put(NO_RECEIVER_ALLOWED, "No receiver can be passed to this function or property");
577    
578            MAP.put(FREE_FUNCTION_CALLED_AS_EXTENSION, "The function cannot be called as an extension function");
579    
580            MAP.put(CREATING_AN_INSTANCE_OF_ABSTRACT_CLASS, "Cannot create an instance of an abstract class");
581    
582            MAP.put(TYPE_INFERENCE_CONFLICTING_SUBSTITUTIONS, "Type inference failed: {0}", TYPE_INFERENCE_CONFLICTING_SUBSTITUTIONS_RENDERER);
583            MAP.put(TYPE_INFERENCE_CANNOT_CAPTURE_TYPES, "Type inference failed: {0}", TYPE_INFERENCE_CANNOT_CAPTURE_TYPES_RENDERER);
584            MAP.put(TYPE_INFERENCE_NO_INFORMATION_FOR_PARAMETER, "Type inference failed: {0}", TYPE_INFERENCE_NO_INFORMATION_FOR_PARAMETER_RENDERER);
585            MAP.put(TYPE_INFERENCE_PARAMETER_CONSTRAINT_ERROR, "Type inference failed: {0}", TYPE_INFERENCE_PARAMETER_CONSTRAINT_ERROR_RENDERER);
586            MAP.put(TYPE_INFERENCE_INCORPORATION_ERROR, "Type inference failed. Please try to specify type arguments explicitly.");
587            MAP.put(TYPE_INFERENCE_UPPER_BOUND_VIOLATED, "{0}", TYPE_INFERENCE_UPPER_BOUND_VIOLATED_RENDERER);
588            MAP.put(TYPE_INFERENCE_EXPECTED_TYPE_MISMATCH, "Type inference failed. Expected type mismatch: found: {1} required: {0}", RENDER_TYPE, RENDER_TYPE);
589    
590            MAP.put(WRONG_NUMBER_OF_TYPE_ARGUMENTS, "{0,choice,0#No type arguments|1#Type argument|1<{0,number,integer} type arguments} expected", (Renderer) null);
591            MAP.put(NO_TYPE_ARGUMENTS_ON_RHS, "{0,choice,0#No type arguments|1#Type argument|1<{0,number,integer} type arguments} expected. " +
592                                                               "Use ''{1}'' if you don''t want to pass type arguments", null, STRING);
593    
594            MAP.put(TYPE_PARAMETER_AS_REIFIED, "Cannot use ''{0}'' as reified type parameter. Use a class instead.", NAME);
595            MAP.put(REIFIED_TYPE_PARAMETER_NO_INLINE, "Only type parameters of inline functions can be reified");
596            MAP.put(REIFIED_TYPE_FORBIDDEN_SUBSTITUTION, "Cannot use ''{0}'' as reified type parameter", RENDER_TYPE);
597            MAP.put(TYPE_PARAMETERS_NOT_ALLOWED, "Type parameters are not allowed here");
598    
599            MAP.put(SUPERTYPES_FOR_ANNOTATION_CLASS, "Annotation class cannot have supertypes");
600            MAP.put(MISSING_VAL_ON_ANNOTATION_PARAMETER, "'val' keyword is missing on annotation parameter");
601            MAP.put(ANNOTATION_CLASS_CONSTRUCTOR_CALL, "Annotation class cannot be instantiated");
602            MAP.put(NOT_AN_ANNOTATION_CLASS, "''{0}'' is not an annotation class", NAME);
603            MAP.put(ANNOTATION_CLASS_WITH_BODY, "Body is not allowed for annotation class");
604            MAP.put(INVALID_TYPE_OF_ANNOTATION_MEMBER, "Invalid type of annotation member");
605            MAP.put(NULLABLE_TYPE_OF_ANNOTATION_MEMBER, "An annotation parameter cannot be nullable");
606            MAP.put(ANNOTATION_PARAMETER_MUST_BE_CONST, "An annotation parameter must be a compile-time constant");
607            MAP.put(ANNOTATION_PARAMETER_MUST_BE_ENUM_CONST, "An enum annotation parameter must be a enum constant");
608            MAP.put(ANNOTATION_PARAMETER_MUST_BE_KCLASS_LITERAL, "An annotation parameter must be a class literal (T::class)");
609            MAP.put(ANNOTATION_PARAMETER_DEFAULT_VALUE_MUST_BE_CONSTANT, "Default value of annotation parameter must be a compile-time constant");
610    
611            MAP.put(CONST_VAL_NOT_TOP_LEVEL_OR_OBJECT, "Const 'val' are only allowed on top level or in objects");
612            MAP.put(CONST_VAL_WITH_DELEGATE, "Const 'val' should not have a delegate");
613            MAP.put(CONST_VAL_WITH_GETTER, "Const 'val' should not have a getter");
614            MAP.put(TYPE_CANT_BE_USED_FOR_CONST_VAL, "Const 'val' has type ''{0}''. Only primitives and String are allowed", RENDER_TYPE);
615            MAP.put(CONST_VAL_WITHOUT_INITIALIZER, "Const 'val' should have an initializer");
616            MAP.put(CONST_VAL_WITH_NON_CONST_INITIALIZER, "Const 'val' initializer should be a constant value");
617            MAP.put(NON_CONST_VAL_USED_IN_CONSTANT_EXPRESSION, "Only 'const val' can be used in constant expressions");
618    
619            MAP.put(DEFAULT_VALUE_NOT_ALLOWED_IN_OVERRIDE, "An overriding function is not allowed to specify default values for its parameters");
620    
621    
622            String multipleDefaultsMessage = "More than one overridden descriptor declares a default value for ''{0}''. " +
623                                             "As the compiler can not make sure these values agree, this is not allowed.";
624            MAP.put(MULTIPLE_DEFAULTS_INHERITED_FROM_SUPERTYPES, multipleDefaultsMessage, FQ_NAMES_IN_TYPES);
625            MAP.put(MULTIPLE_DEFAULTS_INHERITED_FROM_SUPERTYPES_WHEN_NO_EXPLICIT_OVERRIDE, multipleDefaultsMessage, FQ_NAMES_IN_TYPES);
626    
627            MAP.put(PARAMETER_NAME_CHANGED_ON_OVERRIDE, "The corresponding parameter in the supertype ''{0}'' is named ''{1}''. " +
628                                                        "This may cause problems when calling this function with named arguments.", NAME, NAME);
629    
630            MAP.put(DIFFERENT_NAMES_FOR_THE_SAME_PARAMETER_IN_SUPERTYPES,
631                        "Names of the parameter #{1} conflict in the following members of supertypes: ''{0}''. " +
632                        "This may cause problems when calling this function with named arguments.", commaSeparated(FQ_NAMES_IN_TYPES), TO_STRING);
633    
634            MAP.put(DATA_CLASS_WITHOUT_PARAMETERS, "Data class without primary constructor parameters are deprecated");
635            MAP.put(DATA_CLASS_VARARG_PARAMETER, "Primary constructor vararg parameters are deprecated for data classes");
636            MAP.put(DATA_CLASS_NOT_PROPERTY_PARAMETER, "Primary constructor parameters without val / var are deprecated for data classes");
637    
638            MAP.put(AMBIGUOUS_ANONYMOUS_TYPE_INFERRED, "Right-hand side has anonymous type. Please specify type explicitly", TO_STRING);
639    
640            MAP.put(EXTENSION_IN_CLASS_REFERENCE_NOT_ALLOWED,
641                    "''{0}'' is a member and an extension at the same time. References to such elements are not allowed", NAME);
642            MAP.put(CALLABLE_REFERENCE_LHS_NOT_A_CLASS, "Left hand side of a callable reference cannot be a type parameter");
643    
644            MAP.put(CLASS_LITERAL_LHS_NOT_A_CLASS, "Only classes are allowed on the left hand side of a class literal");
645            MAP.put(ARRAY_CLASS_LITERAL_REQUIRES_ARGUMENT, "kotlin.Array class literal requires a type argument, please specify one in angle brackets");
646    
647            //Inline
648            MAP.put(INVISIBLE_MEMBER_FROM_INLINE, "Cannot access effectively non-public-API ''{0}'' member from effectively public-API ''{1}''", SHORT_NAMES_IN_TYPES, SHORT_NAMES_IN_TYPES);
649            MAP.put(NOT_YET_SUPPORTED_IN_INLINE, "''{0}'' construction is not yet supported in inline functions", ELEMENT_TEXT, SHORT_NAMES_IN_TYPES);
650            MAP.put(DECLARATION_CANT_BE_INLINED, "''inline'' modifier is not allowed on virtual members. Only private or final members can be inlined");
651            MAP.put(NOTHING_TO_INLINE, "Expected performance impact of inlining ''{0}'' can be insignificant. Inlining works best for functions with lambda parameters", SHORT_NAMES_IN_TYPES);
652            MAP.put(USAGE_IS_NOT_INLINABLE, "Illegal usage of inline-parameter ''{0}'' in ''{1}''. Add ''noinline'' modifier to the parameter declaration", ELEMENT_TEXT, SHORT_NAMES_IN_TYPES);
653            MAP.put(NULLABLE_INLINE_PARAMETER, "Inline-parameter ''{0}'' of ''{1}'' must not be nullable. Add ''noinline'' modifier to the parameter declaration or make its type not nullable", ELEMENT_TEXT, SHORT_NAMES_IN_TYPES);
654            MAP.put(RECURSION_IN_INLINE, "Inline function ''{1}'' can't be recursive", ELEMENT_TEXT, SHORT_NAMES_IN_TYPES);
655            //Inline non locals
656            MAP.put(NON_LOCAL_RETURN_NOT_ALLOWED, "Can''t inline ''{0}'' here: it may contain non-local returns. Add ''crossinline'' modifier to parameter declaration ''{0}''", ELEMENT_TEXT, SHORT_NAMES_IN_TYPES, SHORT_NAMES_IN_TYPES);
657            MAP.put(INLINE_CALL_CYCLE, "The ''{0}'' invocation is a part of inline cycle", NAME);
658            MAP.put(NON_LOCAL_RETURN_IN_DISABLED_INLINE, "Non-local returns are not allowed with inlining disabled");
659            MAP.put(ACCESS_TO_PRIVATE_TOP_LEVEL_FROM_ANOTHER_FILE, "Cannot access ''{0}'': it is ''{1}'' in ''{2}''", NAME, TO_STRING, RENDER_FILE);
660    
661            MAP.setImmutable();
662    
663            for (Field field : Errors.class.getFields()) {
664                if (Modifier.isStatic(field.getModifiers())) {
665                    try {
666                        Object fieldValue = field.get(null);
667                        if (fieldValue instanceof DiagnosticFactory) {
668                            if (MAP.get((DiagnosticFactory<?>) fieldValue) == null) {
669                                throw new IllegalStateException("No default diagnostic renderer is provided for " + ((DiagnosticFactory<?>)fieldValue).getName());
670                            }
671                        }
672                    }
673                    catch (IllegalAccessException e) {
674                        throw new IllegalStateException(e);
675                    }
676                }
677            }
678        }
679    
680        private DefaultErrorMessages() {
681        }
682    }