| // This code was auto-generated, is not intended to be edited, and is subject to |
| // significant change. Please see the README file for more information. |
| library engine.error; |
| import 'java_core.dart'; |
| import 'source.dart'; |
| import 'ast.dart' show ASTNode; |
| import 'scanner.dart' show Token; |
| /** |
| * Instances of the enumeration `ErrorSeverity` represent the severity of an [ErrorCode] |
| * . |
| * |
| * @coverage dart.engine.error |
| */ |
| class ErrorSeverity extends Enum<ErrorSeverity> { |
| |
| /** |
| * The severity representing a non-error. This is never used for any error code, but is useful for |
| * clients. |
| */ |
| static final ErrorSeverity NONE = new ErrorSeverity('NONE', 0, " ", "none"); |
| |
| /** |
| * The severity representing an informational level analysis issue. |
| */ |
| static final ErrorSeverity INFO = new ErrorSeverity('INFO', 1, "I", "info"); |
| |
| /** |
| * The severity representing a warning. Warnings can become errors if the `-Werror` command |
| * line flag is specified. |
| */ |
| static final ErrorSeverity WARNING = new ErrorSeverity('WARNING', 2, "W", "warning"); |
| |
| /** |
| * The severity representing an error. |
| */ |
| static final ErrorSeverity ERROR = new ErrorSeverity('ERROR', 3, "E", "error"); |
| static final List<ErrorSeverity> values = [NONE, INFO, WARNING, ERROR]; |
| |
| /** |
| * The name of the severity used when producing machine output. |
| */ |
| String machineCode; |
| |
| /** |
| * The name of the severity used when producing readable output. |
| */ |
| String displayName; |
| |
| /** |
| * Initialize a newly created severity with the given names. |
| * |
| * @param machineCode the name of the severity used when producing machine output |
| * @param displayName the name of the severity used when producing readable output |
| */ |
| ErrorSeverity(String name, int ordinal, String machineCode, String displayName) : super(name, ordinal) { |
| this.machineCode = machineCode; |
| this.displayName = displayName; |
| } |
| |
| /** |
| * Return the severity constant that represents the greatest severity. |
| * |
| * @param severity the severity being compared against |
| * @return the most sever of this or the given severity |
| */ |
| ErrorSeverity max(ErrorSeverity severity) => this.ordinal >= severity.ordinal ? this : severity; |
| } |
| /** |
| * Instances of the class `AnalysisErrorWithProperties` |
| */ |
| class AnalysisErrorWithProperties extends AnalysisError { |
| |
| /** |
| * The properties associated with this error. |
| */ |
| Map<ErrorProperty, Object> _propertyMap = new Map<ErrorProperty, Object>(); |
| |
| /** |
| * Initialize a newly created analysis error for the specified source. The error has no location |
| * information. |
| * |
| * @param source the source for which the exception occurred |
| * @param errorCode the error code to be associated with this error |
| * @param arguments the arguments used to build the error message |
| */ |
| AnalysisErrorWithProperties.con1(Source source, ErrorCode errorCode, List<Object> arguments) : super.con1(source, errorCode, arguments); |
| |
| /** |
| * Initialize a newly created analysis error for the specified source at the given location. |
| * |
| * @param source the source for which the exception occurred |
| * @param offset the offset of the location of the error |
| * @param length the length of the location of the error |
| * @param errorCode the error code to be associated with this error |
| * @param arguments the arguments used to build the error message |
| */ |
| AnalysisErrorWithProperties.con2(Source source, int offset, int length, ErrorCode errorCode, List<Object> arguments) : super.con2(source, offset, length, errorCode, arguments); |
| Object getProperty(ErrorProperty property) => _propertyMap[property]; |
| |
| /** |
| * Set the value of the given property to the given value. Using a value of `null` will |
| * effectively remove the property from this error. |
| * |
| * @param property the property whose value is to be returned |
| * @param value the new value of the given property |
| */ |
| void setProperty(ErrorProperty property, Object value) { |
| _propertyMap[property] = value; |
| } |
| } |
| /** |
| * Instances of the class `ErrorReporter` wrap an error listener with utility methods used to |
| * create the errors being reported. |
| * |
| * @coverage dart.engine.error |
| */ |
| class ErrorReporter { |
| |
| /** |
| * The error listener to which errors will be reported. |
| */ |
| AnalysisErrorListener _errorListener; |
| |
| /** |
| * The default source to be used when reporting errors. |
| */ |
| Source _defaultSource; |
| |
| /** |
| * The source to be used when reporting errors. |
| */ |
| Source _source; |
| |
| /** |
| * Initialize a newly created error reporter that will report errors to the given listener. |
| * |
| * @param errorListener the error listener to which errors will be reported |
| * @param defaultSource the default source to be used when reporting errors |
| */ |
| ErrorReporter(AnalysisErrorListener errorListener, Source defaultSource) { |
| if (errorListener == null) { |
| throw new IllegalArgumentException("An error listener must be provided"); |
| } else if (defaultSource == null) { |
| throw new IllegalArgumentException("A default source must be provided"); |
| } |
| this._errorListener = errorListener; |
| this._defaultSource = defaultSource; |
| this._source = defaultSource; |
| } |
| |
| /** |
| * Creates an error with properties with the given error code and arguments. |
| * |
| * @param errorCode the error code of the error to be reported |
| * @param node the node specifying the location of the error |
| * @param arguments the arguments to the error, used to compose the error message |
| */ |
| AnalysisErrorWithProperties newErrorWithProperties(ErrorCode errorCode, ASTNode node, List<Object> arguments) => new AnalysisErrorWithProperties.con2(_source, node.offset, node.length, errorCode, arguments); |
| |
| /** |
| * Report a passed error. |
| * |
| * @param error the error to report |
| */ |
| void reportError(AnalysisError error) { |
| _errorListener.onError(error); |
| } |
| |
| /** |
| * Report an error with the given error code and arguments. |
| * |
| * @param errorCode the error code of the error to be reported |
| * @param node the node specifying the location of the error |
| * @param arguments the arguments to the error, used to compose the error message |
| */ |
| void reportError2(ErrorCode errorCode, ASTNode node, List<Object> arguments) { |
| reportError3(errorCode, node.offset, node.length, arguments); |
| } |
| |
| /** |
| * Report an error with the given error code and arguments. |
| * |
| * @param errorCode the error code of the error to be reported |
| * @param offset the offset of the location of the error |
| * @param length the length of the location of the error |
| * @param arguments the arguments to the error, used to compose the error message |
| */ |
| void reportError3(ErrorCode errorCode, int offset, int length, List<Object> arguments) { |
| _errorListener.onError(new AnalysisError.con2(_source, offset, length, errorCode, arguments)); |
| } |
| |
| /** |
| * Report an error with the given error code and arguments. |
| * |
| * @param errorCode the error code of the error to be reported |
| * @param token the token specifying the location of the error |
| * @param arguments the arguments to the error, used to compose the error message |
| */ |
| void reportError4(ErrorCode errorCode, Token token, List<Object> arguments) { |
| reportError3(errorCode, token.offset, token.length, arguments); |
| } |
| |
| /** |
| * Set the source to be used when reporting errors. Setting the source to `null` will cause |
| * the default source to be used. |
| * |
| * @param source the source to be used when reporting errors |
| */ |
| void set source(Source source) { |
| this._source = source == null ? _defaultSource : source; |
| } |
| } |
| /** |
| * Instances of the class `AnalysisError` represent an error discovered during the analysis of |
| * some Dart code. |
| * |
| * @see AnalysisErrorListener |
| * @coverage dart.engine.error |
| */ |
| class AnalysisError { |
| |
| /** |
| * An empty array of errors used when no errors are expected. |
| */ |
| static List<AnalysisError> NO_ERRORS = new List<AnalysisError>(0); |
| |
| /** |
| * A [Comparator] that sorts by the name of the file that the [AnalysisError] was |
| * found. |
| */ |
| static Comparator<AnalysisError> FILE_COMPARATOR = (AnalysisError o1, AnalysisError o2) => o1.source.shortName.compareTo(o2.source.shortName); |
| |
| /** |
| * A [Comparator] that sorts error codes first by their severity (errors first, warnings |
| * second), and then by the the error code type. |
| */ |
| static Comparator<AnalysisError> ERROR_CODE_COMPARATOR = (AnalysisError o1, AnalysisError o2) { |
| ErrorCode errorCode1 = o1.errorCode; |
| ErrorCode errorCode2 = o2.errorCode; |
| ErrorSeverity errorSeverity1 = errorCode1.errorSeverity; |
| ErrorSeverity errorSeverity2 = errorCode2.errorSeverity; |
| ErrorType errorType1 = errorCode1.type; |
| ErrorType errorType2 = errorCode2.type; |
| if (errorSeverity1 == errorSeverity2) { |
| return errorType1.compareTo(errorType2); |
| } else { |
| return errorSeverity2.compareTo(errorSeverity1); |
| } |
| }; |
| |
| /** |
| * The error code associated with the error. |
| */ |
| ErrorCode errorCode; |
| |
| /** |
| * The localized error message. |
| */ |
| String message; |
| |
| /** |
| * The correction to be displayed for this error, or `null` if there is no correction |
| * information for this error. |
| */ |
| String correction; |
| |
| /** |
| * The source in which the error occurred, or `null` if unknown. |
| */ |
| Source source; |
| |
| /** |
| * The character offset from the beginning of the source (zero based) where the error occurred. |
| */ |
| int offset = 0; |
| |
| /** |
| * The number of characters from the offset to the end of the source which encompasses the |
| * compilation error. |
| */ |
| int length = 0; |
| |
| /** |
| * A flag indicating whether this error can be shown to be a non-issue because of the result of |
| * type propagation. |
| */ |
| bool isStaticOnly = false; |
| |
| /** |
| * Initialize a newly created analysis error for the specified source. The error has no location |
| * information. |
| * |
| * @param source the source for which the exception occurred |
| * @param errorCode the error code to be associated with this error |
| * @param arguments the arguments used to build the error message |
| */ |
| AnalysisError.con1(Source source, ErrorCode errorCode, List<Object> arguments) { |
| this.source = source; |
| this.errorCode = errorCode; |
| this.message = JavaString.format(errorCode.message, arguments); |
| } |
| |
| /** |
| * Initialize a newly created analysis error for the specified source at the given location. |
| * |
| * @param source the source for which the exception occurred |
| * @param offset the offset of the location of the error |
| * @param length the length of the location of the error |
| * @param errorCode the error code to be associated with this error |
| * @param arguments the arguments used to build the error message |
| */ |
| AnalysisError.con2(Source source, int offset, int length, ErrorCode errorCode, List<Object> arguments) { |
| this.source = source; |
| this.offset = offset; |
| this.length = length; |
| this.errorCode = errorCode; |
| this.message = JavaString.format(errorCode.message, arguments); |
| String correctionTemplate = errorCode.correction; |
| if (correctionTemplate != null) { |
| this.correction = JavaString.format(correctionTemplate, arguments); |
| } |
| } |
| |
| /** |
| * Return the value of the given property, or `null` if the given property is not defined |
| * for this error. |
| * |
| * @param property the property whose value is to be returned |
| * @return the value of the given property |
| */ |
| Object getProperty(ErrorProperty property) => null; |
| int get hashCode { |
| int hashCode = offset; |
| hashCode ^= (message != null) ? message.hashCode : 0; |
| hashCode ^= (source != null) ? source.hashCode : 0; |
| return hashCode; |
| } |
| String toString() { |
| JavaStringBuilder builder = new JavaStringBuilder(); |
| builder.append((source != null) ? source.fullName : "<unknown source>"); |
| builder.append("("); |
| builder.append(offset); |
| builder.append(".."); |
| builder.append(offset + length - 1); |
| builder.append("): "); |
| builder.append(message); |
| return builder.toString(); |
| } |
| } |
| /** |
| * The enumeration `ErrorProperty` defines the properties that can be associated with an |
| * [AnalysisError]. |
| */ |
| class ErrorProperty extends Enum<ErrorProperty> { |
| |
| /** |
| * A property whose value is an array of [ExecutableElement] that should |
| * be but are not implemented by a concrete class. |
| */ |
| static final ErrorProperty UNIMPLEMENTED_METHODS = new ErrorProperty('UNIMPLEMENTED_METHODS', 0); |
| static final List<ErrorProperty> values = [UNIMPLEMENTED_METHODS]; |
| ErrorProperty(String name, int ordinal) : super(name, ordinal); |
| } |
| /** |
| * The enumeration `TodoCode` defines the single TODO `ErrorCode`. |
| */ |
| class TodoCode extends Enum<TodoCode> implements ErrorCode { |
| |
| /** |
| * The single enum of TodoCode. |
| */ |
| static final TodoCode TODO = new TodoCode('TODO', 0); |
| static final List<TodoCode> values = [TODO]; |
| |
| /** |
| * This matches the two common Dart task styles |
| * |
| * * TODO: |
| * * TODO(username): |
| * |
| * As well as |
| * * TODO |
| * |
| * But not |
| * * todo |
| * * TODOS |
| */ |
| static RegExp TODO_REGEX = new RegExp("([\\s/\\*])((TODO[^\\w\\d][^\\r\\n]*)|(TODO:?\$))"); |
| TodoCode(String name, int ordinal) : super(name, ordinal); |
| String get correction => null; |
| ErrorSeverity get errorSeverity => ErrorSeverity.INFO; |
| String get message => "%s"; |
| ErrorType get type => ErrorType.TODO; |
| } |
| /** |
| * The enumeration `HintCode` defines the hints and coding recommendations for best practices |
| * which are not mentioned in the Dart Language Specification. |
| */ |
| class HintCode extends Enum<HintCode> implements ErrorCode { |
| |
| /** |
| * Dead code is code that is never reached, this can happen for instance if a statement follows a |
| * return statement. |
| */ |
| static final HintCode DEAD_CODE = new HintCode.con1('DEAD_CODE', 0, "Dead code"); |
| |
| /** |
| * Dead code is code that is never reached. This case covers cases where the user has catch |
| * clauses after `catch (e)` or `on Object catch (e)`. |
| */ |
| static final HintCode DEAD_CODE_CATCH_FOLLOWING_CATCH = new HintCode.con1('DEAD_CODE_CATCH_FOLLOWING_CATCH', 1, "Dead code, catch clauses after a 'catch (e)' or an 'on Object catch (e)' are never reached"); |
| |
| /** |
| * Dead code is code that is never reached. This case covers cases where the user has an on-catch |
| * clause such as `on A catch (e)`, where a supertype of `A` was already caught. |
| * |
| * @param subtypeName name of the subtype |
| * @param supertypeName name of the supertype |
| */ |
| static final HintCode DEAD_CODE_ON_CATCH_SUBTYPE = new HintCode.con1('DEAD_CODE_ON_CATCH_SUBTYPE', 2, "Dead code, this on-catch block will never be executed since '%s' is a subtype of '%s'"); |
| |
| /** |
| * Duplicate imports. |
| */ |
| static final HintCode DUPLICATE_IMPORT = new HintCode.con1('DUPLICATE_IMPORT', 3, "Duplicate import"); |
| |
| /** |
| * Hint to use the ~/ operator. |
| */ |
| static final HintCode DIVISION_OPTIMIZATION = new HintCode.con1('DIVISION_OPTIMIZATION', 4, "The operator x ~/ y is more efficient than (x / y).toInt()"); |
| |
| /** |
| * Hint for the `x is double` type checks. |
| */ |
| static final HintCode IS_DOUBLE = new HintCode.con1('IS_DOUBLE', 5, "When compiled to JS, this test might return true when the left hand side is an int"); |
| |
| /** |
| * Hint for the `x is int` type checks. |
| */ |
| static final HintCode IS_INT = new HintCode.con1('IS_INT', 6, "When compiled to JS, this test might return true when the left hand side is a double"); |
| |
| /** |
| * Hint for the `x is! double` type checks. |
| */ |
| static final HintCode IS_NOT_DOUBLE = new HintCode.con1('IS_NOT_DOUBLE', 7, "When compiled to JS, this test might return false when the left hand side is an int"); |
| |
| /** |
| * Hint for the `x is! int` type checks. |
| */ |
| static final HintCode IS_NOT_INT = new HintCode.con1('IS_NOT_INT', 8, "When compiled to JS, this test might return false when the left hand side is a double"); |
| |
| /** |
| * It is not in best practice to declare a private method that happens to override the method in a |
| * superclass- depending on where the superclass is (either in the same library, or out of the |
| * same library), behavior can be different. |
| * |
| * @param memberType this is either "method", "getter" or "setter" |
| * @param memberName some private member name |
| * @param className the class name where the member is overriding the functionality |
| */ |
| static final HintCode OVERRIDDING_PRIVATE_MEMBER = new HintCode.con1('OVERRIDDING_PRIVATE_MEMBER', 9, "The %s '%s' does not override the definition from '%s' because it is private and in a different library"); |
| |
| /** |
| * Hint for classes that override equals, but not hashCode. |
| * |
| * @param className the name of the current class |
| */ |
| static final HintCode OVERRIDE_EQUALS_BUT_NOT_HASH_CODE = new HintCode.con1('OVERRIDE_EQUALS_BUT_NOT_HASH_CODE', 10, "The class '%s' overrides 'operator==', but not 'get hashCode'"); |
| |
| /** |
| * Type checks of the type `x is! Null` should be done with `x != null`. |
| */ |
| static final HintCode TYPE_CHECK_IS_NOT_NULL = new HintCode.con1('TYPE_CHECK_IS_NOT_NULL', 11, "Tests for non-null should be done with '!= null'"); |
| |
| /** |
| * Type checks of the type `x is Null` should be done with `x == null`. |
| */ |
| static final HintCode TYPE_CHECK_IS_NULL = new HintCode.con1('TYPE_CHECK_IS_NULL', 12, "Tests for null should be done with '== null'"); |
| |
| /** |
| * This hint is generated anywhere where the [StaticTypeWarningCode#UNDEFINED_GETTER] or |
| * [StaticWarningCode#UNDEFINED_GETTER] would have been generated, if we used propagated |
| * information for the warnings. |
| * |
| * @param getterName the name of the getter |
| * @param enclosingType the name of the enclosing type where the getter is being looked for |
| * @see StaticTypeWarningCode#UNDEFINED_GETTER |
| * @see StaticWarningCode#UNDEFINED_GETTER |
| */ |
| static final HintCode UNDEFINED_GETTER = new HintCode.con1('UNDEFINED_GETTER', 13, StaticTypeWarningCode.UNDEFINED_GETTER.message); |
| |
| /** |
| * This hint is generated anywhere where the [StaticTypeWarningCode#UNDEFINED_METHOD] would |
| * have been generated, if we used propagated information for the warnings. |
| * |
| * @param methodName the name of the method that is undefined |
| * @param typeName the resolved type name that the method lookup is happening on |
| * @see StaticTypeWarningCode#UNDEFINED_METHOD |
| */ |
| static final HintCode UNDEFINED_METHOD = new HintCode.con1('UNDEFINED_METHOD', 14, StaticTypeWarningCode.UNDEFINED_METHOD.message); |
| |
| /** |
| * This hint is generated anywhere where the [StaticTypeWarningCode#UNDEFINED_OPERATOR] |
| * would have been generated, if we used propagated information for the warnings. |
| * |
| * @param operator the name of the operator |
| * @param enclosingType the name of the enclosing type where the operator is being looked for |
| * @see StaticTypeWarningCode#UNDEFINED_OPERATOR |
| */ |
| static final HintCode UNDEFINED_OPERATOR = new HintCode.con1('UNDEFINED_OPERATOR', 15, StaticTypeWarningCode.UNDEFINED_OPERATOR.message); |
| |
| /** |
| * This hint is generated anywhere where the [StaticTypeWarningCode#UNDEFINED_SETTER] or |
| * [StaticWarningCode#UNDEFINED_SETTER] would have been generated, if we used propagated |
| * information for the warnings. |
| * |
| * @param setterName the name of the setter |
| * @param enclosingType the name of the enclosing type where the setter is being looked for |
| * @see StaticTypeWarningCode#UNDEFINED_SETTER |
| * @see StaticWarningCode#UNDEFINED_SETTER |
| */ |
| static final HintCode UNDEFINED_SETTER = new HintCode.con1('UNDEFINED_SETTER', 16, StaticTypeWarningCode.UNDEFINED_SETTER.message); |
| |
| /** |
| * Unnecessary cast. |
| */ |
| static final HintCode UNNECESSARY_CAST = new HintCode.con1('UNNECESSARY_CAST', 17, "Unnecessary cast"); |
| |
| /** |
| * Unnecessary type checks, the result is always true. |
| */ |
| static final HintCode UNNECESSARY_TYPE_CHECK_FALSE = new HintCode.con1('UNNECESSARY_TYPE_CHECK_FALSE', 18, "Unnecessary type check, the result is always false"); |
| |
| /** |
| * Unnecessary type checks, the result is always false. |
| */ |
| static final HintCode UNNECESSARY_TYPE_CHECK_TRUE = new HintCode.con1('UNNECESSARY_TYPE_CHECK_TRUE', 19, "Unnecessary type check, the result is always true"); |
| |
| /** |
| * Unused imports are imports which are never not used. |
| */ |
| static final HintCode UNUSED_IMPORT = new HintCode.con1('UNUSED_IMPORT', 20, "Unused import"); |
| static final List<HintCode> values = [ |
| DEAD_CODE, |
| DEAD_CODE_CATCH_FOLLOWING_CATCH, |
| DEAD_CODE_ON_CATCH_SUBTYPE, |
| DUPLICATE_IMPORT, |
| DIVISION_OPTIMIZATION, |
| IS_DOUBLE, |
| IS_INT, |
| IS_NOT_DOUBLE, |
| IS_NOT_INT, |
| OVERRIDDING_PRIVATE_MEMBER, |
| OVERRIDE_EQUALS_BUT_NOT_HASH_CODE, |
| TYPE_CHECK_IS_NOT_NULL, |
| TYPE_CHECK_IS_NULL, |
| UNDEFINED_GETTER, |
| UNDEFINED_METHOD, |
| UNDEFINED_OPERATOR, |
| UNDEFINED_SETTER, |
| UNNECESSARY_CAST, |
| UNNECESSARY_TYPE_CHECK_FALSE, |
| UNNECESSARY_TYPE_CHECK_TRUE, |
| UNUSED_IMPORT]; |
| |
| /** |
| * The template used to create the message to be displayed for this error. |
| */ |
| String _message; |
| |
| /** |
| * The template used to create the correction to be displayed for this error, or `null` if |
| * there is no correction information for this error. |
| */ |
| String correction3; |
| |
| /** |
| * Initialize a newly created error code to have the given message. |
| * |
| * @param message the message template used to create the message to be displayed for the error |
| */ |
| HintCode.con1(String name, int ordinal, String message) : super(name, ordinal) { |
| this._message = message; |
| } |
| |
| /** |
| * Initialize a newly created error code to have the given message and correction. |
| * |
| * @param message the template used to create the message to be displayed for the error |
| * @param correction the template used to create the correction to be displayed for the error |
| */ |
| HintCode.con2(String name, int ordinal, String message, String correction) : super(name, ordinal) { |
| this._message = message; |
| this.correction3 = correction; |
| } |
| String get correction => correction3; |
| ErrorSeverity get errorSeverity => ErrorType.HINT.severity; |
| String get message => _message; |
| ErrorType get type => ErrorType.HINT; |
| } |
| /** |
| * The interface `ErrorCode` defines the behavior common to objects representing error codes |
| * associated with [AnalysisError]. |
| * |
| * Generally, we want to provide messages that consist of three sentences: 1. what is wrong, 2. why |
| * is it wrong, and 3. how do I fix it. However, we combine the first two in the result of |
| * [getMessage] and the last in the result of [getCorrection]. |
| * |
| * @coverage dart.engine.error |
| */ |
| abstract class ErrorCode { |
| |
| /** |
| * Return the template used to create the correction to be displayed for this error, or |
| * `null` if there is no correction information for this error. The correction should |
| * indicate how the user can fix the error. |
| * |
| * @return the template used to create the correction to be displayed for this error |
| */ |
| String get correction; |
| |
| /** |
| * Return the severity of this error. |
| * |
| * @return the severity of this error |
| */ |
| ErrorSeverity get errorSeverity; |
| |
| /** |
| * Return the template used to create the message to be displayed for this error. The message |
| * should indicate what is wrong and why it is wrong. |
| * |
| * @return the template used to create the message to be displayed for this error |
| */ |
| String get message; |
| |
| /** |
| * Return the type of the error. |
| * |
| * @return the type of the error |
| */ |
| ErrorType get type; |
| } |
| /** |
| * Instances of the enumeration `ErrorType` represent the type of an [ErrorCode]. |
| * |
| * @coverage dart.engine.error |
| */ |
| class ErrorType extends Enum<ErrorType> { |
| |
| /** |
| * Task (todo) comments in user code. |
| */ |
| static final ErrorType TODO = new ErrorType('TODO', 0, ErrorSeverity.INFO); |
| |
| /** |
| * Extra analysis run over the code to follow best practices, which are not in the Dart Language |
| * Specification. |
| */ |
| static final ErrorType HINT = new ErrorType('HINT', 1, ErrorSeverity.WARNING); |
| |
| /** |
| * Compile-time errors are errors that preclude execution. A compile time error must be reported |
| * by a Dart compiler before the erroneous code is executed. |
| */ |
| static final ErrorType COMPILE_TIME_ERROR = new ErrorType('COMPILE_TIME_ERROR', 2, ErrorSeverity.ERROR); |
| |
| /** |
| * Suggestions made in situations where the user has deviated from recommended pub programming |
| * practices. |
| */ |
| static final ErrorType PUB_SUGGESTION = new ErrorType('PUB_SUGGESTION', 3, ErrorSeverity.WARNING); |
| |
| /** |
| * Static warnings are those warnings reported by the static checker. They have no effect on |
| * execution. Static warnings must be provided by Dart compilers used during development. |
| */ |
| static final ErrorType STATIC_WARNING = new ErrorType('STATIC_WARNING', 4, ErrorSeverity.WARNING); |
| |
| /** |
| * Many, but not all, static warnings relate to types, in which case they are known as static type |
| * warnings. |
| */ |
| static final ErrorType STATIC_TYPE_WARNING = new ErrorType('STATIC_TYPE_WARNING', 5, ErrorSeverity.WARNING); |
| |
| /** |
| * Syntactic errors are errors produced as a result of input that does not conform to the grammar. |
| */ |
| static final ErrorType SYNTACTIC_ERROR = new ErrorType('SYNTACTIC_ERROR', 6, ErrorSeverity.ERROR); |
| static final List<ErrorType> values = [ |
| TODO, |
| HINT, |
| COMPILE_TIME_ERROR, |
| PUB_SUGGESTION, |
| STATIC_WARNING, |
| STATIC_TYPE_WARNING, |
| SYNTACTIC_ERROR]; |
| |
| /** |
| * The severity of this type of error. |
| */ |
| ErrorSeverity severity; |
| |
| /** |
| * Initialize a newly created error type to have the given severity. |
| * |
| * @param severity the severity of this type of error |
| */ |
| ErrorType(String name, int ordinal, ErrorSeverity severity) : super(name, ordinal) { |
| this.severity = severity; |
| } |
| String get displayName => name.toLowerCase().replaceAll('_', ' '); |
| } |
| /** |
| * The enumeration `CompileTimeErrorCode` defines the error codes used for compile time |
| * errors. The convention for this class is for the name of the error code to indicate the problem |
| * that caused the error to be generated and for the error message to explain what is wrong and, |
| * when appropriate, how the problem can be corrected. |
| * |
| * @coverage dart.engine.error |
| */ |
| class CompileTimeErrorCode extends Enum<CompileTimeErrorCode> implements ErrorCode { |
| |
| /** |
| * 14.2 Exports: It is a compile-time error if a name <i>N</i> is re-exported by a library |
| * <i>L</i> and <i>N</i> is introduced into the export namespace of <i>L</i> by more than one |
| * export. |
| * |
| * @param ambiguousElementName the name of the ambiguous element |
| * @param firstLibraryName the name of the first library that the type is found |
| * @param secondLibraryName the name of the second library that the type is found |
| */ |
| static final CompileTimeErrorCode AMBIGUOUS_EXPORT = new CompileTimeErrorCode.con1('AMBIGUOUS_EXPORT', 0, "The element '%s' is defined in the libraries '%s' and '%s'"); |
| |
| /** |
| * 12.33 Argument Definition Test: It is a compile time error if <i>v</i> does not denote a formal |
| * parameter. |
| * |
| * @param the name of the identifier in the argument definition test that is not a parameter |
| */ |
| static final CompileTimeErrorCode ARGUMENT_DEFINITION_TEST_NON_PARAMETER = new CompileTimeErrorCode.con1('ARGUMENT_DEFINITION_TEST_NON_PARAMETER', 1, "'%s' is not a parameter"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: In checked mode, it is a dynamic type error if |
| * <i>o<sub>i</sub></i> is not <b>null</b> and the actual type of <i>p<sub>i</sub></i> is not a |
| * supertype of the type of <i>o<sub>i</sub></i>, i = 1..m. |
| * |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| * |
| * @param requiredCount the maximum number of positional arguments |
| * @param argumentCount the actual number of positional arguments given |
| */ |
| static final CompileTimeErrorCode ARGUMENT_TYPE_NOT_ASSIGNABLE = new CompileTimeErrorCode.con1('ARGUMENT_TYPE_NOT_ASSIGNABLE', 2, "The argument type '%s' cannot be assigned to the parameter type '%s'"); |
| |
| /** |
| * 12.30 Identifier Reference: It is a compile-time error to use a built-in identifier other than |
| * dynamic as a type annotation. |
| */ |
| static final CompileTimeErrorCode BUILT_IN_IDENTIFIER_AS_TYPE = new CompileTimeErrorCode.con1('BUILT_IN_IDENTIFIER_AS_TYPE', 3, "The built-in identifier '%s' cannot be as a type"); |
| |
| /** |
| * 12.30 Identifier Reference: It is a compile-time error if a built-in identifier is used as the |
| * declared name of a class, type parameter or type alias. |
| */ |
| static final CompileTimeErrorCode BUILT_IN_IDENTIFIER_AS_TYPE_NAME = new CompileTimeErrorCode.con1('BUILT_IN_IDENTIFIER_AS_TYPE_NAME', 4, "The built-in identifier '%s' cannot be used as a type name"); |
| |
| /** |
| * 12.30 Identifier Reference: It is a compile-time error if a built-in identifier is used as the |
| * declared name of a class, type parameter or type alias. |
| */ |
| static final CompileTimeErrorCode BUILT_IN_IDENTIFIER_AS_TYPEDEF_NAME = new CompileTimeErrorCode.con1('BUILT_IN_IDENTIFIER_AS_TYPEDEF_NAME', 5, "The built-in identifier '%s' cannot be used as a type alias name"); |
| |
| /** |
| * 12.30 Identifier Reference: It is a compile-time error if a built-in identifier is used as the |
| * declared name of a class, type parameter or type alias. |
| */ |
| static final CompileTimeErrorCode BUILT_IN_IDENTIFIER_AS_TYPE_PARAMETER_NAME = new CompileTimeErrorCode.con1('BUILT_IN_IDENTIFIER_AS_TYPE_PARAMETER_NAME', 6, "The built-in identifier '%s' cannot be used as a type parameter name"); |
| |
| /** |
| * 13.9 Switch: It is a compile-time error if the class <i>C</i> implements the operator |
| * <i>==</i>. |
| */ |
| static final CompileTimeErrorCode CASE_EXPRESSION_TYPE_IMPLEMENTS_EQUALS = new CompileTimeErrorCode.con1('CASE_EXPRESSION_TYPE_IMPLEMENTS_EQUALS', 7, "The switch case expression type '%s' cannot override the == operator"); |
| |
| /** |
| * 12.1 Constants: It is a compile-time error if evaluation of a compile-time constant would raise |
| * an exception. |
| */ |
| static final CompileTimeErrorCode COMPILE_TIME_CONSTANT_RAISES_EXCEPTION = new CompileTimeErrorCode.con1('COMPILE_TIME_CONSTANT_RAISES_EXCEPTION', 8, ""); |
| |
| /** |
| * 7.2 Getters: It is a compile-time error if a class has both a getter and a method with the same |
| * name. This restriction holds regardless of whether the getter is defined explicitly or |
| * implicitly, or whether the getter or the method are inherited or not. |
| */ |
| static final CompileTimeErrorCode CONFLICTING_GETTER_AND_METHOD = new CompileTimeErrorCode.con1('CONFLICTING_GETTER_AND_METHOD', 9, "Class '%s' cannot have both getter '%s.%s' and method with the same name"); |
| |
| /** |
| * 7.2 Getters: It is a compile-time error if a class has both a getter and a method with the same |
| * name. This restriction holds regardless of whether the getter is defined explicitly or |
| * implicitly, or whether the getter or the method are inherited or not. |
| */ |
| static final CompileTimeErrorCode CONFLICTING_METHOD_AND_GETTER = new CompileTimeErrorCode.con1('CONFLICTING_METHOD_AND_GETTER', 10, "Class '%s' cannot have both method '%s.%s' and getter with the same name"); |
| |
| /** |
| * 7.6 Constructors: A constructor name always begins with the name of its immediately enclosing |
| * class, and may optionally be followed by a dot and an identifier <i>id</i>. It is a |
| * compile-time error if <i>id</i> is the name of a member declared in the immediately enclosing |
| * class. |
| */ |
| static final CompileTimeErrorCode CONFLICTING_CONSTRUCTOR_NAME_AND_FIELD = new CompileTimeErrorCode.con1('CONFLICTING_CONSTRUCTOR_NAME_AND_FIELD', 11, "'%s' cannot be used to name a constructor and a field in this class"); |
| |
| /** |
| * 7.6 Constructors: A constructor name always begins with the name of its immediately enclosing |
| * class, and may optionally be followed by a dot and an identifier <i>id</i>. It is a |
| * compile-time error if <i>id</i> is the name of a member declared in the immediately enclosing |
| * class. |
| */ |
| static final CompileTimeErrorCode CONFLICTING_CONSTRUCTOR_NAME_AND_METHOD = new CompileTimeErrorCode.con1('CONFLICTING_CONSTRUCTOR_NAME_AND_METHOD', 12, "'%s' cannot be used to name a constructor and a method in this class"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| */ |
| static final CompileTimeErrorCode CONST_CONSTRUCTOR_THROWS_EXCEPTION = new CompileTimeErrorCode.con1('CONST_CONSTRUCTOR_THROWS_EXCEPTION', 13, "'const' constructors cannot throw exceptions"); |
| |
| /** |
| * 7.6.3 Constant Constructors: The superinitializer that appears, explicitly or implicitly, in |
| * the initializer list of a constant constructor must specify a constant constructor of the |
| * superclass of the immediately enclosing class or a compile-time error occurs. |
| */ |
| static final CompileTimeErrorCode CONST_CONSTRUCTOR_WITH_NON_CONST_SUPER = new CompileTimeErrorCode.con1('CONST_CONSTRUCTOR_WITH_NON_CONST_SUPER', 14, "Constant constructor cannot call non-constant super constructor"); |
| |
| /** |
| * 7.6.3 Constant Constructors: It is a compile-time error if a constant constructor is declared |
| * by a class that has a non-final instance variable. |
| * |
| * The above refers to both locally declared and inherited instance variables. |
| */ |
| static final CompileTimeErrorCode CONST_CONSTRUCTOR_WITH_NON_FINAL_FIELD = new CompileTimeErrorCode.con1('CONST_CONSTRUCTOR_WITH_NON_FINAL_FIELD', 15, "Cannot define the 'const' constructor for a class with non-final fields"); |
| |
| /** |
| * 7.6.1 Generative Constructors: In checked mode, it is a dynamic type error if o is not |
| * <b>null</b> and the interface of the class of <i>o</i> is not a subtype of the static type of |
| * the field <i>v</i>. |
| * |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| * |
| * @param initializerType the name of the type of the initializer expression |
| * @param fieldType the name of the type of the field |
| */ |
| static final CompileTimeErrorCode CONST_FIELD_INITIALIZER_NOT_ASSIGNABLE = new CompileTimeErrorCode.con1('CONST_FIELD_INITIALIZER_NOT_ASSIGNABLE', 16, "The initializer type '%s' cannot be assigned to the field type '%s'"); |
| |
| /** |
| * 6.2 Formal Parameters: It is a compile-time error if a formal parameter is declared as a |
| * constant variable. |
| */ |
| static final CompileTimeErrorCode CONST_FORMAL_PARAMETER = new CompileTimeErrorCode.con1('CONST_FORMAL_PARAMETER', 17, "Parameters cannot be 'const'"); |
| |
| /** |
| * 5 Variables: A constant variable must be initialized to a compile-time constant or a |
| * compile-time error occurs. |
| */ |
| static final CompileTimeErrorCode CONST_INITIALIZED_WITH_NON_CONSTANT_VALUE = new CompileTimeErrorCode.con1('CONST_INITIALIZED_WITH_NON_CONSTANT_VALUE', 18, "'const' variables must be constant value"); |
| |
| /** |
| * 7.5 Instance Variables: It is a compile-time error if an instance variable is declared to be |
| * constant. |
| */ |
| static final CompileTimeErrorCode CONST_INSTANCE_FIELD = new CompileTimeErrorCode.con1('CONST_INSTANCE_FIELD', 19, "Only static fields can be declared as 'const'"); |
| |
| /** |
| * 5 Variables: A constant variable must be initialized to a compile-time constant (12.1) or a |
| * compile-time error occurs. |
| * |
| * @param name the name of the uninitialized final variable |
| */ |
| static final CompileTimeErrorCode CONST_NOT_INITIALIZED = new CompileTimeErrorCode.con1('CONST_NOT_INITIALIZED', 20, "The const variable '%s' must be initialized"); |
| |
| /** |
| * 12.11.2 Const: An expression of one of the forms !e, e1 && e2 or e1 || e2, where e, e1 and e2 |
| * are constant expressions that evaluate to a boolean value. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_TYPE_BOOL = new CompileTimeErrorCode.con1('CONST_EVAL_TYPE_BOOL', 21, "An expression of type 'bool' was expected"); |
| |
| /** |
| * 12.11.2 Const: An expression of one of the forms e1 == e2 or e1 != e2 where e1 and e2 are |
| * constant expressions that evaluate to a numeric, string or boolean value or to null. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_TYPE_BOOL_NUM_STRING = new CompileTimeErrorCode.con1('CONST_EVAL_TYPE_BOOL_NUM_STRING', 22, "An expression of type 'bool', 'num', 'String' or 'null' was expected"); |
| |
| /** |
| * 12.11.2 Const: An expression of one of the forms ~e, e1 ^ e2, e1 & e2, e1 | e2, e1 >> e2 or e1 |
| * << e2, where e, e1 and e2 are constant expressions that evaluate to an integer value or to |
| * null. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_TYPE_INT = new CompileTimeErrorCode.con1('CONST_EVAL_TYPE_INT', 23, "An expression of type 'int' was expected"); |
| |
| /** |
| * 12.11.2 Const: An expression of one of the forms e, e1 + e2, e1 - e2, e1 * e2, e1 / e2, e1 ~/ |
| * e2, e1 > e2, e1 < e2, e1 >= e2, e1 <= e2 or e1 % e2, where e, e1 and e2 are constant |
| * expressions that evaluate to a numeric value or to null.. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_TYPE_NUM = new CompileTimeErrorCode.con1('CONST_EVAL_TYPE_NUM', 24, "An expression of type 'num' was expected"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_THROWS_EXCEPTION = new CompileTimeErrorCode.con1('CONST_EVAL_THROWS_EXCEPTION', 25, "Evaluation of this constant expression causes exception"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| */ |
| static final CompileTimeErrorCode CONST_EVAL_THROWS_IDBZE = new CompileTimeErrorCode.con1('CONST_EVAL_THROWS_IDBZE', 26, "Evaluation of this constant expression throws IntegerDivisionByZeroException"); |
| |
| /** |
| * 12.11.2 Const: If <i>T</i> is a parameterized type <i>S<U<sub>1</sub>, …, |
| * U<sub>m</sub>></i>, let <i>R = S</i>; It is a compile time error if <i>S</i> is not a |
| * generic type with <i>m</i> type parameters. |
| * |
| * @param typeName the name of the type being referenced (<i>S</i>) |
| * @param parameterCount the number of type parameters that were declared |
| * @param argumentCount the number of type arguments provided |
| * @see CompileTimeErrorCode#NEW_WITH_INVALID_TYPE_PARAMETERS |
| * @see StaticTypeWarningCode#WRONG_NUMBER_OF_TYPE_ARGUMENTS |
| */ |
| static final CompileTimeErrorCode CONST_WITH_INVALID_TYPE_PARAMETERS = new CompileTimeErrorCode.con1('CONST_WITH_INVALID_TYPE_PARAMETERS', 27, "The type '%s' is declared with %d type parameters, but %d type arguments were given"); |
| |
| /** |
| * 12.11.2 Const: If <i>e</i> is of the form <i>const T(a<sub>1</sub>, …, a<sub>n</sub>, |
| * x<sub>n+1</sub>: a<sub>n+1</sub>, …, x<sub>n+k</sub>: a<sub>n+k</sub>)</i> it is a |
| * compile-time error if the type <i>T</i> does not declare a constant constructor with the same |
| * name as the declaration of <i>T</i>. |
| */ |
| static final CompileTimeErrorCode CONST_WITH_NON_CONST = new CompileTimeErrorCode.con1('CONST_WITH_NON_CONST', 28, "The constructor being called is not a 'const' constructor"); |
| |
| /** |
| * 12.11.2 Const: In all of the above cases, it is a compile-time error if <i>a<sub>i</sub>, 1 |
| * <= i <= n + k</i>, is not a compile-time constant expression. |
| */ |
| static final CompileTimeErrorCode CONST_WITH_NON_CONSTANT_ARGUMENT = new CompileTimeErrorCode.con1('CONST_WITH_NON_CONSTANT_ARGUMENT', 29, "Arguments of a constant creation must be constant expressions"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if <i>T</i> is not a class accessible in the current |
| * scope, optionally followed by type arguments. |
| * |
| * 12.11.2 Const: If <i>e</i> is of the form <i>const T.id(a<sub>1</sub>, …, a<sub>n</sub>, |
| * x<sub>n+1</sub>: a<sub>n+1</sub>, … x<sub>n+k</sub>: a<sub>n+k</sub>)</i> it is a |
| * compile-time error if <i>T</i> is not a class accessible in the current scope, optionally |
| * followed by type arguments. |
| * |
| * @param name the name of the non-type element |
| */ |
| static final CompileTimeErrorCode CONST_WITH_NON_TYPE = new CompileTimeErrorCode.con1('CONST_WITH_NON_TYPE', 30, "The name '%s' is not a class"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if <i>T</i> includes any type parameters. |
| */ |
| static final CompileTimeErrorCode CONST_WITH_TYPE_PARAMETERS = new CompileTimeErrorCode.con1('CONST_WITH_TYPE_PARAMETERS', 31, "The constant creation cannot use a type parameter"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if <i>T.id</i> is not the name of a constant |
| * constructor declared by the type <i>T</i>. |
| * |
| * @param typeName the name of the type |
| * @param constructorName the name of the requested constant constructor |
| */ |
| static final CompileTimeErrorCode CONST_WITH_UNDEFINED_CONSTRUCTOR = new CompileTimeErrorCode.con1('CONST_WITH_UNDEFINED_CONSTRUCTOR', 32, "The class '%s' does not have a constant constructor '%s'"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if <i>T.id</i> is not the name of a constant |
| * constructor declared by the type <i>T</i>. |
| * |
| * @param typeName the name of the type |
| */ |
| static final CompileTimeErrorCode CONST_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT = new CompileTimeErrorCode.con1('CONST_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT', 33, "The class '%s' does not have a default constant constructor"); |
| |
| /** |
| * 15.3.1 Typedef: It is a compile-time error if any default values are specified in the signature |
| * of a function type alias. |
| */ |
| static final CompileTimeErrorCode DEFAULT_VALUE_IN_FUNCTION_TYPE_ALIAS = new CompileTimeErrorCode.con1('DEFAULT_VALUE_IN_FUNCTION_TYPE_ALIAS', 34, "Default values aren't allowed in typedefs"); |
| |
| /** |
| * 6.2.1 Required Formals: By means of a function signature that names the parameter and describes |
| * its type as a function type. It is a compile-time error if any default values are specified in |
| * the signature of such a function type. |
| */ |
| static final CompileTimeErrorCode DEFAULT_VALUE_IN_FUNCTION_TYPED_PARAMETER = new CompileTimeErrorCode.con1('DEFAULT_VALUE_IN_FUNCTION_TYPED_PARAMETER', 35, "Default values aren't allowed in function type parameters"); |
| |
| /** |
| * 3.1 Scoping: It is a compile-time error if there is more than one entity with the same name |
| * declared in the same scope. |
| */ |
| static final CompileTimeErrorCode DUPLICATE_CONSTRUCTOR_DEFAULT = new CompileTimeErrorCode.con1('DUPLICATE_CONSTRUCTOR_DEFAULT', 36, "The default constructor is already defined"); |
| |
| /** |
| * 3.1 Scoping: It is a compile-time error if there is more than one entity with the same name |
| * declared in the same scope. |
| * |
| * @param duplicateName the name of the duplicate entity |
| */ |
| static final CompileTimeErrorCode DUPLICATE_CONSTRUCTOR_NAME = new CompileTimeErrorCode.con1('DUPLICATE_CONSTRUCTOR_NAME', 37, "The constructor with name '%s' is already defined"); |
| |
| /** |
| * 3.1 Scoping: It is a compile-time error if there is more than one entity with the same name |
| * declared in the same scope. |
| * |
| * 7 Classes: It is a compile-time error if a class declares two members of the same name. |
| * |
| * 7 Classes: It is a compile-time error if a class has an instance member and a static member |
| * with the same name. |
| * |
| * @param duplicateName the name of the duplicate entity |
| */ |
| static final CompileTimeErrorCode DUPLICATE_DEFINITION = new CompileTimeErrorCode.con1('DUPLICATE_DEFINITION', 38, "The name '%s' is already defined"); |
| |
| /** |
| * 7. Classes: It is a compile-time error if a class has an instance member and a static member |
| * with the same name. |
| * |
| * This covers the additional duplicate definition cases where inheritance has to be considered. |
| * |
| * @param className the name of the class that has conflicting instance/static members |
| * @param name the name of the conflicting members |
| * @see #DUPLICATE_DEFINITION |
| */ |
| static final CompileTimeErrorCode DUPLICATE_DEFINITION_INHERITANCE = new CompileTimeErrorCode.con1('DUPLICATE_DEFINITION_INHERITANCE', 39, "The name '%s' is already defined in '%s'"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: It is a compile-time error if <i>q<sub>i</sub> = |
| * q<sub>j</sub></i> for any <i>i != j</i> [where <i>q<sub>i</sub></i> is the label for a named |
| * argument]. |
| */ |
| static final CompileTimeErrorCode DUPLICATE_NAMED_ARGUMENT = new CompileTimeErrorCode.con1('DUPLICATE_NAMED_ARGUMENT', 40, "The argument for the named parameter '%s' was already specified"); |
| |
| /** |
| * SDK implementation libraries can be exported only by other SDK libraries. |
| * |
| * @param uri the uri pointing to a library |
| */ |
| static final CompileTimeErrorCode EXPORT_INTERNAL_LIBRARY = new CompileTimeErrorCode.con1('EXPORT_INTERNAL_LIBRARY', 41, "The library '%s' is internal and cannot be exported"); |
| |
| /** |
| * 14.2 Exports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * @param uri the uri pointing to a non-library declaration |
| */ |
| static final CompileTimeErrorCode EXPORT_OF_NON_LIBRARY = new CompileTimeErrorCode.con1('EXPORT_OF_NON_LIBRARY', 42, "The exported library '%s' must not have a part-of directive"); |
| |
| /** |
| * 7.9 Superclasses: It is a compile-time error if the extends clause of a class <i>C</i> includes |
| * a type expression that does not denote a class available in the lexical scope of <i>C</i>. |
| * |
| * @param typeName the name of the superclass that was not found |
| */ |
| static final CompileTimeErrorCode EXTENDS_NON_CLASS = new CompileTimeErrorCode.con1('EXTENDS_NON_CLASS', 43, "Classes can only extend other classes"); |
| |
| /** |
| * 12.2 Null: It is a compile-time error for a class to attempt to extend or implement Null. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement int. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement double. |
| * |
| * 12.3 Numbers: It is a compile-time error for any type other than the types int and double to |
| * attempt to extend or implement num. |
| * |
| * 12.4 Booleans: It is a compile-time error for a class to attempt to extend or implement bool. |
| * |
| * 12.5 Strings: It is a compile-time error for a class to attempt to extend or implement String. |
| * |
| * @param typeName the name of the type that cannot be extended |
| * @see #IMPLEMENTS_DISALLOWED_CLASS |
| */ |
| static final CompileTimeErrorCode EXTENDS_DISALLOWED_CLASS = new CompileTimeErrorCode.con1('EXTENDS_DISALLOWED_CLASS', 44, "Classes cannot extend '%s'"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: It is a static warning if <i>m < h</i> or if <i>m > |
| * n</i>. |
| * |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| * |
| * @param requiredCount the maximum number of positional arguments |
| * @param argumentCount the actual number of positional arguments given |
| */ |
| static final CompileTimeErrorCode EXTRA_POSITIONAL_ARGUMENTS = new CompileTimeErrorCode.con1('EXTRA_POSITIONAL_ARGUMENTS', 45, "%d positional arguments expected, but %d found"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. It is a compile time |
| * error if more than one initializer corresponding to a given instance variable appears in |
| * <i>k</i>'s list. |
| */ |
| static final CompileTimeErrorCode FIELD_INITIALIZED_BY_MULTIPLE_INITIALIZERS = new CompileTimeErrorCode.con1('FIELD_INITIALIZED_BY_MULTIPLE_INITIALIZERS', 46, "The field '%s' cannot be initialized twice in the same constructor"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. It is a compile time |
| * error if <i>k</i>'s initializer list contains an initializer for a variable that is initialized |
| * by means of an initializing formal of <i>k</i>. |
| */ |
| static final CompileTimeErrorCode FIELD_INITIALIZED_IN_PARAMETER_AND_INITIALIZER = new CompileTimeErrorCode.con1('FIELD_INITIALIZED_IN_PARAMETER_AND_INITIALIZER', 47, "Fields cannot be initialized in both the parameter list and the initializers"); |
| |
| /** |
| * 5 Variables: It is a compile-time error if a final instance variable that has is initialized by |
| * means of an initializing formal of a constructor is also initialized elsewhere in the same |
| * constructor. |
| * |
| * @param name the name of the field in question |
| */ |
| static final CompileTimeErrorCode FINAL_INITIALIZED_MULTIPLE_TIMES = new CompileTimeErrorCode.con1('FINAL_INITIALIZED_MULTIPLE_TIMES', 48, "'%s' is a final field and so can only be set once"); |
| |
| /** |
| * 7.6.1 Generative Constructors: It is a compile-time error if an initializing formal is used by |
| * a function other than a non-redirecting generative constructor. |
| */ |
| static final CompileTimeErrorCode FIELD_INITIALIZER_FACTORY_CONSTRUCTOR = new CompileTimeErrorCode.con1('FIELD_INITIALIZER_FACTORY_CONSTRUCTOR', 49, "Initializing formal fields cannot be used in factory constructors"); |
| |
| /** |
| * 7.6.1 Generative Constructors: It is a compile-time error if an initializing formal is used by |
| * a function other than a non-redirecting generative constructor. |
| */ |
| static final CompileTimeErrorCode FIELD_INITIALIZER_OUTSIDE_CONSTRUCTOR = new CompileTimeErrorCode.con1('FIELD_INITIALIZER_OUTSIDE_CONSTRUCTOR', 50, "Initializing formal fields can only be used in constructors"); |
| |
| /** |
| * 7.6.1 Generative Constructors: A generative constructor may be redirecting, in which case its |
| * only action is to invoke another generative constructor. |
| * |
| * 7.6.1 Generative Constructors: It is a compile-time error if an initializing formal is used by |
| * a function other than a non-redirecting generative constructor. |
| */ |
| static final CompileTimeErrorCode FIELD_INITIALIZER_REDIRECTING_CONSTRUCTOR = new CompileTimeErrorCode.con1('FIELD_INITIALIZER_REDIRECTING_CONSTRUCTOR', 51, "The redirecting constructor cannot have a field initializer"); |
| |
| /** |
| * 7.2 Getters: It is a compile-time error if a class has both a getter and a method with the same |
| * name. |
| * |
| * @param name the conflicting name of the getter and method |
| */ |
| static final CompileTimeErrorCode GETTER_AND_METHOD_WITH_SAME_NAME = new CompileTimeErrorCode.con1('GETTER_AND_METHOD_WITH_SAME_NAME', 52, "'%s' cannot be used to name a getter, there is already a method with the same name"); |
| |
| /** |
| * 12.2 Null: It is a compile-time error for a class to attempt to extend or implement Null. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement int. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement double. |
| * |
| * 12.3 Numbers: It is a compile-time error for any type other than the types int and double to |
| * attempt to extend or implement num. |
| * |
| * 12.4 Booleans: It is a compile-time error for a class to attempt to extend or implement bool. |
| * |
| * 12.5 Strings: It is a compile-time error for a class to attempt to extend or implement String. |
| * |
| * @param typeName the name of the type that cannot be implemented |
| * @see #EXTENDS_DISALLOWED_CLASS |
| */ |
| static final CompileTimeErrorCode IMPLEMENTS_DISALLOWED_CLASS = new CompileTimeErrorCode.con1('IMPLEMENTS_DISALLOWED_CLASS', 53, "Classes cannot implement '%s'"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the implements clause of a class includes |
| * type dynamic. |
| */ |
| static final CompileTimeErrorCode IMPLEMENTS_DYNAMIC = new CompileTimeErrorCode.con1('IMPLEMENTS_DYNAMIC', 54, "Classes cannot implement 'dynamic'"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the implements clause of a class <i>C</i> |
| * includes a type expression that does not denote a class available in the lexical scope of |
| * <i>C</i>. |
| * |
| * @param typeName the name of the interface that was not found |
| */ |
| static final CompileTimeErrorCode IMPLEMENTS_NON_CLASS = new CompileTimeErrorCode.con1('IMPLEMENTS_NON_CLASS', 55, "Classes can only implement other classes"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if a type <i>T</i> appears more than once in |
| * the implements clause of a class. |
| * |
| * @param className the name of the class that is implemented more than once |
| */ |
| static final CompileTimeErrorCode IMPLEMENTS_REPEATED = new CompileTimeErrorCode.con1('IMPLEMENTS_REPEATED', 56, "'%s' can only be implemented once"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the superclass of a class <i>C</i> appears |
| * in the implements clause of <i>C</i>. |
| * |
| * @param className the name of the class that appears in both "extends" and "implements" clauses |
| */ |
| static final CompileTimeErrorCode IMPLEMENTS_SUPER_CLASS = new CompileTimeErrorCode.con1('IMPLEMENTS_SUPER_CLASS', 57, "'%s' cannot be used in both 'extends' and 'implements' clauses"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Note that <b>this</b> is not in scope on the right hand side of |
| * an initializer. |
| * |
| * 12.10 This: It is a compile-time error if this appears in a top-level function or variable |
| * initializer, in a factory constructor, or in a static method or variable initializer, or in the |
| * initializer of an instance variable. |
| * |
| * @param name the name of the type in question |
| */ |
| static final CompileTimeErrorCode IMPLICIT_THIS_REFERENCE_IN_INITIALIZER = new CompileTimeErrorCode.con1('IMPLICIT_THIS_REFERENCE_IN_INITIALIZER', 58, "Only static members can be accessed in initializers"); |
| |
| /** |
| * SDK implementation libraries can be imported only by other SDK libraries. |
| * |
| * @param uri the uri pointing to a library |
| */ |
| static final CompileTimeErrorCode IMPORT_INTERNAL_LIBRARY = new CompileTimeErrorCode.con1('IMPORT_INTERNAL_LIBRARY', 59, "The library '%s' is internal and cannot be imported"); |
| |
| /** |
| * 14.1 Imports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * @param uri the uri pointing to a non-library declaration |
| */ |
| static final CompileTimeErrorCode IMPORT_OF_NON_LIBRARY = new CompileTimeErrorCode.con1('IMPORT_OF_NON_LIBRARY', 60, "The imported library '%s' must not have a part-of directive"); |
| |
| /** |
| * 13.9 Switch: It is a compile-time error if values of the expressions <i>e<sub>k</sub></i> are |
| * not instances of the same class <i>C</i>, for all <i>1 <= k <= n</i>. |
| * |
| * @param expressionSource the expression source code that is the unexpected type |
| * @param expectedType the name of the expected type |
| */ |
| static final CompileTimeErrorCode INCONSISTENT_CASE_EXPRESSION_TYPES = new CompileTimeErrorCode.con1('INCONSISTENT_CASE_EXPRESSION_TYPES', 61, "Case expressions must have the same types, '%s' is not a %s'"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. It is a compile-time |
| * error if <i>k</i>'s initializer list contains an initializer for a variable that is not an |
| * instance variable declared in the immediately surrounding class. |
| * |
| * @param id the name of the initializing formal that is not an instance variable in the |
| * immediately enclosing class |
| * @see #INITIALIZING_FORMAL_FOR_NON_EXISTANT_FIELD |
| */ |
| static final CompileTimeErrorCode INITIALIZER_FOR_NON_EXISTANT_FIELD = new CompileTimeErrorCode.con1('INITIALIZER_FOR_NON_EXISTANT_FIELD', 62, "'%s' is not a variable in the enclosing class"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. It is a compile-time |
| * error if <i>k</i>'s initializer list contains an initializer for a variable that is not an |
| * instance variable declared in the immediately surrounding class. |
| * |
| * @param id the name of the initializing formal that is a static variable in the immediately |
| * enclosing class |
| * @see #INITIALIZING_FORMAL_FOR_STATIC_FIELD |
| */ |
| static final CompileTimeErrorCode INITIALIZER_FOR_STATIC_FIELD = new CompileTimeErrorCode.con1('INITIALIZER_FOR_STATIC_FIELD', 63, "'%s' is a static variable in the enclosing class, variables initialized in a constructor cannot be static"); |
| |
| /** |
| * 7.6.1 Generative Constructors: An initializing formal has the form <i>this.id</i>. It is a |
| * compile-time error if <i>id</i> is not the name of an instance variable of the immediately |
| * enclosing class. |
| * |
| * @param id the name of the initializing formal that is not an instance variable in the |
| * immediately enclosing class |
| * @see #INITIALIZING_FORMAL_FOR_STATIC_FIELD |
| * @see #INITIALIZER_FOR_NON_EXISTANT_FIELD |
| */ |
| static final CompileTimeErrorCode INITIALIZING_FORMAL_FOR_NON_EXISTANT_FIELD = new CompileTimeErrorCode.con1('INITIALIZING_FORMAL_FOR_NON_EXISTANT_FIELD', 64, "'%s' is not a variable in the enclosing class"); |
| |
| /** |
| * 7.6.1 Generative Constructors: An initializing formal has the form <i>this.id</i>. It is a |
| * compile-time error if <i>id</i> is not the name of an instance variable of the immediately |
| * enclosing class. |
| * |
| * @param id the name of the initializing formal that is a static variable in the immediately |
| * enclosing class |
| * @see #INITIALIZER_FOR_STATIC_FIELD |
| */ |
| static final CompileTimeErrorCode INITIALIZING_FORMAL_FOR_STATIC_FIELD = new CompileTimeErrorCode.con1('INITIALIZING_FORMAL_FOR_STATIC_FIELD', 65, "'%s' is a static variable in the enclosing class, variables initialized in a constructor cannot be static"); |
| |
| /** |
| * 12.30 Identifier Reference: Otherwise, e is equivalent to the property extraction |
| * <b>this</b>.<i>id</i>. |
| */ |
| static final CompileTimeErrorCode INSTANCE_MEMBER_ACCESS_FROM_STATIC = new CompileTimeErrorCode.con1('INSTANCE_MEMBER_ACCESS_FROM_STATIC', 66, "Instance member cannot be accessed from static method"); |
| |
| /** |
| * 11 Metadata: Metadata consists of a series of annotations, each of which begin with the |
| * character @, followed by a constant expression that must be either a reference to a |
| * compile-time constant variable, or a call to a constant constructor. |
| */ |
| static final CompileTimeErrorCode INVALID_ANNOTATION = new CompileTimeErrorCode.con1('INVALID_ANNOTATION', 67, "Annotation can be only constant variable or constant constructor invocation"); |
| |
| /** |
| * TODO(brianwilkerson) Remove this when we have decided on how to report errors in compile-time |
| * constants. Until then, this acts as a placeholder for more informative errors. |
| * |
| * See TODOs in ConstantVisitor |
| */ |
| static final CompileTimeErrorCode INVALID_CONSTANT = new CompileTimeErrorCode.con1('INVALID_CONSTANT', 68, "Invalid constant value"); |
| |
| /** |
| * 7.6 Constructors: It is a compile-time error if the name of a constructor is not a constructor |
| * name. |
| */ |
| static final CompileTimeErrorCode INVALID_CONSTRUCTOR_NAME = new CompileTimeErrorCode.con1('INVALID_CONSTRUCTOR_NAME', 69, "Invalid constructor name"); |
| |
| /** |
| * 7.6.2 Factories: It is a compile-time error if <i>M</i> is not the name of the immediately |
| * enclosing class. |
| */ |
| static final CompileTimeErrorCode INVALID_FACTORY_NAME_NOT_A_CLASS = new CompileTimeErrorCode.con1('INVALID_FACTORY_NAME_NOT_A_CLASS', 70, "The name of the immediately enclosing class expected"); |
| |
| /** |
| * 12.10 This: It is a compile-time error if this appears in a top-level function or variable |
| * initializer, in a factory constructor, or in a static method or variable initializer, or in the |
| * initializer of an instance variable. |
| */ |
| static final CompileTimeErrorCode INVALID_REFERENCE_TO_THIS = new CompileTimeErrorCode.con1('INVALID_REFERENCE_TO_THIS', 71, "Invalid reference to 'this' expression"); |
| |
| /** |
| * 12.6 Lists: It is a compile time error if the type argument of a constant list literal includes |
| * a type parameter. |
| * |
| * @name the name of the type parameter |
| */ |
| static final CompileTimeErrorCode INVALID_TYPE_ARGUMENT_IN_CONST_LIST = new CompileTimeErrorCode.con1('INVALID_TYPE_ARGUMENT_IN_CONST_LIST', 72, "Constant list literals cannot include a type parameter as a type argument, such as '%s'"); |
| |
| /** |
| * 12.7 Maps: It is a compile time error if the type arguments of a constant map literal include a |
| * type parameter. |
| * |
| * @name the name of the type parameter |
| */ |
| static final CompileTimeErrorCode INVALID_TYPE_ARGUMENT_IN_CONST_MAP = new CompileTimeErrorCode.con1('INVALID_TYPE_ARGUMENT_IN_CONST_MAP', 73, "Constant map literals cannot include a type parameter as a type argument, such as '%s'"); |
| |
| /** |
| * 14.2 Exports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * 14.1 Imports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * 14.3 Parts: It is a compile time error if the contents of the URI are not a valid part |
| * declaration. |
| * |
| * @param uri the URI that is invalid |
| * @see #URI_DOES_NOT_EXIST |
| */ |
| static final CompileTimeErrorCode INVALID_URI = new CompileTimeErrorCode.con1('INVALID_URI', 74, "Invalid URI syntax: '%s'"); |
| |
| /** |
| * 13.13 Break: It is a compile-time error if no such statement <i>s<sub>E</sub></i> exists within |
| * the innermost function in which <i>s<sub>b</sub></i> occurs. |
| * |
| * 13.14 Continue: It is a compile-time error if no such statement or case clause |
| * <i>s<sub>E</sub></i> exists within the innermost function in which <i>s<sub>c</sub></i> occurs. |
| * |
| * @param labelName the name of the unresolvable label |
| */ |
| static final CompileTimeErrorCode LABEL_IN_OUTER_SCOPE = new CompileTimeErrorCode.con1('LABEL_IN_OUTER_SCOPE', 75, "Cannot reference label '%s' declared in an outer method"); |
| |
| /** |
| * 13.13 Break: It is a compile-time error if no such statement <i>s<sub>E</sub></i> exists within |
| * the innermost function in which <i>s<sub>b</sub></i> occurs. |
| * |
| * 13.14 Continue: It is a compile-time error if no such statement or case clause |
| * <i>s<sub>E</sub></i> exists within the innermost function in which <i>s<sub>c</sub></i> occurs. |
| * |
| * @param labelName the name of the unresolvable label |
| */ |
| static final CompileTimeErrorCode LABEL_UNDEFINED = new CompileTimeErrorCode.con1('LABEL_UNDEFINED', 76, "Cannot reference undefined label '%s'"); |
| |
| /** |
| * 12.6 Lists: A run-time list literal <<i>E</i>> [<i>e<sub>1</sub></i> ... |
| * <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>a</i> with first argument <i>i</i> and second argument |
| * <i>o<sub>i+1</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final CompileTimeErrorCode LIST_ELEMENT_TYPE_NOT_ASSIGNABLE = new CompileTimeErrorCode.con1('LIST_ELEMENT_TYPE_NOT_ASSIGNABLE', 77, "The element type '%s' cannot be assigned to the list type '%s'"); |
| |
| /** |
| * 12.7 Map: A run-time map literal <<i>K</i>, <i>V</i>> [<i>k<sub>1</sub></i> : |
| * <i>e<sub>1</sub></i> ... <i>k<sub>n</sub></i> : <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>m</i> with first argument <i>k<sub>i</sub></i> and second |
| * argument <i>e<sub>i</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final CompileTimeErrorCode MAP_KEY_TYPE_NOT_ASSIGNABLE = new CompileTimeErrorCode.con1('MAP_KEY_TYPE_NOT_ASSIGNABLE', 78, "The element type '%s' cannot be assigned to the map key type '%s'"); |
| |
| /** |
| * 12.7 Map: A run-time map literal <<i>K</i>, <i>V</i>> [<i>k<sub>1</sub></i> : |
| * <i>e<sub>1</sub></i> ... <i>k<sub>n</sub></i> : <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>m</i> with first argument <i>k<sub>i</sub></i> and second |
| * argument <i>e<sub>i</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final CompileTimeErrorCode MAP_VALUE_TYPE_NOT_ASSIGNABLE = new CompileTimeErrorCode.con1('MAP_VALUE_TYPE_NOT_ASSIGNABLE', 79, "The element type '%s' cannot be assigned to the map value type '%s'"); |
| |
| /** |
| * 7 Classes: It is a compile time error if a class <i>C</i> declares a member with the same name |
| * as <i>C</i>. |
| */ |
| static final CompileTimeErrorCode MEMBER_WITH_CLASS_NAME = new CompileTimeErrorCode.con1('MEMBER_WITH_CLASS_NAME', 80, "Class members cannot have the same name as the enclosing class"); |
| |
| /** |
| * 7.2 Getters: It is a compile-time error if a class has both a getter and a method with the same |
| * name. |
| * |
| * @param name the conflicting name of the getter and method |
| */ |
| static final CompileTimeErrorCode METHOD_AND_GETTER_WITH_SAME_NAME = new CompileTimeErrorCode.con1('METHOD_AND_GETTER_WITH_SAME_NAME', 81, "'%s' cannot be used to name a method, there is already a getter with the same name"); |
| |
| /** |
| * 12.1 Constants: A constant expression is ... a constant list literal. |
| */ |
| static final CompileTimeErrorCode MISSING_CONST_IN_LIST_LITERAL = new CompileTimeErrorCode.con1('MISSING_CONST_IN_LIST_LITERAL', 82, "List literals must be prefixed with 'const' when used as a constant expression"); |
| |
| /** |
| * 12.1 Constants: A constant expression is ... a constant map literal. |
| */ |
| static final CompileTimeErrorCode MISSING_CONST_IN_MAP_LITERAL = new CompileTimeErrorCode.con1('MISSING_CONST_IN_MAP_LITERAL', 83, "Map literals must be prefixed with 'const' when used as a constant expression"); |
| |
| /** |
| * 9 Mixins: It is a compile-time error if a declared or derived mixin explicitly declares a |
| * constructor. |
| * |
| * @param typeName the name of the mixin that is invalid |
| */ |
| static final CompileTimeErrorCode MIXIN_DECLARES_CONSTRUCTOR = new CompileTimeErrorCode.con1('MIXIN_DECLARES_CONSTRUCTOR', 84, "The class '%s' cannot be used as a mixin because it declares a constructor"); |
| |
| /** |
| * 9 Mixins: It is a compile-time error if a mixin is derived from a class whose superclass is not |
| * Object. |
| * |
| * @param typeName the name of the mixin that is invalid |
| */ |
| static final CompileTimeErrorCode MIXIN_INHERITS_FROM_NOT_OBJECT = new CompileTimeErrorCode.con1('MIXIN_INHERITS_FROM_NOT_OBJECT', 85, "The class '%s' cannot be used as a mixin because it extends a class other than Object"); |
| |
| /** |
| * 12.2 Null: It is a compile-time error for a class to attempt to extend or implement Null. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement int. |
| * |
| * 12.3 Numbers: It is a compile-time error for a class to attempt to extend or implement double. |
| * |
| * 12.3 Numbers: It is a compile-time error for any type other than the types int and double to |
| * attempt to extend or implement num. |
| * |
| * 12.4 Booleans: It is a compile-time error for a class to attempt to extend or implement bool. |
| * |
| * 12.5 Strings: It is a compile-time error for a class to attempt to extend or implement String. |
| * |
| * @param typeName the name of the type that cannot be extended |
| * @see #IMPLEMENTS_DISALLOWED_CLASS |
| */ |
| static final CompileTimeErrorCode MIXIN_OF_DISALLOWED_CLASS = new CompileTimeErrorCode.con1('MIXIN_OF_DISALLOWED_CLASS', 86, "Classes cannot mixin '%s'"); |
| |
| /** |
| * 9.1 Mixin Application: It is a compile-time error if <i>M</i> does not denote a class or mixin |
| * available in the immediately enclosing scope. |
| */ |
| static final CompileTimeErrorCode MIXIN_OF_NON_CLASS = new CompileTimeErrorCode.con1('MIXIN_OF_NON_CLASS', 87, "Classes can only mixin other classes"); |
| |
| /** |
| * 9 Mixins: It is a compile-time error if a declared or derived mixin refers to super. |
| */ |
| static final CompileTimeErrorCode MIXIN_REFERENCES_SUPER = new CompileTimeErrorCode.con1('MIXIN_REFERENCES_SUPER', 88, "The class '%s' cannot be used as a mixin because it references 'super'"); |
| |
| /** |
| * 9.1 Mixin Application: It is a compile-time error if <i>S</i> does not denote a class available |
| * in the immediately enclosing scope. |
| */ |
| static final CompileTimeErrorCode MIXIN_WITH_NON_CLASS_SUPERCLASS = new CompileTimeErrorCode.con1('MIXIN_WITH_NON_CLASS_SUPERCLASS', 89, "Mixin can only be applied to class"); |
| |
| /** |
| * 7.6.1 Generative Constructors: A generative constructor may be redirecting, in which case its |
| * only action is to invoke another generative constructor. |
| */ |
| static final CompileTimeErrorCode MULTIPLE_REDIRECTING_CONSTRUCTOR_INVOCATIONS = new CompileTimeErrorCode.con1('MULTIPLE_REDIRECTING_CONSTRUCTOR_INVOCATIONS', 90, "Constructor may have at most one 'this' redirection"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. Then <i>k</i> may |
| * include at most one superinitializer in its initializer list or a compile time error occurs. |
| */ |
| static final CompileTimeErrorCode MULTIPLE_SUPER_INITIALIZERS = new CompileTimeErrorCode.con1('MULTIPLE_SUPER_INITIALIZERS', 91, "Constructor may have at most one 'super' initializer"); |
| |
| /** |
| * 11 Metadata: Metadata consists of a series of annotations, each of which begin with the |
| * character @, followed by a constant expression that must be either a reference to a |
| * compile-time constant variable, or a call to a constant constructor. |
| */ |
| static final CompileTimeErrorCode NO_ANNOTATION_CONSTRUCTOR_ARGUMENTS = new CompileTimeErrorCode.con1('NO_ANNOTATION_CONSTRUCTOR_ARGUMENTS', 92, "Annotation creation must have arguments"); |
| |
| /** |
| * 7.6.1 Generative Constructors: If no superinitializer is provided, an implicit superinitializer |
| * of the form <b>super</b>() is added at the end of <i>k</i>'s initializer list, unless the |
| * enclosing class is class <i>Object</i>. |
| * |
| * 7.6.1 Generative constructors. It is a compile-time error if class <i>S</i> does not declare a |
| * generative constructor named <i>S</i> (respectively <i>S.id</i>) |
| */ |
| static final CompileTimeErrorCode NO_DEFAULT_SUPER_CONSTRUCTOR_EXPLICIT = new CompileTimeErrorCode.con1('NO_DEFAULT_SUPER_CONSTRUCTOR_EXPLICIT', 93, "The class '%s' does not have a default constructor"); |
| |
| /** |
| * 7.6 Constructors: Iff no constructor is specified for a class <i>C</i>, it implicitly has a |
| * default constructor C() : <b>super<b>() {}, unless <i>C</i> is class <i>Object</i>. |
| * |
| * 7.6.1 Generative constructors. It is a compile-time error if class <i>S</i> does not declare a |
| * generative constructor named <i>S</i> (respectively <i>S.id</i>) |
| */ |
| static final CompileTimeErrorCode NO_DEFAULT_SUPER_CONSTRUCTOR_IMPLICIT = new CompileTimeErrorCode.con1('NO_DEFAULT_SUPER_CONSTRUCTOR_IMPLICIT', 94, "The class '%s' does not have a default constructor"); |
| |
| /** |
| * 13.2 Expression Statements: It is a compile-time error if a non-constant map literal that has |
| * no explicit type arguments appears in a place where a statement is expected. |
| */ |
| static final CompileTimeErrorCode NON_CONST_MAP_AS_EXPRESSION_STATEMENT = new CompileTimeErrorCode.con1('NON_CONST_MAP_AS_EXPRESSION_STATEMENT', 95, "A non-constant map literal without type arguments cannot be used as an expression statement"); |
| |
| /** |
| * 13.9 Switch: Given a switch statement of the form <i>switch (e) { label<sub>11</sub> … |
| * label<sub>1j1</sub> case e<sub>1</sub>: s<sub>1</sub> … label<sub>n1</sub> … |
| * label<sub>njn</sub> case e<sub>n</sub>: s<sub>n</sub> default: s<sub>n+1</sub>}</i> or the form |
| * <i>switch (e) { label<sub>11</sub> … label<sub>1j1</sub> case e<sub>1</sub>: |
| * s<sub>1</sub> … label<sub>n1</sub> … label<sub>njn</sub> case e<sub>n</sub>: |
| * s<sub>n</sub>}</i>, it is a compile-time error if the expressions <i>e<sub>k</sub></i> are not |
| * compile-time constants, for all <i>1 <= k <= n</i>. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_CASE_EXPRESSION = new CompileTimeErrorCode.con1('NON_CONSTANT_CASE_EXPRESSION', 96, "Case expressions must be constant"); |
| |
| /** |
| * 6.2.2 Optional Formals: It is a compile-time error if the default value of an optional |
| * parameter is not a compile-time constant. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_DEFAULT_VALUE = new CompileTimeErrorCode.con1('NON_CONSTANT_DEFAULT_VALUE', 97, "Default values of an optional parameter must be constant"); |
| |
| /** |
| * 12.6 Lists: It is a compile time error if an element of a constant list literal is not a |
| * compile-time constant. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_LIST_ELEMENT = new CompileTimeErrorCode.con1('NON_CONSTANT_LIST_ELEMENT', 98, "'const' lists must have all constant values"); |
| |
| /** |
| * 12.7 Maps: It is a compile time error if either a key or a value of an entry in a constant map |
| * literal is not a compile-time constant. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_MAP_KEY = new CompileTimeErrorCode.con1('NON_CONSTANT_MAP_KEY', 99, "The keys in a map must be constant"); |
| |
| /** |
| * 12.7 Maps: It is a compile time error if either a key or a value of an entry in a constant map |
| * literal is not a compile-time constant. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_MAP_VALUE = new CompileTimeErrorCode.con1('NON_CONSTANT_MAP_VALUE', 100, "The values in a 'const' map must be constant"); |
| |
| /** |
| * 11 Metadata: Metadata consists of a series of annotations, each of which begin with the |
| * character @, followed by a constant expression that must be either a reference to a |
| * compile-time constant variable, or a call to a constant constructor. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_ANNOTATION_CONSTRUCTOR = new CompileTimeErrorCode.con1('NON_CONSTANT_ANNOTATION_CONSTRUCTOR', 101, "Annotation creation can use only 'const' constructor"); |
| |
| /** |
| * 7.6.3 Constant Constructors: Any expression that appears within the initializer list of a |
| * constant constructor must be a potentially constant expression, or a compile-time error occurs. |
| */ |
| static final CompileTimeErrorCode NON_CONSTANT_VALUE_IN_INITIALIZER = new CompileTimeErrorCode.con1('NON_CONSTANT_VALUE_IN_INITIALIZER', 102, "Initializer expressions in constant constructors must be constants"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: It is a static warning if <i>m < h</i> or if <i>m > n</i>. |
| * |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| * |
| * @param requiredCount the expected number of required arguments |
| * @param argumentCount the actual number of positional arguments given |
| */ |
| static final CompileTimeErrorCode NOT_ENOUGH_REQUIRED_ARGUMENTS = new CompileTimeErrorCode.con1('NOT_ENOUGH_REQUIRED_ARGUMENTS', 103, "%d required argument(s) expected, but %d found"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>C</i> be the class in which the superinitializer appears |
| * and let <i>S</i> be the superclass of <i>C</i>. Let <i>k</i> be a generative constructor. It is |
| * a compile-time error if class <i>S</i> does not declare a generative constructor named <i>S</i> |
| * (respectively <i>S.id</i>) |
| */ |
| static final CompileTimeErrorCode NON_GENERATIVE_CONSTRUCTOR = new CompileTimeErrorCode.con1('NON_GENERATIVE_CONSTRUCTOR', 104, "The generative constructor '%s' expected, but factory found"); |
| |
| /** |
| * 7.9 Superclasses: It is a compile-time error to specify an extends clause for class Object. |
| */ |
| static final CompileTimeErrorCode OBJECT_CANNOT_EXTEND_ANOTHER_CLASS = new CompileTimeErrorCode.con1('OBJECT_CANNOT_EXTEND_ANOTHER_CLASS', 105, ""); |
| |
| /** |
| * 7.1.1 Operators: It is a compile-time error to declare an optional parameter in an operator. |
| */ |
| static final CompileTimeErrorCode OPTIONAL_PARAMETER_IN_OPERATOR = new CompileTimeErrorCode.con1('OPTIONAL_PARAMETER_IN_OPERATOR', 106, "Optional parameters are not allowed when defining an operator"); |
| |
| /** |
| * 14.3 Parts: It is a compile time error if the contents of the URI are not a valid part |
| * declaration. |
| * |
| * @param uri the uri pointing to a non-library declaration |
| */ |
| static final CompileTimeErrorCode PART_OF_NON_PART = new CompileTimeErrorCode.con1('PART_OF_NON_PART', 107, "The included part '%s' must have a part-of directive"); |
| |
| /** |
| * 14.1 Imports: It is a compile-time error if the current library declares a top-level member |
| * named <i>p</i>. |
| */ |
| static final CompileTimeErrorCode PREFIX_COLLIDES_WITH_TOP_LEVEL_MEMBER = new CompileTimeErrorCode.con1('PREFIX_COLLIDES_WITH_TOP_LEVEL_MEMBER', 108, "The name '%s' is already used as an import prefix and cannot be used to name a top-level element"); |
| |
| /** |
| * 6.2.2 Optional Formals: It is a compile-time error if the name of a named optional parameter |
| * begins with an '_' character. |
| */ |
| static final CompileTimeErrorCode PRIVATE_OPTIONAL_PARAMETER = new CompileTimeErrorCode.con1('PRIVATE_OPTIONAL_PARAMETER', 109, "Named optional parameters cannot start with an underscore"); |
| |
| /** |
| * 12.1 Constants: It is a compile-time error if the value of a compile-time constant expression |
| * depends on itself. |
| */ |
| static final CompileTimeErrorCode RECURSIVE_COMPILE_TIME_CONSTANT = new CompileTimeErrorCode.con1('RECURSIVE_COMPILE_TIME_CONSTANT', 110, ""); |
| |
| /** |
| * 7.6.1 Generative Constructors: A generative constructor may be redirecting, in which case its |
| * only action is to invoke another generative constructor. |
| * |
| * TODO(scheglov) review this later, there are no explicit "it is a compile-time error" in |
| * specification. But it was added to the co19 and there is same error for factories. |
| * |
| * https://code.google.com/p/dart/issues/detail?id=954 |
| */ |
| static final CompileTimeErrorCode RECURSIVE_CONSTRUCTOR_REDIRECT = new CompileTimeErrorCode.con1('RECURSIVE_CONSTRUCTOR_REDIRECT', 111, "Cycle in redirecting generative constructors"); |
| |
| /** |
| * 7.6.2 Factories: It is a compile-time error if a redirecting factory constructor redirects to |
| * itself, either directly or indirectly via a sequence of redirections. |
| */ |
| static final CompileTimeErrorCode RECURSIVE_FACTORY_REDIRECT = new CompileTimeErrorCode.con1('RECURSIVE_FACTORY_REDIRECT', 112, "Cycle in redirecting factory constructors"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the interface of a class <i>C</i> is a |
| * superinterface of itself. |
| * |
| * 8.1 Superinterfaces: It is a compile-time error if an interface is a superinterface of itself. |
| * |
| * 7.9 Superclasses: It is a compile-time error if a class <i>C</i> is a superclass of itself. |
| * |
| * @param className the name of the class that implements itself recursively |
| * @param strImplementsPath a string representation of the implements loop |
| */ |
| static final CompileTimeErrorCode RECURSIVE_INTERFACE_INHERITANCE = new CompileTimeErrorCode.con1('RECURSIVE_INTERFACE_INHERITANCE', 113, "'%s' cannot be a superinterface of itself: %s"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the interface of a class <i>C</i> is a |
| * superinterface of itself. |
| * |
| * 8.1 Superinterfaces: It is a compile-time error if an interface is a superinterface of itself. |
| * |
| * 7.9 Superclasses: It is a compile-time error if a class <i>C</i> is a superclass of itself. |
| * |
| * @param className the name of the class that implements itself recursively |
| */ |
| static final CompileTimeErrorCode RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_EXTENDS = new CompileTimeErrorCode.con1('RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_EXTENDS', 114, "'%s' cannot extend itself"); |
| |
| /** |
| * 7.10 Superinterfaces: It is a compile-time error if the interface of a class <i>C</i> is a |
| * superinterface of itself. |
| * |
| * 8.1 Superinterfaces: It is a compile-time error if an interface is a superinterface of itself. |
| * |
| * 7.9 Superclasses: It is a compile-time error if a class <i>C</i> is a superclass of itself. |
| * |
| * @param className the name of the class that implements itself recursively |
| */ |
| static final CompileTimeErrorCode RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_IMPLEMENTS = new CompileTimeErrorCode.con1('RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_IMPLEMENTS', 115, "'%s' cannot implement itself"); |
| |
| /** |
| * 7.6.2 Factories: It is a compile-time error if <i>k</i> is prefixed with the const modifier but |
| * <i>k'</i> is not a constant constructor. |
| */ |
| static final CompileTimeErrorCode REDIRECT_TO_NON_CONST_CONSTRUCTOR = new CompileTimeErrorCode.con1('REDIRECT_TO_NON_CONST_CONSTRUCTOR', 116, "Constant factory constructor cannot delegate to a non-constant constructor"); |
| |
| /** |
| * 13.3 Local Variable Declaration: It is a compile-time error if <i>e</i> refers to the name |
| * <i>v</i> or the name <i>v=</i>. |
| */ |
| static final CompileTimeErrorCode REFERENCE_TO_DECLARED_VARIABLE_IN_INITIALIZER = new CompileTimeErrorCode.con1('REFERENCE_TO_DECLARED_VARIABLE_IN_INITIALIZER', 117, "The name '%s' cannot be referenced in the initializer of a variable with the same name"); |
| |
| /** |
| * 12.8.1 Rethrow: It is a compile-time error if an expression of the form <i>rethrow;</i> is not |
| * enclosed within a on-catch clause. |
| */ |
| static final CompileTimeErrorCode RETHROW_OUTSIDE_CATCH = new CompileTimeErrorCode.con1('RETHROW_OUTSIDE_CATCH', 118, "rethrow must be inside of a catch clause"); |
| |
| /** |
| * 13.11 Return: It is a compile-time error if a return statement of the form <i>return e;</i> |
| * appears in a generative constructor. |
| */ |
| static final CompileTimeErrorCode RETURN_IN_GENERATIVE_CONSTRUCTOR = new CompileTimeErrorCode.con1('RETURN_IN_GENERATIVE_CONSTRUCTOR', 119, "Constructors cannot return a value"); |
| |
| /** |
| * 12.15.4 Super Invocation: A super method invocation <i>i</i> has the form |
| * <i>super.m(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: a<sub>n+1</sub>, … |
| * x<sub>n+k</sub>: a<sub>n+k</sub>)</i>. It is a compile-time error if a super method invocation |
| * occurs in a top-level function or variable initializer, in an instance variable initializer or |
| * initializer list, in class Object, in a factory constructor, or in a static method or variable |
| * initializer. |
| */ |
| static final CompileTimeErrorCode SUPER_IN_INVALID_CONTEXT = new CompileTimeErrorCode.con1('SUPER_IN_INVALID_CONTEXT', 120, "Invalid context for 'super' invocation"); |
| |
| /** |
| * 7.6.1 Generative Constructors: A generative constructor may be redirecting, in which case its |
| * only action is to invoke another generative constructor. |
| */ |
| static final CompileTimeErrorCode SUPER_IN_REDIRECTING_CONSTRUCTOR = new CompileTimeErrorCode.con1('SUPER_IN_REDIRECTING_CONSTRUCTOR', 121, "The redirecting constructor cannot have a 'super' initializer"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>k</i> be a generative constructor. It is a compile-time |
| * error if a generative constructor of class Object includes a superinitializer. |
| */ |
| static final CompileTimeErrorCode SUPER_INITIALIZER_IN_OBJECT = new CompileTimeErrorCode.con1('SUPER_INITIALIZER_IN_OBJECT', 122, ""); |
| |
| /** |
| * 12.11 Instance Creation: It is a static type warning if any of the type arguments to a |
| * constructor of a generic type <i>G</i> invoked by a new expression or a constant object |
| * expression are not subtypes of the bounds of the corresponding formal type parameters of |
| * <i>G</i>. |
| * |
| * 12.11.1 New: If T is malformed a dynamic error occurs. In checked mode, if T is mal-bounded a |
| * dynamic error occurs. |
| * |
| * 12.1 Constants: It is a compile-time error if evaluation of a compile-time constant would raise |
| * an exception. |
| * |
| * @param boundedTypeName the name of the type used in the instance creation that should be |
| * limited by the bound as specified in the class declaration |
| * @param boundingTypeName the name of the bounding type |
| * @see StaticTypeWarningCode#TYPE_ARGUMENT_NOT_MATCHING_BOUNDS |
| */ |
| static final CompileTimeErrorCode TYPE_ARGUMENT_NOT_MATCHING_BOUNDS = new CompileTimeErrorCode.con1('TYPE_ARGUMENT_NOT_MATCHING_BOUNDS', 123, "'%s' does not extend '%s'"); |
| |
| /** |
| * 15.3.1 Typedef: It is a compile-time error if a typedef refers to itself via a chain of |
| * references that does not include a class declaration. |
| */ |
| static final CompileTimeErrorCode TYPE_ALIAS_CANNOT_REFERENCE_ITSELF = new CompileTimeErrorCode.con1('TYPE_ALIAS_CANNOT_REFERENCE_ITSELF', 124, "Type alias can reference itself only via the bounds of its generic parameters"); |
| |
| /** |
| * 12.11.2 Const: It is a compile-time error if <i>T</i> is not a class accessible in the current |
| * scope, optionally followed by type arguments. |
| */ |
| static final CompileTimeErrorCode UNDEFINED_CLASS = new CompileTimeErrorCode.con1('UNDEFINED_CLASS', 125, "Undefined class '%s'"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>C</i> be the class in which the superinitializer appears |
| * and let <i>S</i> be the superclass of <i>C</i>. Let <i>k</i> be a generative constructor. It is |
| * a compile-time error if class <i>S</i> does not declare a generative constructor named <i>S</i> |
| * (respectively <i>S.id</i>) |
| */ |
| static final CompileTimeErrorCode UNDEFINED_CONSTRUCTOR_IN_INITIALIZER = new CompileTimeErrorCode.con1('UNDEFINED_CONSTRUCTOR_IN_INITIALIZER', 126, "The class '%s' does not have a generative constructor '%s'"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Let <i>C</i> be the class in which the superinitializer appears |
| * and let <i>S</i> be the superclass of <i>C</i>. Let <i>k</i> be a generative constructor. It is |
| * a compile-time error if class <i>S</i> does not declare a generative constructor named <i>S</i> |
| * (respectively <i>S.id</i>) |
| */ |
| static final CompileTimeErrorCode UNDEFINED_CONSTRUCTOR_IN_INITIALIZER_DEFAULT = new CompileTimeErrorCode.con1('UNDEFINED_CONSTRUCTOR_IN_INITIALIZER_DEFAULT', 127, "The class '%s' does not have a default generative constructor"); |
| |
| /** |
| * 12.14.3 Unqualified Invocation: If there exists a lexically visible declaration named |
| * <i>id</i>, let <i>f<sub>id</sub></i> be the innermost such declaration. Then: [skip]. |
| * Otherwise, <i>i</i> is equivalent to <b>this</b>.<i>id</i>(<i>a<sub>1</sub></i>; ... |
| * <i>x<sub>n+k</sub></i> : <i>a<sub>n+k</sub></i>). |
| * |
| * @param methodName the name of the method that is undefined |
| */ |
| static final CompileTimeErrorCode UNDEFINED_FUNCTION = new CompileTimeErrorCode.con1('UNDEFINED_FUNCTION', 128, "The function '%s' is not defined"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: Furthermore, each <i>q<sub>i</sub></i>, <i>1<=i<=l</i>, |
| * must have a corresponding named parameter in the set {<i>p<sub>n+1</sub></i> ... |
| * <i>p<sub>n+k</sub></i>} or a static warning occurs. |
| * |
| * 12.11.2 Const: It is a compile-time error if evaluation of a constant object results in an |
| * uncaught exception being thrown. |
| * |
| * @param name the name of the requested named parameter |
| */ |
| static final CompileTimeErrorCode UNDEFINED_NAMED_PARAMETER = new CompileTimeErrorCode.con1('UNDEFINED_NAMED_PARAMETER', 129, "The named parameter '%s' is not defined"); |
| |
| /** |
| * 14.2 Exports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * 14.1 Imports: It is a compile-time error if the compilation unit found at the specified URI is |
| * not a library declaration. |
| * |
| * 14.3 Parts: It is a compile time error if the contents of the URI are not a valid part |
| * declaration. |
| * |
| * @param uri the URI pointing to a non-existent file |
| * @see #INVALID_URI |
| */ |
| static final CompileTimeErrorCode URI_DOES_NOT_EXIST = new CompileTimeErrorCode.con1('URI_DOES_NOT_EXIST', 130, "Target of URI does not exist: '%s'"); |
| |
| /** |
| * 14.1 Imports: It is a compile-time error if <i>x</i> is not a compile-time constant, or if |
| * <i>x</i> involves string interpolation. |
| * |
| * 14.3 Parts: It is a compile-time error if <i>s</i> is not a compile-time constant, or if |
| * <i>s</i> involves string interpolation. |
| * |
| * 14.5 URIs: It is a compile-time error if the string literal <i>x</i> that describes a URI is |
| * not a compile-time constant, or if <i>x</i> involves string interpolation. |
| */ |
| static final CompileTimeErrorCode URI_WITH_INTERPOLATION = new CompileTimeErrorCode.con1('URI_WITH_INTERPOLATION', 131, "URIs cannot use string interpolation"); |
| |
| /** |
| * 7.1.1 Operators: It is a compile-time error if the arity of the user-declared operator []= is |
| * not 2. It is a compile time error if the arity of a user-declared operator with one of the |
| * names: <, >, <=, >=, ==, +, /, ~/, *, %, |, ^, &, <<, >>, [] is not 1. |
| * It is a compile time error if the arity of the user-declared operator - is not 0 or 1. It is a |
| * compile time error if the arity of the user-declared operator ~ is not 0. |
| * |
| * @param operatorName the name of the declared operator |
| * @param expectedNumberOfParameters the number of parameters expected |
| * @param actualNumberOfParameters the number of parameters found in the operator declaration |
| */ |
| static final CompileTimeErrorCode WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR = new CompileTimeErrorCode.con1('WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR', 132, "Operator '%s' should declare exactly %d parameter(s), but %d found"); |
| |
| /** |
| * 7.1.1 Operators: It is a compile time error if the arity of the user-declared operator - is not |
| * 0 or 1. |
| * |
| * @param actualNumberOfParameters the number of parameters found in the operator declaration |
| */ |
| static final CompileTimeErrorCode WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR_MINUS = new CompileTimeErrorCode.con1('WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR_MINUS', 133, "Operator '-' should declare 0 or 1 parameter, but %d found"); |
| |
| /** |
| * 7.3 Setters: It is a compile-time error if a setter's formal parameter list does not include |
| * exactly one required formal parameter <i>p</i>. |
| */ |
| static final CompileTimeErrorCode WRONG_NUMBER_OF_PARAMETERS_FOR_SETTER = new CompileTimeErrorCode.con1('WRONG_NUMBER_OF_PARAMETERS_FOR_SETTER', 134, "Setters should declare exactly one required parameter"); |
| static final List<CompileTimeErrorCode> values = [ |
| AMBIGUOUS_EXPORT, |
| ARGUMENT_DEFINITION_TEST_NON_PARAMETER, |
| ARGUMENT_TYPE_NOT_ASSIGNABLE, |
| BUILT_IN_IDENTIFIER_AS_TYPE, |
| BUILT_IN_IDENTIFIER_AS_TYPE_NAME, |
| BUILT_IN_IDENTIFIER_AS_TYPEDEF_NAME, |
| BUILT_IN_IDENTIFIER_AS_TYPE_PARAMETER_NAME, |
| CASE_EXPRESSION_TYPE_IMPLEMENTS_EQUALS, |
| COMPILE_TIME_CONSTANT_RAISES_EXCEPTION, |
| CONFLICTING_GETTER_AND_METHOD, |
| CONFLICTING_METHOD_AND_GETTER, |
| CONFLICTING_CONSTRUCTOR_NAME_AND_FIELD, |
| CONFLICTING_CONSTRUCTOR_NAME_AND_METHOD, |
| CONST_CONSTRUCTOR_THROWS_EXCEPTION, |
| CONST_CONSTRUCTOR_WITH_NON_CONST_SUPER, |
| CONST_CONSTRUCTOR_WITH_NON_FINAL_FIELD, |
| CONST_FIELD_INITIALIZER_NOT_ASSIGNABLE, |
| CONST_FORMAL_PARAMETER, |
| CONST_INITIALIZED_WITH_NON_CONSTANT_VALUE, |
| CONST_INSTANCE_FIELD, |
| CONST_NOT_INITIALIZED, |
| CONST_EVAL_TYPE_BOOL, |
| CONST_EVAL_TYPE_BOOL_NUM_STRING, |
| CONST_EVAL_TYPE_INT, |
| CONST_EVAL_TYPE_NUM, |
| CONST_EVAL_THROWS_EXCEPTION, |
| CONST_EVAL_THROWS_IDBZE, |
| CONST_WITH_INVALID_TYPE_PARAMETERS, |
| CONST_WITH_NON_CONST, |
| CONST_WITH_NON_CONSTANT_ARGUMENT, |
| CONST_WITH_NON_TYPE, |
| CONST_WITH_TYPE_PARAMETERS, |
| CONST_WITH_UNDEFINED_CONSTRUCTOR, |
| CONST_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT, |
| DEFAULT_VALUE_IN_FUNCTION_TYPE_ALIAS, |
| DEFAULT_VALUE_IN_FUNCTION_TYPED_PARAMETER, |
| DUPLICATE_CONSTRUCTOR_DEFAULT, |
| DUPLICATE_CONSTRUCTOR_NAME, |
| DUPLICATE_DEFINITION, |
| DUPLICATE_DEFINITION_INHERITANCE, |
| DUPLICATE_NAMED_ARGUMENT, |
| EXPORT_INTERNAL_LIBRARY, |
| EXPORT_OF_NON_LIBRARY, |
| EXTENDS_NON_CLASS, |
| EXTENDS_DISALLOWED_CLASS, |
| EXTRA_POSITIONAL_ARGUMENTS, |
| FIELD_INITIALIZED_BY_MULTIPLE_INITIALIZERS, |
| FIELD_INITIALIZED_IN_PARAMETER_AND_INITIALIZER, |
| FINAL_INITIALIZED_MULTIPLE_TIMES, |
| FIELD_INITIALIZER_FACTORY_CONSTRUCTOR, |
| FIELD_INITIALIZER_OUTSIDE_CONSTRUCTOR, |
| FIELD_INITIALIZER_REDIRECTING_CONSTRUCTOR, |
| GETTER_AND_METHOD_WITH_SAME_NAME, |
| IMPLEMENTS_DISALLOWED_CLASS, |
| IMPLEMENTS_DYNAMIC, |
| IMPLEMENTS_NON_CLASS, |
| IMPLEMENTS_REPEATED, |
| IMPLEMENTS_SUPER_CLASS, |
| IMPLICIT_THIS_REFERENCE_IN_INITIALIZER, |
| IMPORT_INTERNAL_LIBRARY, |
| IMPORT_OF_NON_LIBRARY, |
| INCONSISTENT_CASE_EXPRESSION_TYPES, |
| INITIALIZER_FOR_NON_EXISTANT_FIELD, |
| INITIALIZER_FOR_STATIC_FIELD, |
| INITIALIZING_FORMAL_FOR_NON_EXISTANT_FIELD, |
| INITIALIZING_FORMAL_FOR_STATIC_FIELD, |
| INSTANCE_MEMBER_ACCESS_FROM_STATIC, |
| INVALID_ANNOTATION, |
| INVALID_CONSTANT, |
| INVALID_CONSTRUCTOR_NAME, |
| INVALID_FACTORY_NAME_NOT_A_CLASS, |
| INVALID_REFERENCE_TO_THIS, |
| INVALID_TYPE_ARGUMENT_IN_CONST_LIST, |
| INVALID_TYPE_ARGUMENT_IN_CONST_MAP, |
| INVALID_URI, |
| LABEL_IN_OUTER_SCOPE, |
| LABEL_UNDEFINED, |
| LIST_ELEMENT_TYPE_NOT_ASSIGNABLE, |
| MAP_KEY_TYPE_NOT_ASSIGNABLE, |
| MAP_VALUE_TYPE_NOT_ASSIGNABLE, |
| MEMBER_WITH_CLASS_NAME, |
| METHOD_AND_GETTER_WITH_SAME_NAME, |
| MISSING_CONST_IN_LIST_LITERAL, |
| MISSING_CONST_IN_MAP_LITERAL, |
| MIXIN_DECLARES_CONSTRUCTOR, |
| MIXIN_INHERITS_FROM_NOT_OBJECT, |
| MIXIN_OF_DISALLOWED_CLASS, |
| MIXIN_OF_NON_CLASS, |
| MIXIN_REFERENCES_SUPER, |
| MIXIN_WITH_NON_CLASS_SUPERCLASS, |
| MULTIPLE_REDIRECTING_CONSTRUCTOR_INVOCATIONS, |
| MULTIPLE_SUPER_INITIALIZERS, |
| NO_ANNOTATION_CONSTRUCTOR_ARGUMENTS, |
| NO_DEFAULT_SUPER_CONSTRUCTOR_EXPLICIT, |
| NO_DEFAULT_SUPER_CONSTRUCTOR_IMPLICIT, |
| NON_CONST_MAP_AS_EXPRESSION_STATEMENT, |
| NON_CONSTANT_CASE_EXPRESSION, |
| NON_CONSTANT_DEFAULT_VALUE, |
| NON_CONSTANT_LIST_ELEMENT, |
| NON_CONSTANT_MAP_KEY, |
| NON_CONSTANT_MAP_VALUE, |
| NON_CONSTANT_ANNOTATION_CONSTRUCTOR, |
| NON_CONSTANT_VALUE_IN_INITIALIZER, |
| NOT_ENOUGH_REQUIRED_ARGUMENTS, |
| NON_GENERATIVE_CONSTRUCTOR, |
| OBJECT_CANNOT_EXTEND_ANOTHER_CLASS, |
| OPTIONAL_PARAMETER_IN_OPERATOR, |
| PART_OF_NON_PART, |
| PREFIX_COLLIDES_WITH_TOP_LEVEL_MEMBER, |
| PRIVATE_OPTIONAL_PARAMETER, |
| RECURSIVE_COMPILE_TIME_CONSTANT, |
| RECURSIVE_CONSTRUCTOR_REDIRECT, |
| RECURSIVE_FACTORY_REDIRECT, |
| RECURSIVE_INTERFACE_INHERITANCE, |
| RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_EXTENDS, |
| RECURSIVE_INTERFACE_INHERITANCE_BASE_CASE_IMPLEMENTS, |
| REDIRECT_TO_NON_CONST_CONSTRUCTOR, |
| REFERENCE_TO_DECLARED_VARIABLE_IN_INITIALIZER, |
| RETHROW_OUTSIDE_CATCH, |
| RETURN_IN_GENERATIVE_CONSTRUCTOR, |
| SUPER_IN_INVALID_CONTEXT, |
| SUPER_IN_REDIRECTING_CONSTRUCTOR, |
| SUPER_INITIALIZER_IN_OBJECT, |
| TYPE_ARGUMENT_NOT_MATCHING_BOUNDS, |
| TYPE_ALIAS_CANNOT_REFERENCE_ITSELF, |
| UNDEFINED_CLASS, |
| UNDEFINED_CONSTRUCTOR_IN_INITIALIZER, |
| UNDEFINED_CONSTRUCTOR_IN_INITIALIZER_DEFAULT, |
| UNDEFINED_FUNCTION, |
| UNDEFINED_NAMED_PARAMETER, |
| URI_DOES_NOT_EXIST, |
| URI_WITH_INTERPOLATION, |
| WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR, |
| WRONG_NUMBER_OF_PARAMETERS_FOR_OPERATOR_MINUS, |
| WRONG_NUMBER_OF_PARAMETERS_FOR_SETTER]; |
| |
| /** |
| * The template used to create the message to be displayed for this error. |
| */ |
| String _message; |
| |
| /** |
| * The template used to create the correction to be displayed for this error, or `null` if |
| * there is no correction information for this error. |
| */ |
| String correction2; |
| |
| /** |
| * Initialize a newly created error code to have the given message. |
| * |
| * @param message the message template used to create the message to be displayed for the error |
| */ |
| CompileTimeErrorCode.con1(String name, int ordinal, String message) : super(name, ordinal) { |
| this._message = message; |
| } |
| |
| /** |
| * Initialize a newly created error code to have the given message and correction. |
| * |
| * @param message the template used to create the message to be displayed for the error |
| * @param correction the template used to create the correction to be displayed for the error |
| */ |
| CompileTimeErrorCode.con2(String name, int ordinal, String message, String correction) : super(name, ordinal) { |
| this._message = message; |
| this.correction2 = correction; |
| } |
| String get correction => correction2; |
| ErrorSeverity get errorSeverity => ErrorType.COMPILE_TIME_ERROR.severity; |
| String get message => _message; |
| ErrorType get type => ErrorType.COMPILE_TIME_ERROR; |
| } |
| /** |
| * The enumeration `PubSuggestionCode` defines the suggestions used for reporting deviations |
| * from pub best practices. The convention for this class is for the name of the bad practice to |
| * indicate the problem that caused the suggestion to be generated and for the message to explain |
| * what is wrong and, when appropriate, how the situation can be corrected. |
| */ |
| class PubSuggestionCode extends Enum<PubSuggestionCode> implements ErrorCode { |
| |
| /** |
| * It is a bad practice for a source file in a package "lib" directory hierarchy to traverse |
| * outside that directory hierarchy. For example, a source file in the "lib" directory should not |
| * contain a directive such as `import '../web/some.dart'` which references a file outside |
| * the lib directory. |
| */ |
| static final PubSuggestionCode FILE_IMPORT_INSIDE_LIB_REFERENCES_FILE_OUTSIDE = new PubSuggestionCode.con1('FILE_IMPORT_INSIDE_LIB_REFERENCES_FILE_OUTSIDE', 0, "A file in the 'lib' directory hierarchy should not reference a file outside that hierarchy"); |
| |
| /** |
| * It is a bad practice for a source file ouside a package "lib" directory hierarchy to traverse |
| * into that directory hierarchy. For example, a source file in the "web" directory should not |
| * contain a directive such as `import '../lib/some.dart'` which references a file inside |
| * the lib directory. |
| */ |
| static final PubSuggestionCode FILE_IMPORT_OUTSIDE_LIB_REFERENCES_FILE_INSIDE = new PubSuggestionCode.con1('FILE_IMPORT_OUTSIDE_LIB_REFERENCES_FILE_INSIDE', 1, "A file outside the 'lib' directory hierarchy should not reference a file inside that hierarchy. Use a package: reference instead."); |
| |
| /** |
| * It is a bad practice for a package import to reference anything outside the given package, or |
| * more generally, it is bad practice for a package import to contain a "..". For example, a |
| * source file should not contain a directive such as `import 'package:foo/../some.dart'`. |
| */ |
| static final PubSuggestionCode PACKAGE_IMPORT_CONTAINS_DOT_DOT = new PubSuggestionCode.con1('PACKAGE_IMPORT_CONTAINS_DOT_DOT', 2, "A package import should not contain '..'"); |
| static final List<PubSuggestionCode> values = [ |
| FILE_IMPORT_INSIDE_LIB_REFERENCES_FILE_OUTSIDE, |
| FILE_IMPORT_OUTSIDE_LIB_REFERENCES_FILE_INSIDE, |
| PACKAGE_IMPORT_CONTAINS_DOT_DOT]; |
| |
| /** |
| * The template used to create the message to be displayed for this error. |
| */ |
| String _message; |
| |
| /** |
| * The template used to create the correction to be displayed for this error, or `null` if |
| * there is no correction information for this error. |
| */ |
| String correction5; |
| |
| /** |
| * Initialize a newly created error code to have the given message. |
| * |
| * @param message the message template used to create the message to be displayed for the error |
| */ |
| PubSuggestionCode.con1(String name, int ordinal, String message) : super(name, ordinal) { |
| this._message = message; |
| } |
| |
| /** |
| * Initialize a newly created error code to have the given message and correction. |
| * |
| * @param message the template used to create the message to be displayed for the error |
| * @param correction the template used to create the correction to be displayed for the error |
| */ |
| PubSuggestionCode.con2(String name, int ordinal, String message, String correction) : super(name, ordinal) { |
| this._message = message; |
| this.correction5 = correction; |
| } |
| String get correction => correction5; |
| ErrorSeverity get errorSeverity => ErrorType.PUB_SUGGESTION.severity; |
| String get message => _message; |
| ErrorType get type => ErrorType.PUB_SUGGESTION; |
| } |
| /** |
| * The enumeration `StaticWarningCode` defines the error codes used for static warnings. The |
| * convention for this class is for the name of the error code to indicate the problem that caused |
| * the error to be generated and for the error message to explain what is wrong and, when |
| * appropriate, how the problem can be corrected. |
| * |
| * @coverage dart.engine.error |
| */ |
| class StaticWarningCode extends Enum<StaticWarningCode> implements ErrorCode { |
| |
| /** |
| * 14.1 Imports: If a name <i>N</i> is referenced by a library <i>L</i> and <i>N</i> is introduced |
| * into the top level scope <i>L</i> by more than one import then: |
| * <ol> |
| * * A static warning occurs. |
| * * If <i>N</i> is referenced as a function, getter or setter, a <i>NoSuchMethodError</i> is |
| * raised. |
| * * If <i>N</i> is referenced as a type, it is treated as a malformed type. |
| * </ol> |
| * |
| * @param ambiguousTypeName the name of the ambiguous type |
| * @param firstLibraryName the name of the first library that the type is found |
| * @param secondLibraryName the name of the second library that the type is found |
| */ |
| static final StaticWarningCode AMBIGUOUS_IMPORT = new StaticWarningCode.con1('AMBIGUOUS_IMPORT', 0, "The type '%s' is defined in the libraries '%s' and '%s'"); |
| |
| /** |
| * 12.11.1 New: It is a static warning if the static type of <i>a<sub>i</sub>, 1 <= i <= n+ |
| * k</i> may not be assigned to the type of the corresponding formal parameter of the constructor |
| * <i>T.id</i> (respectively <i>T</i>). |
| * |
| * 12.11.2 Const: It is a static warning if the static type of <i>a<sub>i</sub>, 1 <= i <= |
| * n+ k</i> may not be assigned to the type of the corresponding formal parameter of the |
| * constructor <i>T.id</i> (respectively <i>T</i>). |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| * |
| * 12.14.2 Binding Actuals to Formals: Furthermore, each <i>q<sub>i</sub>, 1 <= i <= l</i>, |
| * must have a corresponding named parameter in the set <i>{p<sub>n+1</sub>, … |
| * p<sub>n+k</sub>}</i> or a static warning occurs. It is a static warning if |
| * <i>T<sub>m+j</sub></i> may not be assigned to <i>S<sub>r</sub></i>, where <i>r = q<sub>j</sub>, |
| * 1 <= j <= l</i>. |
| */ |
| static final StaticWarningCode ARGUMENT_TYPE_NOT_ASSIGNABLE = new StaticWarningCode.con1('ARGUMENT_TYPE_NOT_ASSIGNABLE', 1, "The argument type '%s' cannot be assigned to the parameter type '%s'"); |
| |
| /** |
| * 5 Variables: Attempting to assign to a final variable elsewhere will cause a NoSuchMethodError |
| * to be thrown, because no setter is defined for it. The assignment will also give rise to a |
| * static warning for the same reason. |
| * |
| * A constant variable is always implicitly final. |
| */ |
| static final StaticWarningCode ASSIGNMENT_TO_CONST = new StaticWarningCode.con1('ASSIGNMENT_TO_CONST', 2, "Constant variables cannot be assigned a value"); |
| |
| /** |
| * 5 Variables: Attempting to assign to a final variable elsewhere will cause a NoSuchMethodError |
| * to be thrown, because no setter is defined for it. The assignment will also give rise to a |
| * static warning for the same reason. |
| */ |
| static final StaticWarningCode ASSIGNMENT_TO_FINAL = new StaticWarningCode.con1('ASSIGNMENT_TO_FINAL', 3, "Final variables cannot be assigned a value"); |
| |
| /** |
| * 12.18 Assignment: Let <i>T</i> be the static type of <i>e<sub>1</sub></i>. It is a static type |
| * warning if <i>T</i> does not have an accessible instance setter named <i>v =</i>. |
| */ |
| static final StaticWarningCode ASSIGNMENT_TO_METHOD = new StaticWarningCode.con1('ASSIGNMENT_TO_METHOD', 4, "Methods cannot be assigned a value"); |
| |
| /** |
| * 13.9 Switch: It is a static warning if the last statement of the statement sequence |
| * <i>s<sub>k</sub></i> is not a break, continue, return or throw statement. |
| */ |
| static final StaticWarningCode CASE_BLOCK_NOT_TERMINATED = new StaticWarningCode.con1('CASE_BLOCK_NOT_TERMINATED', 5, "The last statement of the 'case' should be 'break', 'continue', 'return' or 'throw'"); |
| |
| /** |
| * 12.32 Type Cast: It is a static warning if <i>T</i> does not denote a type available in the |
| * current lexical scope. |
| */ |
| static final StaticWarningCode CAST_TO_NON_TYPE = new StaticWarningCode.con1('CAST_TO_NON_TYPE', 6, "The name '%s' is not a type and cannot be used in an 'as' expression"); |
| |
| /** |
| * 16.1.2 Comments: A token of the form <i>[new c](uri)</i> will be replaced by a link in the |
| * formatted output. The link will point at the constructor named <i>c</i> in <i>L</i>. The title |
| * of the link will be <i>c</i>. It is a static warning if uri is not the URI of a dart library |
| * <i>L</i>, or if <i>c</i> is not the name of a constructor of a class declared in the exported |
| * namespace of <i>L</i>. |
| */ |
| static final StaticWarningCode COMMENT_REFERENCE_CONSTRUCTOR_NOT_VISIBLE = new StaticWarningCode.con1('COMMENT_REFERENCE_CONSTRUCTOR_NOT_VISIBLE', 7, ""); |
| |
| /** |
| * 16.1.2 Comments: A token of the form <i>[id](uri)</i> will be replaced by a link in the |
| * formatted output. The link will point at the declaration named <i>id</i> in <i>L</i>. The title |
| * of the link will be <i>id</i>. It is a static warning if uri is not the URI of a dart library |
| * <i>L</i>, or if <i>id</i> is not a name declared in the exported namespace of <i>L</i>. |
| */ |
| static final StaticWarningCode COMMENT_REFERENCE_IDENTIFIER_NOT_VISIBLE = new StaticWarningCode.con1('COMMENT_REFERENCE_IDENTIFIER_NOT_VISIBLE', 8, ""); |
| |
| /** |
| * 16.1.2 Comments: It is a static warning if <i>c</i> does not denote a constructor that |
| * available in the scope of the documentation comment. |
| */ |
| static final StaticWarningCode COMMENT_REFERENCE_UNDECLARED_CONSTRUCTOR = new StaticWarningCode.con1('COMMENT_REFERENCE_UNDECLARED_CONSTRUCTOR', 9, ""); |
| |
| /** |
| * 16.1.2 Comments: It is a static warning if <i>id</i> does not denote a declaration that |
| * available in the scope of the documentation comment. |
| */ |
| static final StaticWarningCode COMMENT_REFERENCE_UNDECLARED_IDENTIFIER = new StaticWarningCode.con1('COMMENT_REFERENCE_UNDECLARED_IDENTIFIER', 10, ""); |
| |
| /** |
| * 16.1.2 Comments: A token of the form <i>[id](uri)</i> will be replaced by a link in the |
| * formatted output. The link will point at the declaration named <i>id</i> in <i>L</i>. The title |
| * of the link will be <i>id</i>. It is a static warning if uri is not the URI of a dart library |
| * <i>L</i>, or if <i>id</i> is not a name declared in the exported namespace of <i>L</i>. |
| */ |
| static final StaticWarningCode COMMENT_REFERENCE_URI_NOT_LIBRARY = new StaticWarningCode.con1('COMMENT_REFERENCE_URI_NOT_LIBRARY', 11, ""); |
| |
| /** |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class. |
| */ |
| static final StaticWarningCode CONCRETE_CLASS_WITH_ABSTRACT_MEMBER = new StaticWarningCode.con1('CONCRETE_CLASS_WITH_ABSTRACT_MEMBER', 12, "'%s' must have a method body because '%s' is not abstract"); |
| |
| /** |
| * 7.2 Getters: It is a static warning if a class <i>C</i> declares an instance getter named |
| * <i>v</i> and an accessible static member named <i>v</i> or <i>v=</i> is declared in a |
| * superclass of <i>C</i>. |
| * |
| * @param superName the name of the super class declaring a static member |
| */ |
| static final StaticWarningCode CONFLICTING_INSTANCE_GETTER_AND_SUPERCLASS_MEMBER = new StaticWarningCode.con1('CONFLICTING_INSTANCE_GETTER_AND_SUPERCLASS_MEMBER', 13, "Superclass '%s' declares static member with the same name"); |
| |
| /** |
| * 7.3 Setters: It is a static warning if a class <i>C</i> declares an instance setter named |
| * <i>v=</i> and an accessible static member named <i>v=</i> or <i>v</i> is declared in a |
| * superclass of <i>C</i>. |
| * |
| * @param superName the name of the super class declaring a static member |
| */ |
| static final StaticWarningCode CONFLICTING_INSTANCE_SETTER_AND_SUPERCLASS_MEMBER = new StaticWarningCode.con1('CONFLICTING_INSTANCE_SETTER_AND_SUPERCLASS_MEMBER', 14, "Superclass '%s' declares static member with the same name"); |
| |
| /** |
| * 7.2 Getters: It is a static warning if a class declares a static getter named <i>v</i> and also |
| * has a non-static setter named <i>v=</i>. |
| */ |
| static final StaticWarningCode CONFLICTING_STATIC_GETTER_AND_INSTANCE_SETTER = new StaticWarningCode.con1('CONFLICTING_STATIC_GETTER_AND_INSTANCE_SETTER', 15, "Class '%s' declares non-static setter with the same name"); |
| |
| /** |
| * 7.3 Setters: It is a static warning if a class declares a static setter named <i>v=</i> and |
| * also has a non-static member named <i>v</i>. |
| */ |
| static final StaticWarningCode CONFLICTING_STATIC_SETTER_AND_INSTANCE_MEMBER = new StaticWarningCode.con1('CONFLICTING_STATIC_SETTER_AND_INSTANCE_MEMBER', 16, "Class '%s' declares non-static member with the same name"); |
| |
| /** |
| * 12.11.2 Const: Given an instance creation expression of the form <i>const q(a<sub>1</sub>, |
| * … a<sub>n</sub>)</i> it is a static warning if <i>q</i> is the constructor of an |
| * abstract class but <i>q</i> is not a factory constructor. |
| */ |
| static final StaticWarningCode CONST_WITH_ABSTRACT_CLASS = new StaticWarningCode.con1('CONST_WITH_ABSTRACT_CLASS', 17, "Abstract classes cannot be created with a 'const' expression"); |
| |
| /** |
| * 12.7 Maps: It is a static warning if the values of any two keys in a map literal are equal. |
| */ |
| static final StaticWarningCode EQUAL_KEYS_IN_MAP = new StaticWarningCode.con1('EQUAL_KEYS_IN_MAP', 18, "Keys in a map cannot be equal"); |
| |
| /** |
| * 14.2 Exports: It is a static warning to export two different libraries with the same name. |
| * |
| * @param uri1 the uri pointing to a first library |
| * @param uri2 the uri pointing to a second library |
| * @param name the shared name of the exported libraries |
| */ |
| static final StaticWarningCode EXPORT_DUPLICATED_LIBRARY_NAME = new StaticWarningCode.con1('EXPORT_DUPLICATED_LIBRARY_NAME', 19, "The exported libraries '%s' and '%s' should not have the same name '%s'"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: It is a static warning if <i>m < h</i> or if <i>m > |
| * n</i>. |
| * |
| * @param requiredCount the maximum number of positional arguments |
| * @param argumentCount the actual number of positional arguments given |
| * @see #NOT_ENOUGH_REQUIRED_ARGUMENTS |
| */ |
| static final StaticWarningCode EXTRA_POSITIONAL_ARGUMENTS = new StaticWarningCode.con1('EXTRA_POSITIONAL_ARGUMENTS', 20, "%d positional arguments expected, but %d found"); |
| |
| /** |
| * 5. Variables: It is a static warning if a final instance variable that has been initialized at |
| * its point of declaration is also initialized in a constructor. |
| */ |
| static final StaticWarningCode FIELD_INITIALIZED_IN_INITIALIZER_AND_DECLARATION = new StaticWarningCode.con1('FIELD_INITIALIZED_IN_INITIALIZER_AND_DECLARATION', 21, "Values cannot be set in the constructor if they are final, and have already been set"); |
| |
| /** |
| * 5. Variables: It is a static warning if a final instance variable that has been initialized at |
| * its point of declaration is also initialized in a constructor. |
| * |
| * @param name the name of the field in question |
| */ |
| static final StaticWarningCode FINAL_INITIALIZED_IN_DECLARATION_AND_CONSTRUCTOR = new StaticWarningCode.con1('FINAL_INITIALIZED_IN_DECLARATION_AND_CONSTRUCTOR', 22, "'%s' is final and was given a value when it was declared, so it cannot be set to a new value"); |
| |
| /** |
| * 7.6.1 Generative Constructors: Execution of an initializer of the form <b>this</b>.<i>v</i> = |
| * <i>e</i> proceeds as follows: First, the expression <i>e</i> is evaluated to an object |
| * <i>o</i>. Then, the instance variable <i>v</i> of the object denoted by this is bound to |
| * <i>o</i>. |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| * |
| * @param initializerType the name of the type of the initializer expression |
| * @param fieldType the name of the type of the field |
| */ |
| static final StaticWarningCode FIELD_INITIALIZER_NOT_ASSIGNABLE = new StaticWarningCode.con1('FIELD_INITIALIZER_NOT_ASSIGNABLE', 23, "The initializer type '%s' cannot be assigned to the field type '%s'"); |
| |
| /** |
| * 7.6.1 Generative Constructors: An initializing formal has the form <i>this.id</i>. It is a |
| * static warning if the static type of <i>id</i> is not assignable to <i>T<sub>id</sub></i>. |
| * |
| * @param parameterType the name of the type of the field formal parameter |
| * @param fieldType the name of the type of the field |
| */ |
| static final StaticWarningCode FIELD_INITIALIZING_FORMAL_NOT_ASSIGNABLE = new StaticWarningCode.con1('FIELD_INITIALIZING_FORMAL_NOT_ASSIGNABLE', 24, "The parameter type '%s' is incompatable with the field type '%s'"); |
| |
| /** |
| * 5 Variables: It is a static warning if a library, static or local variable <i>v</i> is final |
| * and <i>v</i> is not initialized at its point of declaration. |
| * |
| * 7.6.1 Generative Constructors: Each final instance variable <i>f</i> declared in the |
| * immediately enclosing class must have an initializer in <i>k</i>'s initializer list unless it |
| * has already been initialized by one of the following means: |
| * |
| * * Initialization at the declaration of <i>f</i>. |
| * * Initialization by means of an initializing formal of <i>k</i>. |
| * |
| * or a static warning occurs. |
| * |
| * @param name the name of the uninitialized final variable |
| */ |
| static final StaticWarningCode FINAL_NOT_INITIALIZED = new StaticWarningCode.con1('FINAL_NOT_INITIALIZED', 25, "The final variable '%s' must be initialized"); |
| |
| /** |
| * 14.1 Imports: It is a static warning to import two different libraries with the same name. |
| * |
| * @param uri1 the uri pointing to a first library |
| * @param uri2 the uri pointing to a second library |
| * @param name the shared name of the imported libraries |
| */ |
| static final StaticWarningCode IMPORT_DUPLICATED_LIBRARY_NAME = new StaticWarningCode.con1('IMPORT_DUPLICATED_LIBRARY_NAME', 26, "The imported libraries '%s' and '%s' should not have the same name '%s'"); |
| |
| /** |
| * 8.1.1 Inheritance and Overriding: However, if there are multiple members <i>m<sub>1</sub>, |
| * … m<sub>k</sub></i> with the same name <i>n</i> that would be inherited (because |
| * identically named members existed in several superinterfaces) then at most one member is |
| * inherited. |
| * |
| * If some but not all of the <i>m<sub>i</sub>, 1 <= i <= k</i>, are getters, or if some but |
| * not all of the <i>m<sub>i</sub></i> are setters, none of the <i>m<sub>i</sub></i> are |
| * inherited, and a static warning is issued. |
| */ |
| static final StaticWarningCode INCONSISTENT_METHOD_INHERITANCE_GETTER_AND_METHOD = new StaticWarningCode.con1('INCONSISTENT_METHOD_INHERITANCE_GETTER_AND_METHOD', 27, "'%s' is inherited as a getter and also a method"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if a class <i>C</i> declares an instance method |
| * named <i>n</i> and an accessible static member named <i>n</i> is declared in a superclass of |
| * <i>C</i>. |
| * |
| * @param memberName the name of the member with the name conflict |
| * @param superclassName the name of the enclosing class that has the static member |
| */ |
| static final StaticWarningCode INSTANCE_METHOD_NAME_COLLIDES_WITH_SUPERCLASS_STATIC = new StaticWarningCode.con1('INSTANCE_METHOD_NAME_COLLIDES_WITH_SUPERCLASS_STATIC', 28, "'%s' collides with a static member in the superclass '%s'"); |
| |
| /** |
| * 7.2 Getters: It is a static warning if a getter <i>m1</i> overrides a getter <i>m2</i> and the |
| * type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualReturnTypeName the name of the expected return type |
| * @param expectedReturnType the name of the actual return type, not assignable to the |
| * actualReturnTypeName |
| * @param className the name of the class where the overridden getter is declared |
| * @see #INVALID_METHOD_OVERRIDE_RETURN_TYPE |
| */ |
| static final StaticWarningCode INVALID_GETTER_OVERRIDE_RETURN_TYPE = new StaticWarningCode.con1('INVALID_GETTER_OVERRIDE_RETURN_TYPE', 29, "The return type '%s' is not assignable to '%s' as required by the getter it is overriding from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance method <i>m2</i> and the type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualParamTypeName the name of the expected parameter type |
| * @param expectedParamType the name of the actual parameter type, not assignable to the |
| * actualParamTypeName |
| * @param className the name of the class where the overridden method is declared |
| */ |
| static final StaticWarningCode INVALID_METHOD_OVERRIDE_NAMED_PARAM_TYPE = new StaticWarningCode.con1('INVALID_METHOD_OVERRIDE_NAMED_PARAM_TYPE', 30, "The parameter type '%s' is not assignable to '%s' as required by the method it is overriding from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance method <i>m2</i> and the type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualParamTypeName the name of the expected parameter type |
| * @param expectedParamType the name of the actual parameter type, not assignable to the |
| * actualParamTypeName |
| * @param className the name of the class where the overridden method is declared |
| * @see #INVALID_SETTER_OVERRIDE_NORMAL_PARAM_TYPE |
| */ |
| static final StaticWarningCode INVALID_METHOD_OVERRIDE_NORMAL_PARAM_TYPE = new StaticWarningCode.con1('INVALID_METHOD_OVERRIDE_NORMAL_PARAM_TYPE', 31, "The parameter type '%s' is not assignable to '%s' as required by the method it is overriding from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance method <i>m2</i> and the type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualParamTypeName the name of the expected parameter type |
| * @param expectedParamType the name of the actual parameter type, not assignable to the |
| * actualParamTypeName |
| * @param className the name of the class where the overridden method is declared |
| */ |
| static final StaticWarningCode INVALID_METHOD_OVERRIDE_OPTIONAL_PARAM_TYPE = new StaticWarningCode.con1('INVALID_METHOD_OVERRIDE_OPTIONAL_PARAM_TYPE', 32, "The parameter type '%s' is not assignable to '%s' as required by the method it is overriding from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance method <i>m2</i> and the type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualReturnTypeName the name of the expected return type |
| * @param expectedReturnType the name of the actual return type, not assignable to the |
| * actualReturnTypeName |
| * @param className the name of the class where the overridden method is declared |
| * @see #INVALID_GETTER_OVERRIDE_RETURN_TYPE |
| */ |
| static final StaticWarningCode INVALID_METHOD_OVERRIDE_RETURN_TYPE = new StaticWarningCode.con1('INVALID_METHOD_OVERRIDE_RETURN_TYPE', 33, "The return type '%s' is not assignable to '%s' as required by the method it is overriding from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance member <i>m2</i>, the signature of <i>m2</i> explicitly specifies a default value for |
| * a formal parameter <i>p</i> and the signature of <i>m1</i> specifies a different default value |
| * for <i>p</i>. |
| */ |
| static final StaticWarningCode INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_NAMED = new StaticWarningCode.con1('INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_NAMED', 34, "Parameters cannot override default values, this method overrides '%s.%s' where '%s' has a different value"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance member <i>m2</i>, the signature of <i>m2</i> explicitly specifies a default value for |
| * a formal parameter <i>p</i> and the signature of <i>m1</i> specifies a different default value |
| * for <i>p</i>. |
| */ |
| static final StaticWarningCode INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_POSITIONAL = new StaticWarningCode.con1('INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_POSITIONAL', 35, "Parameters cannot override default values, this method overrides '%s.%s' where this positional parameter has a different value"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance member <i>m2</i> and <i>m1</i> does not declare all the named parameters declared by |
| * <i>m2</i>. |
| * |
| * @param paramCount the number of named parameters in the overridden member |
| * @param className the name of the class from the overridden method |
| */ |
| static final StaticWarningCode INVALID_OVERRIDE_NAMED = new StaticWarningCode.con1('INVALID_OVERRIDE_NAMED', 36, "Missing the named parameter '%s' to match the overridden method from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance member <i>m2</i> and <i>m1</i> has fewer optional positional parameters than |
| * <i>m2</i>. |
| * |
| * @param paramCount the number of positional parameters in the overridden member |
| * @param className the name of the class from the overridden method |
| */ |
| static final StaticWarningCode INVALID_OVERRIDE_POSITIONAL = new StaticWarningCode.con1('INVALID_OVERRIDE_POSITIONAL', 37, "Must have at least %d optional parameters to match the overridden method from '%s'"); |
| |
| /** |
| * 7.1 Instance Methods: It is a static warning if an instance method <i>m1</i> overrides an |
| * instance member <i>m2</i> and <i>m1</i> has a greater number of required parameters than |
| * <i>m2</i>. |
| * |
| * @param paramCount the number of required parameters in the overridden member |
| * @param className the name of the class from the overridden method |
| */ |
| static final StaticWarningCode INVALID_OVERRIDE_REQUIRED = new StaticWarningCode.con1('INVALID_OVERRIDE_REQUIRED', 38, "Must have %d required parameters or less to match the overridden method from '%s'"); |
| |
| /** |
| * 7.3 Setters: It is a static warning if a setter <i>m1</i> overrides a setter <i>m2</i> and the |
| * type of <i>m1</i> is not a subtype of the type of <i>m2</i>. |
| * |
| * @param actualParamTypeName the name of the expected parameter type |
| * @param expectedParamType the name of the actual parameter type, not assignable to the |
| * actualParamTypeName |
| * @param className the name of the class where the overridden setter is declared |
| * @see #INVALID_METHOD_OVERRIDE_NORMAL_PARAM_TYPE |
| */ |
| static final StaticWarningCode INVALID_SETTER_OVERRIDE_NORMAL_PARAM_TYPE = new StaticWarningCode.con1('INVALID_SETTER_OVERRIDE_NORMAL_PARAM_TYPE', 39, "The parameter type '%s' is not assignable to '%s' as required by the setter it is overriding from '%s'"); |
| |
| /** |
| * 12.6 Lists: A run-time list literal <<i>E</i>> [<i>e<sub>1</sub></i> ... |
| * <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>a</i> with first argument <i>i</i> and second argument |
| * <i>o<sub>i+1</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final StaticWarningCode LIST_ELEMENT_TYPE_NOT_ASSIGNABLE = new StaticWarningCode.con1('LIST_ELEMENT_TYPE_NOT_ASSIGNABLE', 40, "The element type '%s' cannot be assigned to the list type '%s'"); |
| |
| /** |
| * 12.7 Map: A run-time map literal <<i>K</i>, <i>V</i>> [<i>k<sub>1</sub></i> : |
| * <i>e<sub>1</sub></i> ... <i>k<sub>n</sub></i> : <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>m</i> with first argument <i>k<sub>i</sub></i> and second |
| * argument <i>e<sub>i</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final StaticWarningCode MAP_KEY_TYPE_NOT_ASSIGNABLE = new StaticWarningCode.con1('MAP_KEY_TYPE_NOT_ASSIGNABLE', 41, "The element type '%s' cannot be assigned to the map key type '%s'"); |
| |
| /** |
| * 12.7 Map: A run-time map literal <<i>K</i>, <i>V</i>> [<i>k<sub>1</sub></i> : |
| * <i>e<sub>1</sub></i> ... <i>k<sub>n</sub></i> : <i>e<sub>n</sub></i>] is evaluated as follows: |
| * |
| * * The operator []= is invoked on <i>m</i> with first argument <i>k<sub>i</sub></i> and second |
| * argument <i>e<sub>i</sub></i><i>, 1 <= i <= n</i> |
| * |
| * |
| * 12.14.2 Binding Actuals to Formals: Let <i>T<sub>i</sub></i> be the static type of |
| * <i>a<sub>i</sub></i>, let <i>S<sub>i</sub></i> be the type of <i>p<sub>i</sub>, 1 <= i <= |
| * n+k</i> and let <i>S<sub>q</sub></i> be the type of the named parameter <i>q</i> of <i>f</i>. |
| * It is a static warning if <i>T<sub>j</sub></i> may not be assigned to <i>S<sub>j</sub>, 1 <= |
| * j <= m</i>. |
| */ |
| static final StaticWarningCode MAP_VALUE_TYPE_NOT_ASSIGNABLE = new StaticWarningCode.con1('MAP_VALUE_TYPE_NOT_ASSIGNABLE', 42, "The element type '%s' cannot be assigned to the map value type '%s'"); |
| |
| /** |
| * 7.3 Setters: It is a static warning if a class has a setter named <i>v=</i> with argument type |
| * <i>T</i> and a getter named <i>v</i> with return type <i>S</i>, and <i>T</i> may not be |
| * assigned to <i>S</i>. |
| */ |
| static final StaticWarningCode MISMATCHED_GETTER_AND_SETTER_TYPES = new StaticWarningCode.con1('MISMATCHED_GETTER_AND_SETTER_TYPES', 43, "The parameter type for setter '%s' is '%s' which is not assignable to its getter (of type '%s')"); |
| |
| /** |
| * 12.11.1 New: It is a static warning if <i>q</i> is a constructor of an abstract class and |
| * <i>q</i> is not a factory constructor. |
| */ |
| static final StaticWarningCode NEW_WITH_ABSTRACT_CLASS = new StaticWarningCode.con1('NEW_WITH_ABSTRACT_CLASS', 44, "Abstract classes cannot be created with a 'new' expression"); |
| |
| /** |
| * 15.8 Parameterized Types: Any use of a malbounded type gives rise to a static warning. |
| * |
| * @param typeName the name of the type being referenced (<i>S</i>) |
| * @param parameterCount the number of type parameters that were declared |
| * @param argumentCount the number of type arguments provided |
| * @see CompileTimeErrorCode#CONST_WITH_INVALID_TYPE_PARAMETERS |
| * @see StaticTypeWarningCode#WRONG_NUMBER_OF_TYPE_ARGUMENTS |
| */ |
| static final StaticWarningCode NEW_WITH_INVALID_TYPE_PARAMETERS = new StaticWarningCode.con1('NEW_WITH_INVALID_TYPE_PARAMETERS', 45, "The type '%s' is declared with %d type parameters, but %d type arguments were given"); |
| |
| /** |
| * 12.11.1 New: It is a static warning if <i>T</i> is not a class accessible in the current scope, |
| * optionally followed by type arguments. |
| * |
| * @param name the name of the non-type element |
| */ |
| static final StaticWarningCode NEW_WITH_NON_TYPE = new StaticWarningCode.con1('NEW_WITH_NON_TYPE', 46, "The name '%s' is not a class"); |
| |
| /** |
| * 12.11.1 New: If <i>T</i> is a class or parameterized type accessible in the current scope then: |
| * 1. If <i>e</i> is of the form <i>new T.id(a<sub>1</sub>, …, a<sub>n</sub>, |
| * x<sub>n+1</sub>: a<sub>n+1</sub>, …, x<sub>n+k</sub>: a<sub>n+k</sub>)</i> it is a |
| * static warning if <i>T.id</i> is not the name of a constructor declared by the type <i>T</i>. |
| * If <i>e</i> of the form <i>new T(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: |
| * a<sub>n+1</sub>, … x<sub>n+k</sub>: a<sub>n+kM/sub>)</i> it is a static warning if the |
| * type <i>T</i> does not declare a constructor with the same name as the declaration of <i>T</i>. |
| */ |
| static final StaticWarningCode NEW_WITH_UNDEFINED_CONSTRUCTOR = new StaticWarningCode.con1('NEW_WITH_UNDEFINED_CONSTRUCTOR', 47, "The class '%s' does not have a constructor '%s'"); |
| |
| /** |
| * 12.11.1 New: If <i>T</i> is a class or parameterized type accessible in the current scope then: |
| * 1. If <i>e</i> is of the form <i>new T.id(a<sub>1</sub>, …, a<sub>n</sub>, |
| * x<sub>n+1</sub>: a<sub>n+1</sub>, …, x<sub>n+k</sub>: a<sub>n+k</sub>)</i> it is a |
| * static warning if <i>T.id</i> is not the name of a constructor declared by the type <i>T</i>. |
| * If <i>e</i> of the form <i>new T(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: |
| * a<sub>n+1</sub>, … x<sub>n+k</sub>: a<sub>n+kM/sub>)</i> it is a static warning if the |
| * type <i>T</i> does not declare a constructor with the same name as the declaration of <i>T</i>. |
| */ |
| static final StaticWarningCode NEW_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT = new StaticWarningCode.con1('NEW_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT', 48, "The class '%s' does not have a default constructor"); |
| |
| /** |
| * 7.9.1 Inheritance and Overriding: It is a static warning if a non-abstract class inherits an |
| * abstract method. |
| * |
| * 7.10 Superinterfaces: Let <i>C</i> be a concrete class that does not declare its own |
| * <i>noSuchMethod()</i> method. It is a static warning if the implicit interface of <i>C</i> |
| * includes an instance member <i>m</i> of type <i>F</i> and <i>C</i> does not declare or inherit |
| * a corresponding instance member <i>m</i> of type <i>F'</i> such that <i>F' <: F</i>. |
| * |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class unless that member overrides a concrete one. |
| * |
| * @param memberName the name of the first member |
| * @param memberName the name of the second member |
| * @param memberName the name of the third member |
| * @param memberName the name of the fourth member |
| * @param additionalCount the number of additional missing members that aren't listed |
| */ |
| static final StaticWarningCode NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FIVE_PLUS = new StaticWarningCode.con1('NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FIVE_PLUS', 49, "Missing inherited members: '%s', '%s', '%s', '%s' and %d more"); |
| |
| /** |
| * 7.9.1 Inheritance and Overriding: It is a static warning if a non-abstract class inherits an |
| * abstract method. |
| * |
| * 7.10 Superinterfaces: Let <i>C</i> be a concrete class that does not declare its own |
| * <i>noSuchMethod()</i> method. It is a static warning if the implicit interface of <i>C</i> |
| * includes an instance member <i>m</i> of type <i>F</i> and <i>C</i> does not declare or inherit |
| * a corresponding instance member <i>m</i> of type <i>F'</i> such that <i>F' <: F</i>. |
| * |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class unless that member overrides a concrete one. |
| * |
| * @param memberName the name of the first member |
| * @param memberName the name of the second member |
| * @param memberName the name of the third member |
| * @param memberName the name of the fourth member |
| */ |
| static final StaticWarningCode NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FOUR = new StaticWarningCode.con1('NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FOUR', 50, "Missing inherited members: '%s', '%s', '%s' and '%s'"); |
| |
| /** |
| * 7.9.1 Inheritance and Overriding: It is a static warning if a non-abstract class inherits an |
| * abstract method. |
| * |
| * 7.10 Superinterfaces: Let <i>C</i> be a concrete class that does not declare its own |
| * <i>noSuchMethod()</i> method. It is a static warning if the implicit interface of <i>C</i> |
| * includes an instance member <i>m</i> of type <i>F</i> and <i>C</i> does not declare or inherit |
| * a corresponding instance member <i>m</i> of type <i>F'</i> such that <i>F' <: F</i>. |
| * |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class unless that member overrides a concrete one. |
| * |
| * @param memberName the name of the member |
| */ |
| static final StaticWarningCode NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_ONE = new StaticWarningCode.con1('NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_ONE', 51, "Missing inherited member '%s'"); |
| |
| /** |
| * 7.9.1 Inheritance and Overriding: It is a static warning if a non-abstract class inherits an |
| * abstract method. |
| * |
| * 7.10 Superinterfaces: Let <i>C</i> be a concrete class that does not declare its own |
| * <i>noSuchMethod()</i> method. It is a static warning if the implicit interface of <i>C</i> |
| * includes an instance member <i>m</i> of type <i>F</i> and <i>C</i> does not declare or inherit |
| * a corresponding instance member <i>m</i> of type <i>F'</i> such that <i>F' <: F</i>. |
| * |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class unless that member overrides a concrete one. |
| * |
| * @param memberName the name of the first member |
| * @param memberName the name of the second member |
| * @param memberName the name of the third member |
| */ |
| static final StaticWarningCode NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_THREE = new StaticWarningCode.con1('NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_THREE', 52, "Missing inherited members: '%s', '%s' and '%s'"); |
| |
| /** |
| * 7.9.1 Inheritance and Overriding: It is a static warning if a non-abstract class inherits an |
| * abstract method. |
| * |
| * 7.10 Superinterfaces: Let <i>C</i> be a concrete class that does not declare its own |
| * <i>noSuchMethod()</i> method. It is a static warning if the implicit interface of <i>C</i> |
| * includes an instance member <i>m</i> of type <i>F</i> and <i>C</i> does not declare or inherit |
| * a corresponding instance member <i>m</i> of type <i>F'</i> such that <i>F' <: F</i>. |
| * |
| * 7.4 Abstract Instance Members: It is a static warning if an abstract member is declared or |
| * inherited in a concrete class unless that member overrides a concrete one. |
| * |
| * @param memberName the name of the first member |
| * @param memberName the name of the second member |
| */ |
| static final StaticWarningCode NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_TWO = new StaticWarningCode.con1('NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_TWO', 53, "Missing inherited members: '%s' and '%s'"); |
| |
| /** |
| * 13.11 Try: An on-catch clause of the form <i>on T catch (p<sub>1</sub>, p<sub>2</sub>) s</i> or |
| * <i>on T s</i> matches an object <i>o</i> if the type of <i>o</i> is a subtype of <i>T</i>. It |
| * is a static warning if <i>T</i> does not denote a type available in the lexical scope of the |
| * catch clause. |
| * |
| * @param name the name of the non-type element |
| */ |
| static final StaticWarningCode NON_TYPE_IN_CATCH_CLAUSE = new StaticWarningCode.con1('NON_TYPE_IN_CATCH_CLAUSE', 54, "The name '%s' is not a type and cannot be used in an on-catch clause"); |
| |
| /** |
| * 7.1.1 Operators: It is a static warning if the return type of the user-declared operator []= is |
| * explicitly declared and not void. |
| */ |
| static final StaticWarningCode NON_VOID_RETURN_FOR_OPERATOR = new StaticWarningCode.con1('NON_VOID_RETURN_FOR_OPERATOR', 55, "The return type of the operator []= must be 'void'"); |
| |
| /** |
| * 7.3 Setters: It is a static warning if a setter declares a return type other than void. |
| */ |
| static final StaticWarningCode NON_VOID_RETURN_FOR_SETTER = new StaticWarningCode.con1('NON_VOID_RETURN_FOR_SETTER', 56, "The return type of the setter must be 'void'"); |
| |
| /** |
| * 15.1 Static Types: A type <i>T</i> is malformed iff: * <i>T</i> has the form <i>id</i> or the |
| * form <i>prefix.id</i>, and in the enclosing lexical scope, the name <i>id</i> (respectively |
| * <i>prefix.id</i>) does not denote a type. * <i>T</i> denotes a type parameter in the |
| * enclosing lexical scope, but occurs in the signature or body of a static member. * |
| * <i>T</i> is a parameterized type of the form <i>G<S<sub>1</sub>, .., S<sub>n</sub>></i>, |
| * and <i>G</i> is malformed. |
| * |
| * Any use of a malformed type gives rise to a static warning. |
| * |
| * @param nonTypeName the name that is not a type |
| */ |
| static final StaticWarningCode NOT_A_TYPE = new StaticWarningCode.con1('NOT_A_TYPE', 57, "%s is not a type"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: It is a static warning if <i>m < h</i> or if <i>m > |
| * n</i>. |
| * |
| * @param requiredCount the expected number of required arguments |
| * @param argumentCount the actual number of positional arguments given |
| * @see #EXTRA_POSITIONAL_ARGUMENTS |
| */ |
| static final StaticWarningCode NOT_ENOUGH_REQUIRED_ARGUMENTS = new StaticWarningCode.con1('NOT_ENOUGH_REQUIRED_ARGUMENTS', 58, "%d required argument(s) expected, but %d found"); |
| |
| /** |
| * 14.3 Parts: It is a static warning if the referenced part declaration <i>p</i> names a library |
| * other than the current library as the library to which <i>p</i> belongs. |
| * |
| * @param expectedLibraryName the name of expected library name |
| * @param actualLibraryName the non-matching actual library name from the "part of" declaration |
| */ |
| static final StaticWarningCode PART_OF_DIFFERENT_LIBRARY = new StaticWarningCode.con1('PART_OF_DIFFERENT_LIBRARY', 59, "Expected this library to be part of '%s', not '%s'"); |
| |
| /** |
| * 7.6.2 Factories: It is a static warning if the function type of <i>k'</i> is not a subtype of |
| * the type of <i>k</i>. |
| * |
| * @param redirectedName the name of the redirected constructor |
| * @param redirectingName the name of the redirecting constructor |
| */ |
| static final StaticWarningCode REDIRECT_TO_INVALID_FUNCTION_TYPE = new StaticWarningCode.con1('REDIRECT_TO_INVALID_FUNCTION_TYPE', 60, "The redirected constructor '%s' has incompatible parameters with '%s'"); |
| |
| /** |
| * 7.6.2 Factories: It is a static warning if the function type of <i>k'</i> is not a subtype of |
| * the type of <i>k</i>. |
| * |
| * @param redirectedName the name of the redirected constructor return type |
| * @param redirectingName the name of the redirecting constructor return type |
| */ |
| static final StaticWarningCode REDIRECT_TO_INVALID_RETURN_TYPE = new StaticWarningCode.con1('REDIRECT_TO_INVALID_RETURN_TYPE', 61, "The return type '%s' of the redirected constructor is not a subclass of '%s'"); |
| |
| /** |
| * 7.6.2 Factories: It is a static warning if type does not denote a class accessible in the |
| * current scope; if type does denote such a class <i>C</i> it is a static warning if the |
| * referenced constructor (be it <i>type</i> or <i>type.id</i>) is not a constructor of <i>C</i>. |
| */ |
| static final StaticWarningCode REDIRECT_TO_MISSING_CONSTRUCTOR = new StaticWarningCode.con1('REDIRECT_TO_MISSING_CONSTRUCTOR', 62, "The constructor '%s' could not be found in '%s'"); |
| |
| /** |
| * 7.6.2 Factories: It is a static warning if type does not denote a class accessible in the |
| * current scope; if type does denote such a class <i>C</i> it is a static warning if the |
| * referenced constructor (be it <i>type</i> or <i>type.id</i>) is not a constructor of <i>C</i>. |
| */ |
| static final StaticWarningCode REDIRECT_TO_NON_CLASS = new StaticWarningCode.con1('REDIRECT_TO_NON_CLASS', 63, "The name '%s' is not a type and cannot be used in a redirected constructor"); |
| |
| /** |
| * 13.11 Return: Let <i>f</i> be the function immediately enclosing a return statement of the form |
| * <i>return;</i> It is a static warning if both of the following conditions hold: |
| * <ol> |
| * * <i>f</i> is not a generative constructor. |
| * * The return type of <i>f</i> may not be assigned to void. |
| * </ol> |
| */ |
| static final StaticWarningCode RETURN_WITHOUT_VALUE = new StaticWarningCode.con1('RETURN_WITHOUT_VALUE', 64, "Missing return value after 'return'"); |
| |
| /** |
| * 12.15.3 Static Invocation: It is a static warning if <i>C</i> does not declare a static method |
| * or getter <i>m</i>. |
| * |
| * @param memberName the name of the instance member |
| */ |
| static final StaticWarningCode STATIC_ACCESS_TO_INSTANCE_MEMBER = new StaticWarningCode.con1('STATIC_ACCESS_TO_INSTANCE_MEMBER', 65, "Instance member '%s' cannot be accessed using static access"); |
| |
| /** |
| * 13.9 Switch: It is a static warning if the type of <i>e</i> may not be assigned to the type of |
| * <i>e<sub>k</sub></i>. |
| */ |
| static final StaticWarningCode SWITCH_EXPRESSION_NOT_ASSIGNABLE = new StaticWarningCode.con1('SWITCH_EXPRESSION_NOT_ASSIGNABLE', 66, "Type '%s' of the switch expression is not assignable to the type '%s' of case expressions"); |
| |
| /** |
| * 12.31 Type Test: It is a static warning if <i>T</i> does not denote a type available in the |
| * current lexical scope. |
| */ |
| static final StaticWarningCode TYPE_TEST_NON_TYPE = new StaticWarningCode.con1('TYPE_TEST_NON_TYPE', 67, "The name '%s' is not a type and cannot be used in an 'is' expression"); |
| |
| /** |
| * 10 Generics: However, a type parameter is considered to be a malformed type when referenced by |
| * a static member. |
| * |
| * 15.1 Static Types: Any use of a malformed type gives rise to a static warning. A malformed type |
| * is then interpreted as dynamic by the static type checker and the runtime. |
| */ |
| static final StaticWarningCode TYPE_PARAMETER_REFERENCED_BY_STATIC = new StaticWarningCode.con1('TYPE_PARAMETER_REFERENCED_BY_STATIC', 68, "Static members cannot reference type parameters"); |
| |
| /** |
| * 12.15.3 Static Invocation: A static method invocation <i>i</i> has the form |
| * <i>C.m(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: a<sub>n+1</sub>, … |
| * x<sub>n+k</sub>: a<sub>n+k</sub>)</i>. It is a static warning if <i>C</i> does not denote a |
| * class in the current scope. |
| * |
| * @param undefinedClassName the name of the undefined class |
| */ |
| static final StaticWarningCode UNDEFINED_CLASS = new StaticWarningCode.con1('UNDEFINED_CLASS', 69, "Undefined class '%s'"); |
| |
| /** |
| * Same as [UNDEFINED_CLASS], but to catch using "boolean" instead of "bool". |
| */ |
| static final StaticWarningCode UNDEFINED_CLASS_BOOLEAN = new StaticWarningCode.con1('UNDEFINED_CLASS_BOOLEAN', 70, "Undefined class 'boolean'; did you mean 'bool'?"); |
| |
| /** |
| * 12.17 Getter Invocation: It is a static warning if there is no class <i>C</i> in the enclosing |
| * lexical scope of <i>i</i>, or if <i>C</i> does not declare, implicitly or explicitly, a getter |
| * named <i>m</i>. |
| * |
| * @param getterName the name of the getter |
| * @param enclosingType the name of the enclosing type where the getter is being looked for |
| */ |
| static final StaticWarningCode UNDEFINED_GETTER = new StaticWarningCode.con1('UNDEFINED_GETTER', 71, "There is no such getter '%s' in '%s'"); |
| |
| /** |
| * 12.30 Identifier Reference: It is as static warning if an identifier expression of the form |
| * <i>id</i> occurs inside a top level or static function (be it function, method, getter, or |
| * setter) or variable initializer and there is no declaration <i>d</i> with name <i>id</i> in the |
| * lexical scope enclosing the expression. |
| * |
| * @param name the name of the identifier |
| */ |
| static final StaticWarningCode UNDEFINED_IDENTIFIER = new StaticWarningCode.con1('UNDEFINED_IDENTIFIER', 72, "Undefined name '%s'"); |
| |
| /** |
| * 12.14.2 Binding Actuals to Formals: Furthermore, each <i>q<sub>i</sub></i>, <i>1<=i<=l</i>, |
| * must have a corresponding named parameter in the set {<i>p<sub>n+1</sub></i> ... |
| * <i>p<sub>n+k</sub></i>} or a static warning occurs. |
| * |
| * @param name the name of the requested named parameter |
| */ |
| static final StaticWarningCode UNDEFINED_NAMED_PARAMETER = new StaticWarningCode.con1('UNDEFINED_NAMED_PARAMETER', 73, "The named parameter '%s' is not defined"); |
| |
| /** |
| * 12.18 Assignment: It is as static warning if an assignment of the form <i>v = e</i> occurs |
| * inside a top level or static function (be it function, method, getter, or setter) or variable |
| * initializer and there is no declaration <i>d</i> with name <i>v=</i> in the lexical scope |
| * enclosing the assignment. |
| * |
| * 12.18 Assignment: It is a static warning if there is no class <i>C</i> in the enclosing lexical |
| * scope of the assignment, or if <i>C</i> does not declare, implicitly or explicitly, a setter |
| * <i>v=</i>. |
| * |
| * @param setterName the name of the getter |
| * @param enclosingType the name of the enclosing type where the setter is being looked for |
| */ |
| static final StaticWarningCode UNDEFINED_SETTER = new StaticWarningCode.con1('UNDEFINED_SETTER', 74, "There is no such setter '%s' in '%s'"); |
| |
| /** |
| * 12.15.3 Static Invocation: It is a static warning if <i>C</i> does not declare a static method |
| * or getter <i>m</i>. |
| * |
| * @param methodName the name of the method |
| * @param enclosingType the name of the enclosing type where the method is being looked for |
| */ |
| static final StaticWarningCode UNDEFINED_STATIC_METHOD_OR_GETTER = new StaticWarningCode.con1('UNDEFINED_STATIC_METHOD_OR_GETTER', 75, "There is no such static method '%s' in '%s'"); |
| static final List<StaticWarningCode> values = [ |
| AMBIGUOUS_IMPORT, |
| ARGUMENT_TYPE_NOT_ASSIGNABLE, |
| ASSIGNMENT_TO_CONST, |
| ASSIGNMENT_TO_FINAL, |
| ASSIGNMENT_TO_METHOD, |
| CASE_BLOCK_NOT_TERMINATED, |
| CAST_TO_NON_TYPE, |
| COMMENT_REFERENCE_CONSTRUCTOR_NOT_VISIBLE, |
| COMMENT_REFERENCE_IDENTIFIER_NOT_VISIBLE, |
| COMMENT_REFERENCE_UNDECLARED_CONSTRUCTOR, |
| COMMENT_REFERENCE_UNDECLARED_IDENTIFIER, |
| COMMENT_REFERENCE_URI_NOT_LIBRARY, |
| CONCRETE_CLASS_WITH_ABSTRACT_MEMBER, |
| CONFLICTING_INSTANCE_GETTER_AND_SUPERCLASS_MEMBER, |
| CONFLICTING_INSTANCE_SETTER_AND_SUPERCLASS_MEMBER, |
| CONFLICTING_STATIC_GETTER_AND_INSTANCE_SETTER, |
| CONFLICTING_STATIC_SETTER_AND_INSTANCE_MEMBER, |
| CONST_WITH_ABSTRACT_CLASS, |
| EQUAL_KEYS_IN_MAP, |
| EXPORT_DUPLICATED_LIBRARY_NAME, |
| EXTRA_POSITIONAL_ARGUMENTS, |
| FIELD_INITIALIZED_IN_INITIALIZER_AND_DECLARATION, |
| FINAL_INITIALIZED_IN_DECLARATION_AND_CONSTRUCTOR, |
| FIELD_INITIALIZER_NOT_ASSIGNABLE, |
| FIELD_INITIALIZING_FORMAL_NOT_ASSIGNABLE, |
| FINAL_NOT_INITIALIZED, |
| IMPORT_DUPLICATED_LIBRARY_NAME, |
| INCONSISTENT_METHOD_INHERITANCE_GETTER_AND_METHOD, |
| INSTANCE_METHOD_NAME_COLLIDES_WITH_SUPERCLASS_STATIC, |
| INVALID_GETTER_OVERRIDE_RETURN_TYPE, |
| INVALID_METHOD_OVERRIDE_NAMED_PARAM_TYPE, |
| INVALID_METHOD_OVERRIDE_NORMAL_PARAM_TYPE, |
| INVALID_METHOD_OVERRIDE_OPTIONAL_PARAM_TYPE, |
| INVALID_METHOD_OVERRIDE_RETURN_TYPE, |
| INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_NAMED, |
| INVALID_OVERRIDE_DIFFERENT_DEFAULT_VALUES_POSITIONAL, |
| INVALID_OVERRIDE_NAMED, |
| INVALID_OVERRIDE_POSITIONAL, |
| INVALID_OVERRIDE_REQUIRED, |
| INVALID_SETTER_OVERRIDE_NORMAL_PARAM_TYPE, |
| LIST_ELEMENT_TYPE_NOT_ASSIGNABLE, |
| MAP_KEY_TYPE_NOT_ASSIGNABLE, |
| MAP_VALUE_TYPE_NOT_ASSIGNABLE, |
| MISMATCHED_GETTER_AND_SETTER_TYPES, |
| NEW_WITH_ABSTRACT_CLASS, |
| NEW_WITH_INVALID_TYPE_PARAMETERS, |
| NEW_WITH_NON_TYPE, |
| NEW_WITH_UNDEFINED_CONSTRUCTOR, |
| NEW_WITH_UNDEFINED_CONSTRUCTOR_DEFAULT, |
| NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FIVE_PLUS, |
| NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_FOUR, |
| NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_ONE, |
| NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_THREE, |
| NON_ABSTRACT_CLASS_INHERITS_ABSTRACT_MEMBER_TWO, |
| NON_TYPE_IN_CATCH_CLAUSE, |
| NON_VOID_RETURN_FOR_OPERATOR, |
| NON_VOID_RETURN_FOR_SETTER, |
| NOT_A_TYPE, |
| NOT_ENOUGH_REQUIRED_ARGUMENTS, |
| PART_OF_DIFFERENT_LIBRARY, |
| REDIRECT_TO_INVALID_FUNCTION_TYPE, |
| REDIRECT_TO_INVALID_RETURN_TYPE, |
| REDIRECT_TO_MISSING_CONSTRUCTOR, |
| REDIRECT_TO_NON_CLASS, |
| RETURN_WITHOUT_VALUE, |
| STATIC_ACCESS_TO_INSTANCE_MEMBER, |
| SWITCH_EXPRESSION_NOT_ASSIGNABLE, |
| TYPE_TEST_NON_TYPE, |
| TYPE_PARAMETER_REFERENCED_BY_STATIC, |
| UNDEFINED_CLASS, |
| UNDEFINED_CLASS_BOOLEAN, |
| UNDEFINED_GETTER, |
| UNDEFINED_IDENTIFIER, |
| UNDEFINED_NAMED_PARAMETER, |
| UNDEFINED_SETTER, |
| UNDEFINED_STATIC_METHOD_OR_GETTER]; |
| |
| /** |
| * The template used to create the message to be displayed for this error. |
| */ |
| String _message; |
| |
| /** |
| * The template used to create the correction to be displayed for this error, or `null` if |
| * there is no correction information for this error. |
| */ |
| String correction7; |
| |
| /** |
| * Initialize a newly created error code to have the given message. |
| * |
| * @param message the message template used to create the message to be displayed for the error |
| */ |
| StaticWarningCode.con1(String name, int ordinal, String message) : super(name, ordinal) { |
| this._message = message; |
| } |
| |
| /** |
| * Initialize a newly created error code to have the given message and correction. |
| * |
| * @param message the template used to create the message to be displayed for the error |
| * @param correction the template used to create the correction to be displayed for the error |
| */ |
| StaticWarningCode.con2(String name, int ordinal, String message, String correction) : super(name, ordinal) { |
| this._message = message; |
| this.correction7 = correction; |
| } |
| String get correction => correction7; |
| ErrorSeverity get errorSeverity => ErrorType.STATIC_WARNING.severity; |
| String get message => _message; |
| ErrorType get type => ErrorType.STATIC_WARNING; |
| } |
| /** |
| * The interface `AnalysisErrorListener` defines the behavior of objects that listen for |
| * [AnalysisError] being produced by the analysis engine. |
| * |
| * @coverage dart.engine.error |
| */ |
| abstract class AnalysisErrorListener { |
| |
| /** |
| * An error listener that ignores errors that are reported to it. |
| */ |
| static final AnalysisErrorListener _NULL_LISTENER = new AnalysisErrorListener_6(); |
| |
| /** |
| * This method is invoked when an error has been found by the analysis engine. |
| * |
| * @param error the error that was just found (not `null`) |
| */ |
| void onError(AnalysisError error); |
| } |
| class AnalysisErrorListener_6 implements AnalysisErrorListener { |
| void onError(AnalysisError event) { |
| } |
| } |
| /** |
| * The enumeration `HtmlWarningCode` defines the error codes used for warnings in HTML files. |
| * The convention for this class is for the name of the error code to indicate the problem that |
| * caused the error to be generated and for the error message to explain what is wrong and, when |
| * appropriate, how the problem can be corrected. |
| * |
| * @coverage dart.engine.error |
| */ |
| class HtmlWarningCode extends Enum<HtmlWarningCode> implements ErrorCode { |
| |
| /** |
| * An error code indicating that the value of the 'src' attribute of a Dart script tag is not a |
| * valid URI. |
| * |
| * @param uri the URI that is invalid |
| */ |
| static final HtmlWarningCode INVALID_URI = new HtmlWarningCode.con1('INVALID_URI', 0, "Invalid URI syntax: '%s'"); |
| |
| /** |
| * An error code indicating that the value of the 'src' attribute of a Dart script tag references |
| * a file that does not exist. |
| * |
| * @param uri the URI pointing to a non-existent file |
| */ |
| static final HtmlWarningCode URI_DOES_NOT_EXIST = new HtmlWarningCode.con1('URI_DOES_NOT_EXIST', 1, "Target of URI does not exist: '%s'"); |
| static final List<HtmlWarningCode> values = [INVALID_URI, URI_DOES_NOT_EXIST]; |
| |
| /** |
| * The template used to create the message to be displayed for this error. |
| */ |
| String _message; |
| |
| /** |
| * The template used to create the correction to be displayed for this error, or `null` if |
| * there is no correction information for this error. |
| */ |
| String correction4; |
| |
| /** |
| * Initialize a newly created error code to have the given message. |
| * |
| * @param message the message template used to create the message to be displayed for the error |
| */ |
| HtmlWarningCode.con1(String name, int ordinal, String message) : super(name, ordinal) { |
| this._message = message; |
| } |
| |
| /** |
| * Initialize a newly created error code to have the given message and correction. |
| * |
| * @param message the template used to create the message to be displayed for the error |
| * @param correction the template used to create the correction to be displayed for the error |
| */ |
| HtmlWarningCode.con2(String name, int ordinal, String message, String correction) : super(name, ordinal) { |
| this._message = message; |
| this.correction4 = correction; |
| } |
| String get correction => correction4; |
| ErrorSeverity get errorSeverity => ErrorSeverity.WARNING; |
| String get message => _message; |
| ErrorType get type => ErrorType.STATIC_WARNING; |
| } |
| /** |
| * The enumeration `StaticTypeWarningCode` defines the error codes used for static type |
| * warnings. The convention for this class is for the name of the error code to indicate the problem |
| * that caused the error to be generated and for the error message to explain what is wrong and, |
| * when appropriate, how the problem can be corrected. |
| * |
| * @coverage dart.engine.error |
| */ |
| class StaticTypeWarningCode extends Enum<StaticTypeWarningCode> implements ErrorCode { |
| |
| /** |
| * 12.18 Assignment: Let <i>T</i> be the static type of <i>e<sub>1</sub></i>. It is a static type |
| * warning if <i>T</i> does not have an accessible instance setter named <i>v=</i>. |
| * |
| * @see #UNDEFINED_SETTER |
| */ |
| static final StaticTypeWarningCode INACCESSIBLE_SETTER = new StaticTypeWarningCode.con1('INACCESSIBLE_SETTER', 0, ""); |
| |
| /** |
| * 8.1.1 Inheritance and Overriding: However, if there are multiple members <i>m<sub>1</sub>, |
| * … m<sub>k</sub></i> with the same name <i>n</i> that would be inherited (because |
| * identically named members existed in several superinterfaces) then at most one member is |
| * inherited. |
| * |
| * If the static types <i>T<sub>1</sub>, …, T<sub>k</sub></i> of the members |
| * <i>m<sub>1</sub>, …, m<sub>k</sub></i> are not identical, then there must be a member |
| * <i>m<sub>x</sub></i> such that <i>T<sub>x</sub> < T<sub>i</sub>, 1 <= x <= k</i> for |
| * all <i>i, 1 <= i < k</i>, or a static type warning occurs. The member that is inherited |
| * is <i>m<sub>x</sub></i>, if it exists; otherwise: |
| * <ol> |
| * * If all of <i>m<sub>1</sub>, … m<sub>k</sub></i> have the same number <i>r</i> of |
| * required parameters and the same set of named parameters <i>s</i>, then let <i>h = max( |
| * numberOfOptionalPositionals( m<sub>i</sub> ) ), 1 <= i <= k</i>. <i>I</i> has a method |
| * named <i>n</i>, with <i>r</i> required parameters of type dynamic, <i>h</i> optional positional |
| * parameters of type dynamic, named parameters <i>s</i> of type dynamic and return type dynamic. |
| * * Otherwise none of the members <i>m<sub>1</sub>, …, m<sub>k</sub></i> is inherited. |
| * </ol> |
| */ |
| static final StaticTypeWarningCode INCONSISTENT_METHOD_INHERITANCE = new StaticTypeWarningCode.con1('INCONSISTENT_METHOD_INHERITANCE', 1, "'%s' is inherited by at least two interfaces inconsistently"); |
| |
| /** |
| * 12.15.1 Ordinary Invocation: It is a static type warning if <i>T</i> does not have an |
| * accessible (3.2) instance member named <i>m</i>. |
| * |
| * @param memberName the name of the static member |
| * @see UNQUALIFIED_REFERENCE_TO_NON_LOCAL_STATIC_MEMBER |
| */ |
| static final StaticTypeWarningCode INSTANCE_ACCESS_TO_STATIC_MEMBER = new StaticTypeWarningCode.con1('INSTANCE_ACCESS_TO_STATIC_MEMBER', 2, "Static member '%s' cannot be accessed using instance access"); |
| |
| /** |
| * 12.18 Assignment: It is a static type warning if the static type of <i>e</i> may not be |
| * assigned to the static type of <i>v</i>. The static type of the expression <i>v = e</i> is the |
| * static type of <i>e</i>. |
| * |
| * 12.18 Assignment: It is a static type warning if the static type of <i>e</i> may not be |
| * assigned to the static type of <i>C.v</i>. The static type of the expression <i>C.v = e</i> is |
| * the static type of <i>e</i>. |
| * |
| * 12.18 Assignment: Let <i>T</i> be the static type of <i>e<sub>1</sub></i>. It is a static type |
| * warning if the static type of <i>e<sub>2</sub></i> may not be assigned to <i>T</i>. |
| * |
| * @param rhsTypeName the name of the right hand side type |
| * @param lhsTypeName the name of the left hand side type |
| */ |
| static final StaticTypeWarningCode INVALID_ASSIGNMENT = new StaticTypeWarningCode.con1('INVALID_ASSIGNMENT', 3, "A value of type '%s' cannot be assigned to a variable of type '%s'"); |
| |
| /** |
| * 12.15.1 Ordinary Invocation: An ordinary method invocation <i>i</i> has the form |
| * <i>o.m(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: a<sub>n+1</sub>, … |
| * x<sub>n+k</sub>: a<sub>n+k</sub>)</i>. |
| * |
| * Let <i>T</i> be the static type of <i>o</i>. It is a static type warning if <i>T</i> does not |
| * have an accessible instance member named <i>m</i>. If <i>T.m</i> exists, it is a static warning |
| * if the type <i>F</i> of <i>T.m</i> may not be assigned to a function type. If <i>T.m</i> does |
| * not exist, or if <i>F</i> is not a function type, the static type of <i>i</i> is dynamic. |
| * |
| * 12.15.3 Static Invocation: It is a static type warning if the type <i>F</i> of <i>C.m</i> may |
| * not be assigned to a function type. |
| * |
| * 12.15.4 Super Invocation: A super method invocation <i>i</i> has the form |
| * <i>super.m(a<sub>1</sub>, …, a<sub>n</sub>, x<sub>n+1</sub>: a<sub>n+1</sub>, … |
| * x<sub>n+k</sub>: a<sub>n+k</sub>)</i>. If <i>S.m</i> exists, it is a static warning if the type |
| * <i>F</i> of <i>S.m</i> may not be assigned to a function type. |
| * |
| * @param nonFunctionIdentifier the name of the identifier that is not a function type |
| */ |
| static final StaticTypeWarningCode INVOCATION_OF_NON_FUNCTION = new StaticTypeWarningCode.con1('INVOCATION_OF_NON_FUNCTION', 4, "'%s' is not a method"); |
| |
| /** |
| * 12.14.4 Function Expression Invocation: A function expression invocation <i>i</i> has the form |
| * <i>e<sub>f</sub>(a<sub>1</sub>, … a<sub>n</sub>, x<sub>n+1</sub>: a<sub>n+1</sub>, |
| * …, x<sub>n+k</sub>: a<sub>n+k</sub>)</i>, where <i>e<sub>f</sub></i> is an expression. |
| * |
| * It is a static type warning if the static type <i>F</i> of <i>e<sub>f</sub></i> may not be |
| * assigned to a function type. |
| */ |
| static final StaticTypeWarningCode INVOCATION_OF_NON_FUNCTION_EXPRESSION = new StaticTypeWarningCode.con1('INVOCATION_OF_NON_FUNCTION_EXPRESSION', 5, "Cannot invoke a non-function"); |
| |
| /** |
| * 12.19 Conditional: It is a static type warning if the type of <i>e<sub>1</sub></i> may not be |
| * assigned to bool. |
| * |
| * 13.5 If: It is a static type warning if the type of the expression <i>b</i> may not be assigned |
| * to bool. |
| * |
| * 13.7 While: It is a static type warning if the type of <i>e</i> may not be assigned to bool. |
| * |
| * 13.8 Do: It is a static type warning if the type of <i>e</i> cannot be assigned to bool. |
| */ |
| static final StaticTypeWarningCode NON_BOOL_CONDITION = new StaticTypeWarningCode.con1('NON_BOOL_CONDITION', 6, "Conditions must have a static type of 'bool'"); |
| |
| /** |
| * 13.15 Assert: It is a static type warning if the type of <i>e</i> may not be assigned to either |
| * bool or () → bool |
| */ |
| static final StaticTypeWarningCode NON_BOOL_EXPRESSION = new StaticTypeWarningCode.con1('NON_BOOL_EXPRESSION', 7, "Assertions must be on either a 'bool' or '() -> bool'"); |
| |
| /** |
| * 15.8 Parameterized Types: It is a static type warning if <i>A<sub>i</sub>, 1 <= i <= |
| * n</i> does not denote a type in the enclosing lexical scope. |
| */ |
| static final StaticTypeWarningCode NON_TYPE_AS_TYPE_ARGUMENT = new StaticTypeWarningCode.con1('NON_TYPE_AS_TYPE_ARGUMENT', 8, "The name '%s' is not a type and cannot be used as a parameterized type"); |
| |
| /** |
| * 13.11 Return: It is a static type warning if the type of <i>e</i> may not be assigned to the |
| * declared return type of the immediately enclosing function. |
| * |
| * @param actualReturnType the return type as declared in the return statement |
| * @param expectedReturnType the expected return type as defined by the method |
| * @param methodName the name of the method |
| */ |
| static final StaticTypeWarningCode RETURN_OF_INVALID_TYPE = new StaticTypeWarningCode.con1('RETURN_OF_INVALID_TYPE', 9, "The return type '%s' is not a '%s', as defined by the method '%s'"); |
| |
| /** |
| * 12.11 Instance Creation: It is a static type warning if any of the type arguments to a |
| * constructor of a generic type <i>G</i> invoked by a new expression or a constant object |
| * expression are not subtypes of the bounds of the corresponding formal type parameters of |
| * <i>G</i>. |
| * |
| * 10 Generics: It is a static type warning if a type parameter is a supertype of its upper bound. |
| * |
| * 15.8 Parameterized Types: If <i>S</i> is the static type of a member <i>m</i> of <i>G</i>, then |
| * the static type of the member <i>m</i> of <i>G<A<sub>1</sub>, … A<sub>n</sub>></i> |
| * is <i>[A<sub>1</sub>, …, A<sub>n</sub>/T<sub>1</sub>, …, T<sub>n</sub>]S</i> |
| * where <i>T<sub>1</sub>, … T<sub>n</sub></i> are the formal type parameters of <i>G</i>. |
| * Let <i>B<sub>i</sub></i> be the bounds of <i>T<sub>i</sub>, 1 <= i <= n</i>. It is a |
| * static type warning if <i>A<sub>i</sub></i> is not a subtype of <i>[A<sub>1</sub>, …, |
| * A<sub>n</sub>/T<sub>1</sub>, …, T<sub>n</sub>]B<sub>i</sub>, 1 <= i <= n</i>. |
| * |
| * 7.6.2 Factories: It is a static type warning if any of the type arguments to <i>k'</i> are not |
| * subtypes of the bounds of the corresponding formal type parameters of type. |
| * |
| * @param boundedTypeName the name of the type used in the instance creation that should be |
| * limited by the bound as specified in the class declaration |
| * @param boundingTypeName the name of the bounding type |
| */ |
| static final StaticTypeWarningCode TYPE_ARGUMENT_NOT_MATCHING_BOUNDS = new StaticTypeWarningCode.con1('TYPE_ARGUMENT_NOT_MATCHING_BOUNDS', 10, "'%s' does not extend '%s'"); |
| |
| /** |
| * 12.17 Getter Invocation: Let <i>T</i> be the static type of <i>e</i>. It is a static type |
|