mirror of
https://github.com/dart-lang/sdk
synced 2024-09-19 14:51:30 +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>
23 lines
625 B
Dart
23 lines
625 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.
|
|
|
|
// Regression test for dart2js that used to infer that code following
|
|
// a dynamic call could assume the receiver is not null. This does not
|
|
// work for Object methods.
|
|
|
|
import "package:expect/expect.dart";
|
|
|
|
main() {
|
|
var a = true ? null : 42;
|
|
a.toString();
|
|
foo(a);
|
|
}
|
|
|
|
@pragma('vm:never-inline')
|
|
@pragma('dart2js:noInline')
|
|
foo(a) {
|
|
var f = () => 42;
|
|
Expect.throwsNoSuchMethodError(() => a + 42);
|
|
}
|