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