mirror of
https://github.com/dart-lang/sdk
synced 2024-09-16 04:16:51 +00:00
d4154ac6dc
Change-Id: Iad2963c7f9c184b089dc6d15aa4442f58d194bc2 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/151983 Reviewed-by: Nicholas Shahan <nshahan@google.com> Commit-Queue: Bob Nystrom <rnystrom@google.com> Auto-Submit: Bob Nystrom <rnystrom@google.com>
37 lines
880 B
Dart
37 lines
880 B
Dart
// Copyright (c) 2017, 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 test exercises a corner case of override checking that is safe from a
|
|
// soundness perspective, but which we haven't decided whether or not to allow
|
|
// from a usability perspective.
|
|
|
|
class A {
|
|
void foo() {}
|
|
}
|
|
|
|
abstract class I {
|
|
void foo([x]);
|
|
}
|
|
|
|
abstract class B extends A implements I {
|
|
// If this class were concrete, there would be a problem, since `new
|
|
// B().foo(42)` would be statically allowed, but would lead to invalid
|
|
// arguments being passed to A.foo. But since the class is abstract, there is
|
|
// no problem.
|
|
}
|
|
|
|
class C extends B {
|
|
void foo([x]) {
|
|
super.foo();
|
|
}
|
|
}
|
|
|
|
void f(B b) {
|
|
b.foo(42);
|
|
}
|
|
|
|
main() {
|
|
f(new C());
|
|
}
|