mirror of
https://github.com/dart-lang/sdk
synced 2024-11-02 12:24:24 +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>
31 lines
887 B
Dart
31 lines
887 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.
|
|
|
|
// Test that dart2js's inferrer and code optimizers know a double
|
|
// literal might become an int at runtime.
|
|
|
|
import "package:expect/expect.dart";
|
|
|
|
@pragma('vm:never-inline')
|
|
@pragma('dart2js:noInline')
|
|
callWithStringAndDouble(value) {
|
|
() => 42;
|
|
if (value is! int) throw new ArgumentError(value);
|
|
return 42;
|
|
}
|
|
|
|
@pragma('vm:never-inline')
|
|
@pragma('dart2js:noInline')
|
|
callWithDouble(value) {
|
|
() => 42;
|
|
if (value is! int) throw new ArgumentError(value);
|
|
return 42;
|
|
}
|
|
|
|
main() {
|
|
Expect.throws(
|
|
() => callWithStringAndDouble('foo'), (e) => e is ArgumentError);
|
|
Expect.equals(42, callWithStringAndDouble(0.0));
|
|
Expect.equals(42, callWithDouble(0.0));
|
|
}
|