mirror of
https://github.com/dart-lang/sdk
synced 2024-09-19 21:11:40 +00:00
b101a7d002
Change-Id: Ib33169c3e0ffc870915c189404074a1dea472546 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/196548 Reviewed-by: Bob Nystrom <rnystrom@google.com> Commit-Queue: Leaf Petersen <leafp@google.com>
55 lines
1.2 KiB
Dart
55 lines
1.2 KiB
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.
|
|
|
|
// @dart = 2.9
|
|
|
|
// dart2js regression test for issue 8781.
|
|
|
|
import "package:expect/expect.dart";
|
|
|
|
class N {
|
|
var outgoing;
|
|
var incoming;
|
|
N(this.outgoing, this.incoming);
|
|
}
|
|
|
|
class A {
|
|
int offset = 0;
|
|
var list;
|
|
var node;
|
|
|
|
A(node)
|
|
: node = node,
|
|
list = node.outgoing;
|
|
|
|
next() {
|
|
// dart2js used to update [offset] twice: once in the optimized
|
|
// version, which would bailout to the non-optimized version
|
|
// because [list] is not an Array, and once in the non-optimized
|
|
// version.
|
|
var edge = list[offset++];
|
|
if (list == node.outgoing) {
|
|
list = node.incoming;
|
|
offset = 0;
|
|
} else
|
|
list = null;
|
|
return edge;
|
|
}
|
|
}
|
|
|
|
main() {
|
|
var o = new A(new N(confuse([1]), confuse([2])));
|
|
|
|
for (var i = 1; i <= 2; i++) Expect.equals(i, o.next());
|
|
|
|
Expect.equals(null, o.list);
|
|
}
|
|
|
|
// Use confuse to defeat type inferencing.
|
|
@pragma('dart2js:noInline')
|
|
@pragma('dart2js:assumeDynamic')
|
|
confuse(x) {
|
|
return x;
|
|
}
|