dart-sdk/tests/language/patterns/invalid_const_pattern_test.dart
Kallen Tu 951d589c20 [analyzer] Refactor visitPrefixExpression, visitNamedExpression, and visitParenthesizedExpression.
Change-Id: I5a5fa0897d25aab3092fc526342c5af12a67e0a5
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/310770
Reviewed-by: Konstantin Shcheglov <scheglov@google.com>
Reviewed-by: Brian Wilkerson <brianwilkerson@google.com>
Commit-Queue: Kallen Tu <kallentu@google.com>
2023-06-22 20:48:48 +00:00

593 lines
16 KiB
Dart

// Copyright (c) 2023, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'invalid_const_pattern_test.dart' as prefix;
const int value = 42;
void func() {}
class Class {
const Class([a]);
const Class.named();
call() {}
test(o) async {
const dynamic local = 0;
dynamic variable = 0;
switch (o) {
case true: // Ok
}
switch (o) {
case null: // Ok
}
switch (o) {
case this: // Error
// ^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case this(): // Error
// ^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case super(): // Error
// ^^^^^
// [analyzer] COMPILE_TIME_ERROR.INVOCATION_OF_NON_FUNCTION_EXPRESSION
// [cfe] Method invocation is not a constant expression.
}
switch (o) {
case 42: // Ok
}
switch (o) {
case -42: // Ok
}
switch (o) {
case 42.5: // Ok
}
switch (o) {
case -42.5: // Ok
}
switch (o) {
case 'foo': // Ok
}
switch (o) {
case 'foo' 'bar': // Ok
}
switch (o) {
case value: // Ok
}
switch (o) {
case value!: // Ok
}
switch (o) {
case value?: // Ok
}
switch (o) {
case value as int: // Ok
}
switch (o) {
case -value: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_NEGATION
// [cfe] Only negation of a numeric literal is supported as a constant pattern.
}
switch (o) {
case local: // Ok
}
switch (o) {
case -local: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_NEGATION
// [cfe] Only negation of a numeric literal is supported as a constant pattern.
}
switch (o) {
case func: // Ok
}
switch (o) {
case prefix.value: // Ok
}
switch (o) {
case -prefix.value: // Error
// ^^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_NEGATION
// [cfe] Only negation of a numeric literal is supported as a constant pattern.
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_NEGATION
// [cfe] Only negation of a numeric literal is supported as a constant pattern.
}
switch (o) {
case prefix.Class.named: // Ok
}
switch (o) {
case 1 + 2: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_BINARY
// [cfe] The binary operator + is not supported as a constant pattern.
}
switch (o) {
case 1 * 2: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_BINARY
// [cfe] The binary operator * is not supported as a constant pattern.
}
switch (o) {
case void fun() {}: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.EXPECTED_TOKEN
// [cfe] Expected ':' before this.
// ^
// [analyzer] SYNTACTIC_ERROR.EXPECTED_TOKEN
// [cfe] Expected ';' after this.
// ^
// [analyzer] SYNTACTIC_ERROR.MISSING_IDENTIFIER
// [analyzer] SYNTACTIC_ERROR.UNEXPECTED_TOKEN
// [cfe] Expected an identifier, but got ':'.
// [cfe] Unexpected token ':'.
}
switch (o) {
case assert(false): // Error
// ^^^^^^
// [analyzer] COMPILE_TIME_ERROR.UNDEFINED_IDENTIFIER
// ^^^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] `assert` can't be used as an expression.
}
switch (o) {
case switch (o) { _ => true }: // Error
// ^^^^^^^^^^^^^^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
// ^
// [cfe] Not a constant expression.
}
switch (o) {
case await 0: // Error
// ^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case !false: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_UNARY
// [cfe] The unary operator ! is not supported as a constant pattern.
}
switch (o) {
case ~0: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_UNARY
// [cfe] The unary operator ~ is not supported as a constant pattern.
}
switch (o) {
case ++variable: // Error
// ^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case const 0: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const 0x0: // Error
// ^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const 0.5: // Error
// ^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const true: // Error
// ^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const null: // Error
// ^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const -0: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const 'foo': // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const #a: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const value: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const local: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const prefix.value: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const -prefix.value: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const prefix.Class.named: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const 1 + 2: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_CONST_PREFIX
// [cfe] The expression can't be prefixed by 'const' to form a constant pattern.
}
switch (o) {
case const void fun() {}: // Error
// ^
// [cfe] Not a constant expression.
// ^^^
// [analyzer] SYNTACTIC_ERROR.NAMED_FUNCTION_EXPRESSION
// [cfe] A function expression can't have a name.
// ^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
}
switch (o) {
case const assert(false): // Error
// ^^^^^^
// [analyzer] COMPILE_TIME_ERROR.UNDEFINED_IDENTIFIER
// ^^^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] `assert` can't be used as an expression.
}
switch (o) {
case const switch (o) { _ => true }: // Error
// ^^^^^^^^^^^^^^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
// ^
// [cfe] Not a constant expression.
}
switch (o) {
case const await 0: // Error
// ^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case const !false: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_UNARY
// [cfe] The unary operator ! is not supported as a constant pattern.
}
switch (o) {
case const ~0: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_UNARY
// [cfe] The unary operator ~ is not supported as a constant pattern.
}
switch (o) {
case const ++variable: // Error
// ^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] Not a constant expression.
}
switch (o) {
case const Class(): // Ok
}
switch (o) {
case const Class(0): // Ok
}
switch (o) {
case const GenericClass(): // Ok
}
switch (o) {
case const GenericClass(a: 0): // Ok
}
switch (o) {
case const GenericClass<int>(): // Ok
}
switch (o) {
case const GenericClass<int>(a: 0): // Ok
}
switch (o) {
case const GenericClass<int>.new(): // Ok
}
switch (o) {
case const GenericClass<int>.new(a: 1): // Ok
}
switch (o) {
case const []: // Ok
}
switch (o) {
case const <int>[]: // Ok
}
switch (o) {
case const {}: // Ok
}
switch (o) {
case const <int, String>{}: // Ok
}
switch (o) {
case const const Class(): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const Class(0): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const GenericClass(): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const GenericClass(a: 0): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const GenericClass<int>(): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const GenericClass<int>(a: 0): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const []: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const <int>[]: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const {}: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const const <int, String>{}: // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const new Class(): // Error
// ^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] New expression is not a constant expression.
// ^
// [cfe] New expression is not a constant expression.
}
switch (o) {
case new Class(): // Error
// ^^^^^^^^^^^
// [analyzer] COMPILE_TIME_ERROR.CONSTANT_PATTERN_WITH_NON_CONSTANT_EXPRESSION
// [cfe] New expression is not a constant expression.
// ^
// [cfe] New expression is not a constant expression.
}
switch (o) {
case const (): // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_EMPTY_RECORD_LITERAL
// [cfe] The empty record literal is not supported as a constant pattern.
}
switch (o) {
case const const (): // Error
// ^^^^^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_DUPLICATE_CONST
// [cfe] Duplicate 'const' keyword in constant expression.
}
switch (o) {
case const (1): // Ok
}
switch (o) {
case const (-1): // Ok
}
switch (o) {
case const (value): // Ok
}
switch (o) {
case const (-value): // Ok
}
switch (o) {
case const (1 + 2): // Ok
}
switch (o) {
case GenericClass<int>: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case prefix.GenericClass<int>: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case GenericClass<int>.new: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case prefix.GenericClass<int>.new: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case const GenericClass<int>: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case const prefix.GenericClass<int>: // Error
// ^
// [analyzer] SYNTACTIC_ERROR.INVALID_CONSTANT_PATTERN_GENERIC
// [cfe] This expression is not supported as a constant pattern.
}
switch (o) {
case const (GenericClass<int>): // Ok
}
switch (o) {
case const (prefix.GenericClass<int>): // Ok
}
switch (o) {
case const (GenericClass<int>.new): // Ok
}
switch (o) {
case const (prefix.GenericClass<int>.new): // Ok
print(0);
}
}
}
class GenericClass<T> {
const GenericClass({a});
}