Skip to content

Commit

Permalink
#2339. Add more tests for the extension method with the name type (#…
Browse files Browse the repository at this point in the history
…2542)

Note that these tests have intentional syntax errors.
  • Loading branch information
sgrekhov authored Feb 13, 2024
1 parent 6e18976 commit ed8e9db
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 0 deletions.
25 changes: 25 additions & 0 deletions LanguageFeatures/Extension-methods/syntax_t08.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
// Copyright (c) 2024, 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 an extension declaration is a top-level declaration with a grammar
/// similar to:
/// <extension> ::=
/// `extension' <identifier>? <typeParameters>? `on' <type> `?'? `{'
/// memberDeclaration*
/// `}'
/// Such a declaration introduces its name (the identifier) into the surrounding
/// scope
///
/// @description Check that it is a compile-time error if an extension has the
/// name `type`. Test empty record type
/// @author sgrekhov22@gmail.com
extension type on () {}
// ^
// [analyzer] unspecified
// [cfe] unspecified

main() {
print(());
}
25 changes: 25 additions & 0 deletions LanguageFeatures/Extension-methods/syntax_t09.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
// Copyright (c) 2024, 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 an extension declaration is a top-level declaration with a grammar
/// similar to:
/// <extension> ::=
/// `extension' <identifier>? <typeParameters>? `on' <type> `?'? `{'
/// memberDeclaration*
/// `}'
/// Such a declaration introduces its name (the identifier) into the surrounding
/// scope
///
/// @description Check that it is a compile-time error if an extension has the
/// name `type`. Test record type with a named field
/// @author sgrekhov22@gmail.com
extension type on ({int i}) {}
// ^
// [analyzer] unspecified
// [cfe] unspecified

main() {
print((i: 42));
}

0 comments on commit ed8e9db

Please sign in to comment.