| OLD | NEW | 
|---|
| 1 // Copyright (c) 2014, the Dart project authors.  Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors.  Please see the AUTHORS file | 
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a | 
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. | 
| 4 | 4 | 
| 5 library tree_ir.optimization.statement_rewriter; | 5 library tree_ir.optimization.statement_rewriter; | 
| 6 | 6 | 
| 7 import 'optimization.dart' show Pass; | 7 import 'optimization.dart' show Pass; | 
| 8 import '../tree_ir_nodes.dart'; | 8 import '../tree_ir_nodes.dart'; | 
| 9 | 9 | 
| 10 /** | 10 /** | 
| (...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 281   /// Returns true if [exp] has no side effects and has a constant value within | 281   /// Returns true if [exp] has no side effects and has a constant value within | 
| 282   /// any given activation of the enclosing method. | 282   /// any given activation of the enclosing method. | 
| 283   bool isEffectivelyConstant(Expression exp) { | 283   bool isEffectivelyConstant(Expression exp) { | 
| 284     // TODO(asgerf): Can be made more aggressive e.g. by checking conditional | 284     // TODO(asgerf): Can be made more aggressive e.g. by checking conditional | 
| 285     // expressions recursively. Determine if that is a valuable optimization | 285     // expressions recursively. Determine if that is a valuable optimization | 
| 286     // and/or if it is better handled at the CPS level. | 286     // and/or if it is better handled at the CPS level. | 
| 287     return exp is Constant || | 287     return exp is Constant || | 
| 288            exp is This || | 288            exp is This || | 
| 289            exp is CreateInvocationMirror || | 289            exp is CreateInvocationMirror || | 
| 290            exp is InvokeStatic && exp.isEffectivelyConstant || | 290            exp is InvokeStatic && exp.isEffectivelyConstant || | 
|  | 291            exp is Interceptor || | 
| 291            exp is ApplyBuiltinOperator || | 292            exp is ApplyBuiltinOperator || | 
| 292            exp is VariableUse && constantEnvironment.containsKey(exp.variable); | 293            exp is VariableUse && constantEnvironment.containsKey(exp.variable); | 
| 293   } | 294   } | 
| 294 | 295 | 
| 295   /// True if [node] is an assignment that can be propagated as a constant. | 296   /// True if [node] is an assignment that can be propagated as a constant. | 
| 296   bool isEffectivelyConstantAssignment(Expression node) { | 297   bool isEffectivelyConstantAssignment(Expression node) { | 
| 297     return node is Assign && | 298     return node is Assign && | 
| 298            node.variable.writeCount == 1 && | 299            node.variable.writeCount == 1 && | 
| 299            isEffectivelyConstant(node.value); | 300            isEffectivelyConstant(node.value); | 
| 300   } | 301   } | 
| (...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 623   Expression visitTypeExpression(TypeExpression node) { | 624   Expression visitTypeExpression(TypeExpression node) { | 
| 624     _rewriteList(node.arguments); | 625     _rewriteList(node.arguments); | 
| 625     return node; | 626     return node; | 
| 626   } | 627   } | 
| 627 | 628 | 
| 628   Expression visitCreateInvocationMirror(CreateInvocationMirror node) { | 629   Expression visitCreateInvocationMirror(CreateInvocationMirror node) { | 
| 629     _rewriteList(node.arguments); | 630     _rewriteList(node.arguments); | 
| 630     return node; | 631     return node; | 
| 631   } | 632   } | 
| 632 | 633 | 
|  | 634   Expression visitInterceptor(Interceptor node) { | 
|  | 635     node.input = visitExpression(node.input); | 
|  | 636     return node; | 
|  | 637   } | 
|  | 638 | 
| 633   /// True if [operator] is a binary operator that always has the same value | 639   /// True if [operator] is a binary operator that always has the same value | 
| 634   /// if its arguments are swapped. | 640   /// if its arguments are swapped. | 
| 635   bool isSymmetricOperator(BuiltinOperator operator) { | 641   bool isSymmetricOperator(BuiltinOperator operator) { | 
| 636     switch (operator) { | 642     switch (operator) { | 
| 637       case BuiltinOperator.StrictEq: | 643       case BuiltinOperator.StrictEq: | 
| 638       case BuiltinOperator.StrictNeq: | 644       case BuiltinOperator.StrictNeq: | 
| 639       case BuiltinOperator.LooseEq: | 645       case BuiltinOperator.LooseEq: | 
| 640       case BuiltinOperator.LooseNeq: | 646       case BuiltinOperator.LooseNeq: | 
| 641       case BuiltinOperator.NumAnd: | 647       case BuiltinOperator.NumAnd: | 
| 642       case BuiltinOperator.NumOr: | 648       case BuiltinOperator.NumOr: | 
| (...skipping 390 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1033   IsVariableUsedVisitor(this.variable); | 1039   IsVariableUsedVisitor(this.variable); | 
| 1034 | 1040 | 
| 1035   visitVariableUse(VariableUse node) { | 1041   visitVariableUse(VariableUse node) { | 
| 1036     if (node.variable == variable) { | 1042     if (node.variable == variable) { | 
| 1037       wasFound = true; | 1043       wasFound = true; | 
| 1038     } | 1044     } | 
| 1039   } | 1045   } | 
| 1040 | 1046 | 
| 1041   visitInnerFunction(FunctionDefinition node) {} | 1047   visitInnerFunction(FunctionDefinition node) {} | 
| 1042 } | 1048 } | 
| OLD | NEW | 
|---|