mirror of
https://github.com/dart-lang/sdk
synced 2024-09-15 23:39:48 +00:00
db90fd784b
Remove the `@DontInline()` annotation. None of the backends implemented it. (Searching for "DontInline" yields nothing in our code base.) Instead replaced the use sites with `@pragma('vm:never-inline')` and `@pragma('dart2js:noInline')`, which are implemented in the backends. Original suggestion: https://dart-review.googlesource.com/c/sdk/+/208080/4..6/tests/language_2/const/map_hashcode_override_test.dart#b11 Change-Id: Ifdcfc8ef3413d0b5964edc1bc1fa47c5ce306935 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/208082 Reviewed-by: Erik Ernst <eernst@google.com> Commit-Queue: Daco Harkes <dacoharkes@google.com>
41 lines
1.1 KiB
Dart
41 lines
1.1 KiB
Dart
// TODO(multitest): This was automatically migrated from a multitest and may
|
|
// contain strange or dead code.
|
|
|
|
// 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.
|
|
|
|
// Regression test for dart2js that used to duplicate some `Object`
|
|
// methods to handle `noSuchMethod`.
|
|
|
|
import "package:expect/expect.dart";
|
|
|
|
class Foo {
|
|
noSuchMethod(im) => 42;
|
|
}
|
|
|
|
@pragma('vm:never-inline')
|
|
@pragma('dart2js:noInline')
|
|
returnFoo() {
|
|
(() => 42)();
|
|
return new Foo();
|
|
}
|
|
|
|
class Bar {
|
|
operator ==(other) => false;
|
|
}
|
|
|
|
var a = [false, true, new Object(), new Bar()];
|
|
|
|
main() {
|
|
if (a[0] as bool) {
|
|
// This `==` call will make the compiler create a selector with an
|
|
// exact `TypeMask` of `Foo`. Since `Foo` is abstract, such a call
|
|
// cannot happen, but we still used to generate a `==` method on
|
|
// the `Object` class to handle `noSuchMethod`.
|
|
print(returnFoo() == 42);
|
|
} else {
|
|
Expect.isFalse(a[2] == 42);
|
|
}
|
|
}
|