| library /*isNonNullableByDefault*/; |
| // |
| // Problems in library: |
| // |
| // pkg/front_end/testcases/dart2js/issue47916f.dart:10:17: Error: Cyclic definition of factory 'B'. |
| // const factory B() = C; |
| // ^ |
| // |
| // pkg/front_end/testcases/dart2js/issue47916f.dart:14:17: Error: Cyclic definition of factory 'C'. |
| // const factory C() = B; |
| // ^ |
| // |
| import self as self; |
| import "dart:core" as core; |
| |
| abstract class A<T extends core::Object? = dynamic> extends core::Object { |
| static final field dynamic _redirecting# = <dynamic>[self::A::•]/*isLegacy*/; |
| static factory •<T extends core::Object? = dynamic>() → self::A<self::A::•::T%> |
| return self::B::•<self::A::•::T%>(); |
| static method _#new#tearOff<T extends core::Object? = dynamic>() → self::A<self::A::_#new#tearOff::T%>; |
| } |
| abstract class B<T extends core::Object? = dynamic> extends core::Object implements self::A<self::B::T%> { |
| static final field dynamic _redirecting# = <dynamic>[self::B::•]/*isLegacy*/; |
| static factory •<T extends core::Object? = dynamic>() → self::B<self::B::•::T%> |
| return invalid-expression "pkg/front_end/testcases/dart2js/issue47916f.dart:10:17: Error: Cyclic definition of factory 'B'. |
| const factory B() = C; |
| ^"; |
| static method _#new#tearOff<T extends core::Object? = dynamic>() → self::B<self::B::_#new#tearOff::T%>; |
| } |
| class C<T extends core::Object? = dynamic> extends core::Object implements self::B<self::C::T%> { |
| static final field dynamic _redirecting# = <dynamic>[self::C::•]/*isLegacy*/; |
| static factory •<T extends core::Object? = dynamic>() → self::C<self::C::•::T%> |
| return invalid-expression "pkg/front_end/testcases/dart2js/issue47916f.dart:14:17: Error: Cyclic definition of factory 'C'. |
| const factory C() = B; |
| ^"; |
| static method _#new#tearOff<T extends core::Object? = dynamic>() → self::C<self::C::_#new#tearOff::T%>; |
| } |
| static method test() → dynamic |
| ; |
| static method main() → dynamic |
| ; |
| |
| |
| Extra constant evaluation status: |
| Evaluated: ConstructorTearOff @ org-dartlang-testcase:///issue47916f.dart:5:16 -> ConstructorTearOffConstant(A.) |
| Evaluated: ConstructorTearOff @ org-dartlang-testcase:///issue47916f.dart:9:16 -> ConstructorTearOffConstant(B.) |
| Evaluated: ConstructorTearOff @ org-dartlang-testcase:///issue47916f.dart:13:7 -> ConstructorTearOffConstant(C.) |
| Extra constant evaluation: evaluated: 7, effectively constant: 3 |