| OLD | NEW |
| 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2017, 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 import 'dart:io' hide Link; | 5 import 'dart:io' hide Link; |
| 6 import 'package:async_helper/async_helper.dart'; | 6 import 'package:async_helper/async_helper.dart'; |
| 7 import 'package:compiler/src/closure.dart'; | 7 import 'package:compiler/src/closure.dart'; |
| 8 import 'package:compiler/src/commandline_options.dart'; | 8 import 'package:compiler/src/commandline_options.dart'; |
| 9 import 'package:compiler/src/common.dart'; | 9 import 'package:compiler/src/common.dart'; |
| 10 import 'package:compiler/src/compiler.dart'; | 10 import 'package:compiler/src/compiler.dart'; |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 void computeKernelClosureData( | 52 void computeKernelClosureData( |
| 53 Compiler compiler, MemberEntity member, Map<Id, ActualData> actualMap, | 53 Compiler compiler, MemberEntity member, Map<Id, ActualData> actualMap, |
| 54 {bool verbose: false}) { | 54 {bool verbose: false}) { |
| 55 KernelBackendStrategy backendStrategy = compiler.backendStrategy; | 55 KernelBackendStrategy backendStrategy = compiler.backendStrategy; |
| 56 KernelToElementMapForBuilding elementMap = backendStrategy.elementMap; | 56 KernelToElementMapForBuilding elementMap = backendStrategy.elementMap; |
| 57 GlobalLocalsMap localsMap = backendStrategy.globalLocalsMapForTesting; | 57 GlobalLocalsMap localsMap = backendStrategy.globalLocalsMapForTesting; |
| 58 ClosureDataLookup closureDataLookup = backendStrategy.closureDataLookup; | 58 ClosureDataLookup closureDataLookup = backendStrategy.closureDataLookup; |
| 59 MemberDefinition definition = elementMap.getMemberDefinition(member); | 59 MemberDefinition definition = elementMap.getMemberDefinition(member); |
| 60 assert(definition.kind == MemberKind.regular, | 60 assert(definition.kind == MemberKind.regular, |
| 61 failedAt(member, "Unexpected member definition $definition")); | 61 failedAt(member, "Unexpected member definition $definition")); |
| 62 new ClosureIrChecker(actualMap, elementMap, member, | 62 new ClosureIrChecker(compiler.reporter, actualMap, elementMap, member, |
| 63 localsMap.getLocalsMap(member), closureDataLookup, | 63 localsMap.getLocalsMap(member), closureDataLookup, |
| 64 verbose: verbose) | 64 verbose: verbose) |
| 65 .run(definition.node); | 65 .run(definition.node); |
| 66 } | 66 } |
| 67 | 67 |
| 68 /// Ast visitor for computing closure data. | 68 /// Ast visitor for computing closure data. |
| 69 class ClosureAstComputer extends AstDataExtractor with ComputeValueMixin { | 69 class ClosureAstComputer extends AstDataExtractor with ComputeValueMixin { |
| 70 final ClosureDataLookup<ast.Node> closureDataLookup; | 70 final ClosureDataLookup<ast.Node> closureDataLookup; |
| 71 final bool verbose; | 71 final bool verbose; |
| 72 | 72 |
| (...skipping 11 matching lines...) Expand all Loading... |
| 84 pushLocalFunction(node); | 84 pushLocalFunction(node); |
| 85 super.visitFunctionExpression(node); | 85 super.visitFunctionExpression(node); |
| 86 popLocalFunction(); | 86 popLocalFunction(); |
| 87 popMember(); | 87 popMember(); |
| 88 } else { | 88 } else { |
| 89 super.visitFunctionExpression(node); | 89 super.visitFunctionExpression(node); |
| 90 } | 90 } |
| 91 } | 91 } |
| 92 | 92 |
| 93 @override | 93 @override |
| 94 String computeNodeValue(ast.Node node, [AstElement element]) { | 94 String computeNodeValue(Id id, ast.Node node, [AstElement element]) { |
| 95 if (element != null && element.isLocal) { | 95 if (element != null && element.isLocal) { |
| 96 if (element.isFunction) { | 96 if (element.isFunction) { |
| 97 LocalFunctionElement localFunction = element; | 97 LocalFunctionElement localFunction = element; |
| 98 return computeObjectValue(localFunction.callMethod); | 98 return computeObjectValue(localFunction.callMethod); |
| 99 } else { | 99 } else { |
| 100 LocalElement local = element; | 100 LocalElement local = element; |
| 101 return computeLocalValue(local); | 101 return computeLocalValue(local); |
| 102 } | 102 } |
| 103 } | 103 } |
| 104 // TODO(johnniwinther,efortuna): Collect data for other nodes? | 104 // TODO(johnniwinther,efortuna): Collect data for other nodes? |
| 105 return null; | 105 return null; |
| 106 } | 106 } |
| 107 | 107 |
| 108 @override | 108 @override |
| 109 String computeElementValue(covariant MemberElement element) { | 109 String computeElementValue(Id id, covariant MemberElement element) { |
| 110 // TODO(johnniwinther,efortuna): Collect data for the member | 110 // TODO(johnniwinther,efortuna): Collect data for the member |
| 111 // (has thisLocal, has box, etc.). | 111 // (has thisLocal, has box, etc.). |
| 112 return computeObjectValue(element); | 112 return computeObjectValue(element); |
| 113 } | 113 } |
| 114 } | 114 } |
| 115 | 115 |
| 116 /// Kernel IR visitor for computing closure data. | 116 /// Kernel IR visitor for computing closure data. |
| 117 class ClosureIrChecker extends IrDataExtractor with ComputeValueMixin<ir.Node> { | 117 class ClosureIrChecker extends IrDataExtractor with ComputeValueMixin<ir.Node> { |
| 118 final MemberEntity member; | 118 final MemberEntity member; |
| 119 final ClosureDataLookup<ir.Node> closureDataLookup; | 119 final ClosureDataLookup<ir.Node> closureDataLookup; |
| 120 final KernelToLocalsMap _localsMap; | 120 final KernelToLocalsMap _localsMap; |
| 121 final bool verbose; | 121 final bool verbose; |
| 122 | 122 |
| 123 ClosureIrChecker( | 123 ClosureIrChecker( |
| 124 DiagnosticReporter reporter, |
| 124 Map<Id, ActualData> actualMap, | 125 Map<Id, ActualData> actualMap, |
| 125 KernelToElementMapForBuilding elementMap, | 126 KernelToElementMapForBuilding elementMap, |
| 126 this.member, | 127 this.member, |
| 127 this._localsMap, | 128 this._localsMap, |
| 128 this.closureDataLookup, | 129 this.closureDataLookup, |
| 129 {this.verbose: false}) | 130 {this.verbose: false}) |
| 130 : super(actualMap) { | 131 : super(reporter, actualMap) { |
| 131 pushMember(member); | 132 pushMember(member); |
| 132 } | 133 } |
| 133 | 134 |
| 134 visitFunctionExpression(ir.FunctionExpression node) { | 135 visitFunctionExpression(ir.FunctionExpression node) { |
| 135 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); | 136 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); |
| 136 pushMember(info.callMethod); | 137 pushMember(info.callMethod); |
| 137 pushLocalFunction(node); | 138 pushLocalFunction(node); |
| 138 super.visitFunctionExpression(node); | 139 super.visitFunctionExpression(node); |
| 139 popLocalFunction(); | 140 popLocalFunction(); |
| 140 popMember(); | 141 popMember(); |
| 141 } | 142 } |
| 142 | 143 |
| 143 visitFunctionDeclaration(ir.FunctionDeclaration node) { | 144 visitFunctionDeclaration(ir.FunctionDeclaration node) { |
| 144 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); | 145 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); |
| 145 pushMember(info.callMethod); | 146 pushMember(info.callMethod); |
| 146 pushLocalFunction(node); | 147 pushLocalFunction(node); |
| 147 super.visitFunctionDeclaration(node); | 148 super.visitFunctionDeclaration(node); |
| 148 popLocalFunction(); | 149 popLocalFunction(); |
| 149 popMember(); | 150 popMember(); |
| 150 } | 151 } |
| 151 | 152 |
| 152 @override | 153 @override |
| 153 String computeNodeValue(ir.Node node) { | 154 String computeNodeValue(Id id, ir.Node node) { |
| 154 if (node is ir.VariableDeclaration) { | 155 if (node is ir.VariableDeclaration) { |
| 155 if (node.parent is ir.FunctionDeclaration) { | |
| 156 ClosureRepresentationInfo info = | |
| 157 closureDataLookup.getClosureInfo(node.parent); | |
| 158 return computeObjectValue(info.callMethod); | |
| 159 } | |
| 160 Local local = _localsMap.getLocalVariable(node); | 156 Local local = _localsMap.getLocalVariable(node); |
| 161 return computeLocalValue(local); | 157 return computeLocalValue(local); |
| 158 } else if (node is ir.FunctionDeclaration) { |
| 159 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); |
| 160 return computeObjectValue(info.callMethod); |
| 162 } else if (node is ir.FunctionExpression) { | 161 } else if (node is ir.FunctionExpression) { |
| 163 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); | 162 ClosureRepresentationInfo info = closureDataLookup.getClosureInfo(node); |
| 164 return computeObjectValue(info.callMethod); | 163 return computeObjectValue(info.callMethod); |
| 165 } | 164 } |
| 166 return null; | 165 return null; |
| 167 } | 166 } |
| 168 | 167 |
| 169 @override | 168 @override |
| 170 String computeMemberValue(ir.Member node) { | 169 String computeMemberValue(Id id, ir.Member node) { |
| 171 return computeObjectValue(member); | 170 return computeObjectValue(member); |
| 172 } | 171 } |
| 173 } | 172 } |
| 174 | 173 |
| 175 abstract class ComputeValueMixin<T> { | 174 abstract class ComputeValueMixin<T> { |
| 176 bool get verbose; | 175 bool get verbose; |
| 177 Map<BoxLocal, String> boxNames = <BoxLocal, String>{}; | 176 Map<BoxLocal, String> boxNames = <BoxLocal, String>{}; |
| 178 ClosureDataLookup<T> get closureDataLookup; | 177 ClosureDataLookup<T> get closureDataLookup; |
| 179 Link<ScopeInfo> scopeInfoStack = const Link<ScopeInfo>(); | 178 Link<ScopeInfo> scopeInfoStack = const Link<ScopeInfo>(); |
| 180 ScopeInfo get scopeInfo => scopeInfoStack.head; | 179 ScopeInfo get scopeInfo => scopeInfoStack.head; |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 311 if (value != '') { | 310 if (value != '') { |
| 312 sb.write('='); | 311 sb.write('='); |
| 313 sb.write(value); | 312 sb.write(value); |
| 314 } | 313 } |
| 315 needsComma = true; | 314 needsComma = true; |
| 316 } | 315 } |
| 317 } | 316 } |
| 318 return sb.toString(); | 317 return sb.toString(); |
| 319 } | 318 } |
| 320 } | 319 } |
| OLD | NEW |