mirror of
https://github.com/dart-lang/sdk
synced 2024-10-14 10:13:38 +00:00
912005267d
Change-Id: I46be49b2effec3e38a3dc44cd45cfe736f77fa78 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/182680 Commit-Queue: Sigmund Cherem <sigmund@google.com> Reviewed-by: Joshua Litt <joshualitt@google.com> Reviewed-by: Nicholas Shahan <nshahan@google.com> Reviewed-by: Stephen Adams <sra@google.com>
36 lines
941 B
Dart
36 lines
941 B
Dart
// Copyright (c) 2013, 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.
|
|
|
|
/// This is a regression test from issue #29310. The global type-inferrer does
|
|
/// tracing of closures including allocated classes that implement a `call`
|
|
/// method. We incorrectly considered also classes with invoked factory
|
|
/// constructors, even if those were only abstract interfaces or mixins that
|
|
/// weren't actually allocated explicitly.
|
|
library regression_29130;
|
|
|
|
main() {
|
|
new B();
|
|
new C();
|
|
}
|
|
|
|
class A {
|
|
call() {}
|
|
}
|
|
|
|
// interface scenario: we shouldn't trace B
|
|
abstract class B implements A {
|
|
factory B() => DummyB();
|
|
}
|
|
|
|
class DummyB implements B {
|
|
call() {}
|
|
}
|
|
|
|
// mixin scenario: we should trace C, but we should trace _C
|
|
abstract class C implements A {
|
|
factory C() => new D();
|
|
}
|
|
|
|
class D = A with C;
|