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 'package:kernel/ast.dart' as ir; | 5 import 'package:kernel/ast.dart' as ir; |
6 | 6 |
7 import '../closure.dart'; | 7 import '../closure.dart'; |
8 import '../compiler.dart'; | 8 import '../compiler.dart'; |
9 import '../elements/elements.dart'; | 9 import '../elements/elements.dart'; |
10 import '../elements/entities.dart'; | 10 import '../elements/entities.dart'; |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 // Eagerly bailout, because computing the closure data only | 96 // Eagerly bailout, because computing the closure data only |
97 // works for functions and field assignments. | 97 // works for functions and field assignments. |
98 return types.nullType; | 98 return types.nullType; |
99 } | 99 } |
100 } | 100 } |
101 | 101 |
102 // Update the locals that are boxed in [locals]. These locals will | 102 // Update the locals that are boxed in [locals]. These locals will |
103 // be handled specially, in that we are computing their LUB at | 103 // be handled specially, in that we are computing their LUB at |
104 // each update, and reading them yields the type that was found in a | 104 // each update, and reading them yields the type that was found in a |
105 // previous analysis of [outermostElement]. | 105 // previous analysis of [outermostElement]. |
106 ClosureRepresentationInfo closureData = compiler.closureDataLookup | 106 ClosureRepresentationInfo closureData = compiler |
| 107 .backendStrategy.closureDataLookup |
107 .getClosureRepresentationInfo(resolvedAst.element); | 108 .getClosureRepresentationInfo(resolvedAst.element); |
108 closureData.forEachCapturedVariable((variable, field) { | 109 closureData.forEachCapturedVariable((variable, field) { |
109 locals.setCaptured(variable, field); | 110 locals.setCaptured(variable, field); |
110 }); | 111 }); |
111 closureData.forEachBoxedVariable((variable, field) { | 112 closureData.forEachBoxedVariable((variable, field) { |
112 locals.setCapturedAndBoxed(variable, field); | 113 locals.setCapturedAndBoxed(variable, field); |
113 }); | 114 }); |
114 | 115 |
115 if (analyzedNode is ir.Field) { | 116 if (analyzedNode is ir.Field) { |
116 return initializer.accept(this); | 117 return initializer.accept(this); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
162 : types.simplifyPhi(null, null, elementType); | 163 : types.simplifyPhi(null, null, elementType); |
163 TypeInformation containerType = | 164 TypeInformation containerType = |
164 listLiteral.isConst ? types.constListType : types.growableListType; | 165 listLiteral.isConst ? types.constListType : types.growableListType; |
165 // TODO(efortuna): Change signature of allocateList and the rest of | 166 // TODO(efortuna): Change signature of allocateList and the rest of |
166 // type_system to deal with Kernel elements. | 167 // type_system to deal with Kernel elements. |
167 return types.allocateList(containerType, astAdapter.getNode(listLiteral), | 168 return types.allocateList(containerType, astAdapter.getNode(listLiteral), |
168 outermostElement, elementType, length); | 169 outermostElement, elementType, length); |
169 }); | 170 }); |
170 } | 171 } |
171 } | 172 } |
OLD | NEW |