blob: b2add6fb5fec493bda31c89905d05a51852979b9 [file] [log] [blame]
// 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.
enum Enum { a, b }
sealed class A {
final Enum a;
bool get b;
A(this.a);
}
class B extends A {
final bool b;
B(super.a, this.b);
}
void exhaustiveSwitch1(A r) {
/*
checkingOrder={A,B},
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
}
}
void exhaustiveSwitch2(A r) {
/*
checkingOrder={A,B},
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
}
}
void nonExhaustiveSwitch1(A r) {
/*
checkingOrder={A,B},
error=non-exhaustive:B(a: Enum.b, b: false),
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
}
}
void nonExhaustiveSwitch2(A r) {
/*
checkingOrder={A,B},
error=non-exhaustive:B(a: Enum.a, b: false),
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
}
}
void nonExhaustiveSwitchWithDefault(A r) {
/*
checkingOrder={A,B},
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
default:
print('default');
break;
}
}
void exhaustiveNullableSwitch(A? r) {
/*
checkingOrder={A?,A,Null,B},
expandedSubtypes={B,Null},
fields={a:-,b:-},
subtypes={A,Null},
type=A?
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
/*space=Null*/
case null:
print('null');
break;
}
}
void nonExhaustiveNullableSwitch1(A? r) {
/*
checkingOrder={A?,A,Null,B},
error=non-exhaustive:null,
expandedSubtypes={B,Null},
fields={a:-,b:-},
subtypes={A,Null},
type=A?
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
}
}
void nonExhaustiveNullableSwitch2(A? r) {
/*
checkingOrder={A?,A,Null,B},
error=non-exhaustive:B(a: Enum.b, b: false),
expandedSubtypes={B,Null},
fields={a:-,b:-},
subtypes={A,Null},
type=A?
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
/*space=Null*/
case null:
print('null');
break;
}
}
void unreachableCase1(A r) {
/*
checkingOrder={A,B},
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false) #1');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
/*
error=unreachable,
space=A(a: Enum.a, b: false)
*/
case A(a: Enum.a, b: false):
print('(a, false) #2');
break;
}
}
void unreachableCase2(A r) {
// TODO(johnniwinther): Should we avoid the unreachable error here?
/*
checkingOrder={A,B},
fields={a:Enum,b:bool},
subtypes={B},
type=A
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
/*space=Null*/
case null:
print('null');
break;
}
}
void unreachableCase3(A? r) {
/*
checkingOrder={A?,A,Null,B},
expandedSubtypes={B,Null},
fields={a:-,b:-},
subtypes={A,Null},
type=A?
*/
switch (r) {
/*space=A(a: Enum.a, b: false)*/
case A(a: Enum.a, b: false):
print('A(a, false)');
break;
/*space=A(a: Enum.b, b: false)*/
case A(a: Enum.b, b: false):
print('A(b, false)');
break;
/*space=A(a: Enum.a, b: true)*/
case A(a: Enum.a, b: true):
print('A(a, true)');
break;
/*space=A(a: Enum.b, b: true)*/
case A(a: Enum.b, b: true):
print('A(b, true)');
break;
/*space=Null*/
case null:
print('null #1');
break;
/*
error=unreachable,
space=Null
*/
case null:
print('null #2');
break;
}
}