blob: 897fb891360c0e9dcd8115f13efb63576c90a493 [file] [edit]
// Copyright (c) 2026, 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.
/// @assertion We say that an augmenting function or constructor's signature
/// matches an introductory signature if:
/// - It has the same number of type parameters with the same type parameter
/// names (same identifiers) and bounds (after type annotation inheritance),
/// if any (same types, even if they may not be written exactly the same in
/// case one of the declarations needs to refer to a type using an import
/// prefix).
/// - The return type (if not omitted) is the same as the introductory
/// declaration's return type.
/// - It has the same number of positional parameters as the introductory
/// declaration, and the same number of those are optional.
/// - It has the same set of named parameter names as the introductory
/// declaration.
/// - For each corresponding pair of parameters:
/// - They have the same name. This is trivial for named parameters, but may
/// fail to hold for positional parameters.
/// - They have the same type (or the augmenting declaration omits the type).
/// - They both have the modifier `covariant`, or none of them have it.
/// - They both have the modifier `required`, or none of them have it.
/// ...
/// It is a compile-time error if:
/// - The signature of the augmenting constructor does not match the signature
/// of the corresponding introductory constructor.
///
/// @description Checks that it is a compile-time error if the name of a
/// positional formal parameter of an augmenting primary constructor is not the
/// same as the name of the corresponding positional parameter.
/// @author sgrekhov22@gmail.com
// SharedOptions=--enable-experiment=augmentations,primary-constructors
class C1(int? x) {}
augment class C1 {
augment C1(int? _);
// ^
// [analyzer] unspecified
// [cfe] unspecified
}
class C2([int? _]) {}
augment class C2 {
augment C2([int? x]);
// ^
// [analyzer] unspecified
// [cfe] unspecified
}
enum E1(int _) {
e0(0);
}
augment enum E1 {
;
augment const E1(int x);
// ^
// [analyzer] unspecified
// [cfe] unspecified
}
enum E2([int? x]) {
e0;
}
augment enum E2 {
;
augment const E2([int? _]);
// ^
// [analyzer] unspecified
// [cfe] unspecified
}
main() {
print(C1);
print(C2);
print(E1);
print(E2);
}