Index: pkg/compiler/lib/src/tree_ir/tree_ir_nodes.dart |
diff --git a/pkg/compiler/lib/src/tree_ir/tree_ir_nodes.dart b/pkg/compiler/lib/src/tree_ir/tree_ir_nodes.dart |
index c2e67b79e046a8c5be4abdd3ad8bf05495631959..fe216b17377bc80c77477838d2a9ab97b6fb57d4 100644 |
--- a/pkg/compiler/lib/src/tree_ir/tree_ir_nodes.dart |
+++ b/pkg/compiler/lib/src/tree_ir/tree_ir_nodes.dart |
@@ -330,13 +330,14 @@ class LiteralMap extends Expression { |
} |
} |
-/// Given the interceptor for a value, test the value against a type. |
class TypeOperator extends Expression { |
- Expression receiver; |
+ Expression value; |
final DartType type; |
+ final List<Expression> typeArguments; |
final bool isTypeTest; |
- TypeOperator(this.receiver, this.type, {bool this.isTypeTest}); |
+ TypeOperator(this.value, this.type, this.typeArguments, |
+ {bool this.isTypeTest}); |
accept(ExpressionVisitor visitor) => visitor.visitTypeOperator(this); |
accept1(ExpressionVisitor1 visitor, arg) { |
@@ -1157,7 +1158,8 @@ abstract class RecursiveVisitor implements StatementVisitor, ExpressionVisitor { |
} |
visitTypeOperator(TypeOperator node) { |
- visitExpression(node.receiver); |
+ visitExpression(node.value); |
+ node.typeArguments.forEach(visitExpression); |
} |
visitFunctionExpression(FunctionExpression node) { |
@@ -1349,7 +1351,8 @@ class RecursiveTransformer extends Transformer { |
} |
visitTypeOperator(TypeOperator node) { |
- node.receiver = visitExpression(node.receiver); |
+ node.value = visitExpression(node.value); |
+ _replaceExpressions(node.typeArguments); |
return node; |
} |