OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 part of dart2js.js_emitter; | 5 part of dart2js.js_emitter; |
6 | 6 |
7 /// This class should morph into something that makes it easy to build | 7 /// This class should morph into something that makes it easy to build |
8 /// JavaScript representations of libraries, class-sides, and instance-sides. | 8 /// JavaScript representations of libraries, class-sides, and instance-sides. |
9 /// Initially, it is just a placeholder for code that is moved from | 9 /// Initially, it is just a placeholder for code that is moved from |
10 /// [CodeEmitterTask]. | 10 /// [CodeEmitterTask]. |
(...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
123 tearOffInfo.add(new jsAst.LiteralString(callSelectorString)); | 123 tearOffInfo.add(new jsAst.LiteralString(callSelectorString)); |
124 } | 124 } |
125 | 125 |
126 expressions | 126 expressions |
127 ..addAll(tearOffInfo) | 127 ..addAll(tearOffInfo) |
128 ..add((tearOffName == null || member.isAccessor) | 128 ..add((tearOffName == null || member.isAccessor) |
129 ? js("null") : js.string(tearOffName)) | 129 ? js("null") : js.string(tearOffName)) |
130 ..add(js.number(requiredParameterCount)) | 130 ..add(js.number(requiredParameterCount)) |
131 ..add(js.number(optionalParameterCount)) | 131 ..add(js.number(optionalParameterCount)) |
132 ..add(memberTypeExpression == null ? js("null") : memberTypeExpression) | 132 ..add(memberTypeExpression == null ? js("null") : memberTypeExpression) |
133 ..addAll(task.metadataCollector | 133 ..addAll(task.metadataCollector.reifyDefaultArguments(member)); |
134 .reifyDefaultArguments(member).map(js.number)); | |
135 | 134 |
136 if (canBeReflected || canBeApplied) { | 135 if (canBeReflected || canBeApplied) { |
137 parameters.forEachParameter((Element parameter) { | 136 parameters.forEachParameter((Element parameter) { |
138 expressions.add( | 137 expressions.add(task.metadataCollector.reifyName(parameter.name)); |
139 js.number(task.metadataCollector.reifyName(parameter.name))); | |
140 if (backend.mustRetainMetadata) { | 138 if (backend.mustRetainMetadata) { |
141 Iterable<int> metadataIndices = | 139 Iterable<jsAst.Expression> metadataIndices = |
142 parameter.metadata.map((MetadataAnnotation annotation) { | 140 parameter.metadata.map((MetadataAnnotation annotation) { |
143 ConstantValue constant = | 141 ConstantValue constant = |
144 backend.constants.getConstantValueForMetadata(annotation); | 142 backend.constants.getConstantValueForMetadata(annotation); |
145 backend.constants.addCompileTimeConstantForEmission(constant); | 143 backend.constants.addCompileTimeConstantForEmission(constant); |
146 return task.metadataCollector.reifyMetadata(annotation); | 144 return task.metadataCollector.reifyMetadata(annotation); |
147 }); | 145 }); |
148 expressions.add(new jsAst.ArrayInitializer( | 146 expressions.add(new jsAst.ArrayInitializer(metadataIndices.toList())); |
149 metadataIndices.map(js.number).toList())); | |
150 } | 147 } |
151 }); | 148 }); |
152 } | 149 } |
153 if (canBeReflected) { | 150 if (canBeReflected) { |
154 jsAst.LiteralString reflectionName; | 151 jsAst.LiteralString reflectionName; |
155 if (member.isConstructor) { | 152 if (member.isConstructor) { |
156 String reflectionNameString = emitter.getReflectionName(member, name); | 153 String reflectionNameString = emitter.getReflectionName(member, name); |
157 reflectionName = | 154 reflectionName = |
158 new jsAst.LiteralString( | 155 new jsAst.LiteralString( |
159 '"new ${Elements.reconstructConstructorName(member)}"'); | 156 '"new ${Elements.reconstructConstructorName(member)}"'); |
160 } else { | 157 } else { |
161 reflectionName = | 158 reflectionName = |
162 js.string(namer.privateName(member.memberName)); | 159 js.string(namer.privateName(member.memberName)); |
163 } | 160 } |
164 expressions | 161 expressions |
165 ..add(reflectionName) | 162 ..add(reflectionName) |
166 ..addAll(task.metadataCollector | 163 ..addAll(task.metadataCollector.computeMetadata(member)); |
167 .computeMetadata(member).map(js.number)); | |
168 } else if (isClosure && canBeApplied) { | 164 } else if (isClosure && canBeApplied) { |
169 expressions.add(js.string(namer.privateName(member.memberName))); | 165 expressions.add(js.string(namer.privateName(member.memberName))); |
170 } | 166 } |
171 | 167 |
172 jsAst.ArrayInitializer arrayInit = | 168 jsAst.ArrayInitializer arrayInit = |
173 new jsAst.ArrayInitializer(expressions.toList()); | 169 new jsAst.ArrayInitializer(expressions.toList()); |
174 compiler.dumpInfoTask.registerElementAst(member, | 170 compiler.dumpInfoTask.registerElementAst(member, |
175 builder.addProperty(name, arrayInit)); | 171 builder.addProperty(name, arrayInit)); |
176 } | 172 } |
177 | 173 |
178 void addMemberField(Field field, ClassBuilder builder) { | 174 void addMemberField(Field field, ClassBuilder builder) { |
179 // For now, do nothing. | 175 // For now, do nothing. |
180 } | 176 } |
181 } | 177 } |
OLD | NEW |