Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(483)

Unified Diff: tests/compiler/dart2js/closure/closure_test.dart

Issue 2998113002: Reduce use of getClosureInfoForMember and cleanup closure_test (Closed)
Patch Set: Created 3 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tests/compiler/dart2js/closure/closure_test.dart
diff --git a/tests/compiler/dart2js/closure/closure_test.dart b/tests/compiler/dart2js/closure/closure_test.dart
index 79760ef505c754822e976934c5891bf086d61a38..76a404f952af38fe3cf7addd30e8880fb690ee6b 100644
--- a/tests/compiler/dart2js/closure/closure_test.dart
+++ b/tests/compiler/dart2js/closure/closure_test.dart
@@ -107,7 +107,7 @@ class ClosureAstComputer extends AstDataExtractor with ComputeValueMixin {
String computeNodeValue(ast.Node node, [AstElement element]) {
if (element != null && element.isLocal) {
if (element.isFunction) {
- return computeEntityValue(element);
+ return computeObjectValue(element);
} else {
LocalElement local = element;
return computeLocalValue(local);
@@ -121,7 +121,7 @@ class ClosureAstComputer extends AstDataExtractor with ComputeValueMixin {
String computeElementValue(AstElement element) {
// TODO(johnniwinther,efortuna): Collect data for the member
// (has thisLocal, has box, etc.).
- return computeEntityValue(element);
+ return computeObjectValue(element);
}
}
@@ -158,18 +158,20 @@ class ClosureIrChecker extends IrDataExtractor with ComputeValueMixin<ir.Node> {
@override
String computeNodeValue(ir.Node node) {
if (node is ir.VariableDeclaration) {
+ if (node.parent is ir.FunctionDeclaration) {
+ return computeObjectValue(node.parent);
+ }
Local local = _localsMap.getLocalVariable(node);
return computeLocalValue(local);
+ } else if (node is ir.FunctionExpression) {
+ return computeObjectValue(node);
}
- // TODO(johnniwinther,efortuna): Collect data for other nodes?
return null;
}
@override
String computeMemberValue(ir.Member node) {
- // TODO(johnniwinther,efortuna): Collect data for the member
- // (has thisLocal, has box, etc.).
- return computeEntityValue(member);
+ return computeObjectValue(member);
}
}
@@ -182,25 +184,24 @@ abstract class ComputeValueMixin<T> {
Link<ClosureRepresentationInfo> closureRepresentationInfoStack =
const Link<ClosureRepresentationInfo>();
ClosureRepresentationInfo get closureRepresentationInfo =>
- closureRepresentationInfoStack.head;
+ closureRepresentationInfoStack.isNotEmpty
+ ? closureRepresentationInfoStack.head
+ : null;
void pushMember(MemberEntity member) {
scopeInfoStack =
scopeInfoStack.prepend(closureDataLookup.getScopeInfo(member));
capturedScope = closureDataLookup.getCapturedScope(member);
- closureRepresentationInfoStack = closureRepresentationInfoStack
- .prepend(closureDataLookup.getClosureInfoForMemberTesting(member));
dump(member);
}
void popMember() {
scopeInfoStack = scopeInfoStack.tail;
- closureRepresentationInfoStack = closureRepresentationInfoStack.tail;
}
void pushLocalFunction(T node) {
closureRepresentationInfoStack = closureRepresentationInfoStack
- .prepend(closureDataLookup.getClosureInfoForTesting(node));
+ .prepend(closureDataLookup.getClosureInfo(node));
dump(node);
}
@@ -265,7 +266,7 @@ abstract class ComputeValueMixin<T> {
return (features.toList()..sort()).join(',');
}
- String computeEntityValue(Entity entity) {
+ String computeObjectValue(Object object) {
Map<String, String> features = <String, String>{};
void addLocals(String name, forEach(f(Local local, _))) {
@@ -280,17 +281,17 @@ abstract class ComputeValueMixin<T> {
String value = names.isEmpty ? null : '[${(names..sort()).join(',')}]';
if (features.containsKey(name)) {
Expect.equals(
- features[name], value, "Inconsistent values for $name on $entity.");
+ features[name], value, "Inconsistent values for $name on $object.");
}
features[name] = value;
}
- if (scopeInfo.thisLocal != null) {
- features['hasThis'] = '';
- }
- addLocals('boxed', scopeInfo.forEachBoxedVariable);
+ if (object is MemberEntity) {
+ if (scopeInfo.thisLocal != null) {
+ features['hasThis'] = '';
+ }
+ addLocals('boxed', scopeInfo.forEachBoxedVariable);
- if (entity is MemberEntity) {
if (capturedScope.requiresContextBox) {
features['requiresBox'] = '';
}

Powered by Google App Engine
This is Rietveld 408576698