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

Unified Diff: sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart

Issue 11415168: Revert "Emit constants using ASTs" (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 1 month 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: sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart
diff --git a/sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart b/sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart
index f7d7de8f41daecb45ac1e3dcc5ab55cc36dc92c3..ba5a9d942b1601a124e8965b402ca29ff86d88c6 100644
--- a/sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart
+++ b/sdk/lib/_internal/compiler/implementation/js_backend/emitter.dart
@@ -81,17 +81,13 @@ class CodeEmitterTask extends CompilerTask {
});
}
- js.Expression constantReference(Constant value) {
- return constantEmitter.reference(value);
- }
-
- js.Expression constantInitializerExpression(Constant value) {
- return constantEmitter.initializationExpression(value);
- }
-
- // Deprecated. Remove after last use is converted to JS ASTs.
- void writeConstantToBuffer(Constant value, CodeBuffer buffer) {
- buffer.add(js.prettyPrint(constantReference(value), compiler));
+ void writeConstantToBuffer(Constant value, CodeBuffer buffer,
+ {emitCanonicalVersion: true}) {
+ if (emitCanonicalVersion) {
+ constantEmitter.emitCanonicalVersionOfConstant(value, buffer);
+ } else {
+ constantEmitter.emitJavaScriptCodeForConstant(value, buffer);
+ }
}
String get name => 'CodeEmitter';
@@ -1323,17 +1319,12 @@ $classesCollector.$mangledName = {'':
List<VariableElement> staticNonFinalFields =
handler.getStaticNonFinalFieldsForEmission();
for (Element element in staticNonFinalFields) {
+ buffer.add('$isolateProperties.${namer.getName(element)} = ');
compiler.withCurrentElement(element, () {
- Constant initialValue = handler.getInitialValueFor(element);
- js.Expression init =
- new js.Assignment(
- new js.PropertyAccess.field(
- new js.VariableUse(isolateProperties),
- namer.getName(element)),
- constantEmitter.referenceInInitializationContext(initialValue));
- buffer.add(js.prettyPrint(init, compiler));
- buffer.add(';\n');
- });
+ Constant initialValue = handler.getInitialValueFor(element);
+ writeConstantToBuffer(initialValue, buffer);
+ });
+ buffer.add(';\n');
}
}
@@ -1391,13 +1382,8 @@ $classesCollector.$mangledName = {'':
addedMakeConstantList = true;
emitMakeConstantList(buffer);
}
- js.Expression init =
- new js.Assignment(
- new js.PropertyAccess.field(
- new js.VariableUse(isolateProperties),
- name),
- constantInitializerExpression(constant));
- buffer.add(js.prettyPrint(init, compiler));
+ buffer.add('$isolateProperties.$name = ');
+ writeConstantToBuffer(constant, buffer, emitCanonicalVersion: false);
buffer.add(';\n');
}
}

Powered by Google App Engine
This is Rietveld 408576698