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

Unified Diff: pkg/kernel/testcases/reify/field_initializer2_test.dart.expect

Issue 2697873007: Merge the work on Generic Types Reification from 'dart-lang/reify' repo (Closed)
Patch Set: Get back parameter erroneously removed by previous commit Created 3 years, 10 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/kernel/testcases/reify/field_initializer2_test.dart.expect
diff --git a/pkg/kernel/testcases/reify/field_initializer2_test.dart.expect b/pkg/kernel/testcases/reify/field_initializer2_test.dart.expect
new file mode 100644
index 0000000000000000000000000000000000000000..e27360d623fd4b6cdad91e396d86720b00f2f0d5
--- /dev/null
+++ b/pkg/kernel/testcases/reify/field_initializer2_test.dart.expect
@@ -0,0 +1,67 @@
+library field_initializer2_test;
+import self as self;
+import "dart:core" as core;
+import "../../runtime/reify/interceptors.dart" as int;
+import "../../runtime/reify/types.dart" as typ;
+import "./test_base.dart" as tes;
+import "../../runtime/reify/declarations.dart" as dec;
+
+class A extends core::Object implements int::HasRuntimeTypeGetter {
+ final field typ::ReifiedType $type;
+ constructor •(typ::ReifiedType $type) → void
+ : self::A::$type = $type, super core::Object::•()
+ ;
+ get $A$T() → typ::ReifiedType
+ return typ::getTypeArguments(typ::asInstanceOf(this.$type, self::$declarations.[](0))).[](0);
+ get $is$A() → core::bool
+ return true;
+ get runtimeType() → core::Type
+ return this.{=self::A::$type};
+}
+class B extends core::Object implements int::HasRuntimeTypeGetter {
+ field dynamic x;
+ field dynamic y;
+ final field typ::ReifiedType $type;
+ constructor •(typ::ReifiedType $type) → void
+ : self::B::x = self::B::$init$x($type), self::B::$type = $type, self::B::y = new self::A::•(new typ::Interface::•(self::$declarations.[](0), typ::getTypeArguments(typ::asInstanceOf($type, self::$declarations.[](1))))), super core::Object::•()
+ ;
+ get $B$T() → typ::ReifiedType
+ return typ::getTypeArguments(typ::asInstanceOf(this.$type, self::$declarations.[](1))).[](0);
+ get $is$A() → core::bool
+ return false;
+ get runtimeType() → core::Type
+ return this.{=self::B::$type};
+ static method $init$x(dynamic $type) → dynamic
+ return new self::A::•(new typ::Interface::•(self::$declarations.[](0), typ::getTypeArguments(typ::asInstanceOf($type, self::$declarations.[](1)))));
+}
+static final field core::List<dec::Class> $declarations = (core::List<dec::Class> d) → core::List<dec::Class> {
+ dec::init(d, 0, new typ::Interface::•(d.[](15)));
+ dec::init(d, 1, new typ::Interface::•(d.[](15)));
+ dec::init(d, 2, new typ::Interface::•(d.[](15)));
+ dec::init(d, 3, new typ::Interface::•(d.[](15)));
+ dec::init(d, 4, new typ::Interface::•(d.[](15)), <dynamic>[new typ::Interface::•(d.[](17), <dynamic>[new typ::Interface::•(d.[](4))]), new typ::Interface::•(d.[](18))]);
+ dec::init(d, 5, new typ::Interface::•(d.[](19)));
+ dec::init(d, 6, new typ::Interface::•(d.[](19)));
+ dec::init(d, 7, new typ::Interface::•(d.[](15)));
+ dec::init(d, 8, new typ::Interface::•(d.[](20)));
+ dec::init(d, 9, new typ::Interface::•(d.[](20)));
+ dec::init(d, 10, new typ::Interface::•(d.[](20)));
+ dec::init(d, 11, new typ::Interface::•(d.[](20)));
+ dec::init(d, 12, new typ::Interface::•(d.[](15)), <dynamic>[new typ::Interface::•(d.[](21))]);
+ dec::init(d, 13, new typ::Interface::•(d.[](14)));
+ dec::init(d, 14, new typ::Interface::•(d.[](20)));
+ dec::init(d, 15, null);
+ dec::init(d, 17, new typ::Interface::•(d.[](15)));
+ dec::init(d, 18, new typ::Interface::•(d.[](15)));
+ dec::init(d, 19, new typ::Interface::•(d.[](15)), <dynamic>[new typ::Interface::•(d.[](17), <dynamic>[new typ::Interface::•(d.[](19))])]);
+ dec::init(d, 20, new typ::Interface::•(d.[](15)));
+ dec::init(d, 21, new typ::Interface::•(d.[](15)));
+ return d;
+}.call(dec::allocateDeclarations(<dynamic>["A", "B", "Null", "bool", "String", "int", "double", "Type", "AbstractClassInstantiationError", "NoSuchMethodError", "CyclicInitializationError", "UnsupportedError", "IntegerDivisionByZeroException", "RangeError", "ArgumentError", "Object", "HasRuntimeTypeGetter", "Comparable", "Pattern", "num", "Error", "Exception"], <dynamic>[1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0]));
+static method main() → dynamic {
+ dynamic b = new self::B::•(new typ::Interface::•(self::$declarations.[](1), <dynamic>[new typ::Interface::•(self::$declarations.[](0), <dynamic>[const typ::Dynamic::•()])]));
+ tes::expectTrue(let dynamic #t1 = b.x in #t1 is int::HasRuntimeTypeGetter && #t1.$is$A && (let dynamic #t2 = new typ::Interface::•(self::$declarations.[](0), <dynamic>[new typ::Interface::•(self::$declarations.[](0), <dynamic>[const typ::Dynamic::•()])]) in typ::isSubtypeOf(#t1.$type, #t2)));
+ tes::expectTrue(let dynamic #t3 = b.y in #t3 is int::HasRuntimeTypeGetter && #t3.$is$A && (let dynamic #t4 = new typ::Interface::•(self::$declarations.[](0), <dynamic>[new typ::Interface::•(self::$declarations.[](0), <dynamic>[const typ::Dynamic::•()])]) in typ::isSubtypeOf(#t3.$type, #t4)));
+ tes::expectFalse(let dynamic #t5 = b.x in #t5 is int::HasRuntimeTypeGetter && #t5.$is$A && (let dynamic #t6 = new typ::Interface::•(self::$declarations.[](0), <dynamic>[new typ::Interface::•(self::$declarations.[](1), <dynamic>[const typ::Dynamic::•()])]) in typ::isSubtypeOf(#t5.$type, #t6)));
+ tes::expectFalse(let dynamic #t7 = b.y in #t7 is int::HasRuntimeTypeGetter && #t7.$is$A && (let dynamic #t8 = new typ::Interface::•(self::$declarations.[](0), <dynamic>[new typ::Interface::•(self::$declarations.[](1), <dynamic>[const typ::Dynamic::•()])]) in typ::isSubtypeOf(#t7.$type, #t8)));
+}
« no previous file with comments | « pkg/kernel/testcases/reify/field_initializer2_test.dart ('k') | pkg/kernel/testcases/reify/field_initializer_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698