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

Unified Diff: pkg/front_end/testcases/inference/infer_assign_to_property_super.dart.direct.expect

Issue 2931363003: Add type inference for assignments to properties. (Closed)
Patch Set: Created 3 years, 6 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
Index: pkg/front_end/testcases/inference/infer_assign_to_property_super.dart.direct.expect
diff --git a/pkg/front_end/testcases/inference/infer_assign_to_property_super.dart.direct.expect b/pkg/front_end/testcases/inference/infer_assign_to_property_super.dart.direct.expect
new file mode 100644
index 0000000000000000000000000000000000000000..64d4d36f26345221de4fd0dd606781f55e6e7646
--- /dev/null
+++ b/pkg/front_end/testcases/inference/infer_assign_to_property_super.dart.direct.expect
@@ -0,0 +1,57 @@
+library test;
+import self as self;
+import "dart:core" as core;
+
+class A extends core::Object {
+ constructor •() → void
+ : super core::Object::•()
+ ;
+}
+class B extends self::A {
+ constructor •() → void
+ : super self::A::•()
+ ;
+ operator +(self::C v) → self::A
+ return null;
+ operator -(core::int i) → self::B
+ return null;
+ operator *(self::B v) → self::B
+ return null;
+ operator &(self::A v) → self::C
+ return null;
+}
+class C extends self::B {
+ constructor •() → void
+ : super self::B::•()
+ ;
+}
+class Base extends core::Object {
+ field self::B member = null;
+ constructor •() → void
+ : super core::Object::•()
+ ;
+}
+class Test extends self::Base {
+ constructor •() → void
+ : super self::Base::•()
+ ;
+ method test() → void {
+ this.{=self::Base::member} = self::f();
+ this.{=self::Base::member}.==(null) ? this.{=self::Base::member} = self::f() : null;
+ this.{=self::Base::member} = this.{=self::Base::member}.+(self::f());
+ this.{=self::Base::member} = this.{=self::Base::member}.*(self::f());
+ this.{=self::Base::member} = this.{=self::Base::member}.&(self::f());
+ this.{=self::Base::member} = this.{=self::Base::member}.-(1);
+ this.{=self::Base::member} = this.{=self::Base::member}.-(1);
+ dynamic v1 = this.{=self::Base::member} = self::f();
+ dynamic v2 = let final dynamic #t1 = this.{=self::Base::member} in #t1.==(null) ? this.{=self::Base::member} = self::f() : #t1;
+ dynamic v3 = this.{=self::Base::member} = this.{=self::Base::member}.+(self::f());
+ dynamic v4 = this.{=self::Base::member} = this.{=self::Base::member}.*(self::f());
+ dynamic v5 = this.{=self::Base::member} = this.{=self::Base::member}.&(self::f());
+ dynamic v6 = this.{=self::Base::member} = this.{=self::Base::member}.-(1);
+ dynamic v7 = let final dynamic #t2 = this.{=self::Base::member} in let final dynamic #t3 = this.{=self::Base::member} = #t2.-(1) in #t2;
+ }
+}
+static method f() → dynamic
+ return null;
+static method main() → dynamic {}

Powered by Google App Engine
This is Rietveld 408576698