Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(86)

Unified Diff: tests/language/abstract_method_test.dart

Issue 227703010: Fix instance method resolution with abstract accessors and methods (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/vm/parser.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/language/abstract_method_test.dart
===================================================================
--- tests/language/abstract_method_test.dart (revision 0)
+++ tests/language/abstract_method_test.dart (working copy)
@@ -0,0 +1,41 @@
+// Copyright (c) 2014, 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.
+
+import "package:expect/expect.dart";
+
+// Checks that abstract instance methods are correctly resolved.
+
+int get length => throw "error: top-level getter called";
+int set height(x) { throw "error: top-level setter called"; }
+width() { throw "error: top-level function called"; }
+
+class A {
+ int get length; // Abstract instance getter.
+ int set height(x); // Abstract instance setter.
+ int width(); // Abstract instance method.
+
+ // Must resolve to non-abstract length getter in subclass.
+ get useLength => length;
+ // Must resolve to non-abstract height setter in subclass.
+ setHeight(x) => height = x;
+ // Must resolve to non-abstract width() method in subclass.
+ useWidth() => width();
+}
+
+class A1 extends A {
+ int length; // Implies a length getter.
+ int height; // Implies a height setter.
+ int width() => 345;
+ A1(this.length);
+}
+
+main() {
+ var a = new A1(123);
+ Expect.equals(123, a.useLength);
+ a.setHeight(234);
+ Expect.equals(234, a.height);
+ Expect.equals(345, a.useWidth());
+ print([a.useLength, a.height, a.useWidth()]);
+}
+
« no previous file with comments | « runtime/vm/parser.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698