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 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
110 | 110 |
111 var body; // List or jsAst.Statement. | 111 var body; // List or jsAst.Statement. |
112 if (member.hasFixedBackendName) { | 112 if (member.hasFixedBackendName) { |
113 body = emitter.nativeEmitter.generateParameterStubStatements( | 113 body = emitter.nativeEmitter.generateParameterStubStatements( |
114 member, isInterceptedMethod, invocationName, | 114 member, isInterceptedMethod, invocationName, |
115 parametersBuffer, argumentsBuffer, | 115 parametersBuffer, argumentsBuffer, |
116 indexOfLastOptionalArgumentInParameters); | 116 indexOfLastOptionalArgumentInParameters); |
117 } else if (member.isInstanceMember) { | 117 } else if (member.isInstanceMember) { |
118 if (needsSuperGetter(member)) { | 118 if (needsSuperGetter(member)) { |
119 ClassElement superClass = member.enclosingClass; | 119 ClassElement superClass = member.enclosingClass; |
120 String methodName = namer.getNameOfInstanceMember(member); | 120 String methodName = namer.instanceMethodName(member); |
121 // When redirecting, we must ensure that we don't end up in a subclass. | 121 // When redirecting, we must ensure that we don't end up in a subclass. |
122 // We thus can't just invoke `this.foo$1.call(filledInArguments)`. | 122 // We thus can't just invoke `this.foo$1.call(filledInArguments)`. |
123 // Instead we need to call the statically resolved target. | 123 // Instead we need to call the statically resolved target. |
124 // `<class>.prototype.bar$1.call(this, argument0, ...)`. | 124 // `<class>.prototype.bar$1.call(this, argument0, ...)`. |
125 body = js.statement( | 125 body = js.statement( |
126 'return #.#.call(this, #);', | 126 'return #.#.call(this, #);', |
127 [backend.emitter.prototypeAccess(superClass, | 127 [backend.emitter.prototypeAccess(superClass, |
128 hasBeenInstantiated: true), | 128 hasBeenInstantiated: true), |
129 methodName, | 129 methodName, |
130 argumentsBuffer]); | 130 argumentsBuffer]); |
131 } else { | 131 } else { |
132 body = js.statement( | 132 body = js.statement( |
133 'return this.#(#);', | 133 'return this.#(#);', |
134 [namer.getNameOfInstanceMember(member), argumentsBuffer]); | 134 [namer.instanceMethodName(member), argumentsBuffer]); |
135 } | 135 } |
136 } else { | 136 } else { |
137 body = js.statement('return #(#)', | 137 body = js.statement('return #(#)', |
138 [emitter.staticFunctionAccess(member), argumentsBuffer]); | 138 [emitter.staticFunctionAccess(member), argumentsBuffer]); |
139 } | 139 } |
140 | 140 |
141 jsAst.Fun function = js('function(#) { #; }', [parametersBuffer, body]); | 141 jsAst.Fun function = js('function(#) { #; }', [parametersBuffer, body]); |
142 | 142 |
143 addStub(selector, function); | 143 addStub(selector, function); |
144 } | 144 } |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
260 MemberInfo info = analyzeMemberMethod(member); | 260 MemberInfo info = analyzeMemberMethod(member); |
261 if (info != null) { | 261 if (info != null) { |
262 addMemberMethodFromInfo(info, builder); | 262 addMemberMethodFromInfo(info, builder); |
263 } | 263 } |
264 } | 264 } |
265 | 265 |
266 MemberInfo analyzeMemberMethod(FunctionElement member) { | 266 MemberInfo analyzeMemberMethod(FunctionElement member) { |
267 if (member.isAbstract) return null; | 267 if (member.isAbstract) return null; |
268 jsAst.Expression code = backend.generatedCode[member]; | 268 jsAst.Expression code = backend.generatedCode[member]; |
269 if (code == null) return null; | 269 if (code == null) return null; |
270 String name = namer.getNameOfMember(member); | 270 String name = namer.getNameOfMethod(member); |
271 | 271 |
272 FunctionSignature parameters = member.functionSignature; | 272 FunctionSignature parameters = member.functionSignature; |
273 bool needsStubs = !parameters.optionalParameters.isEmpty; | 273 bool needsStubs = !parameters.optionalParameters.isEmpty; |
274 bool canTearOff = false; | 274 bool canTearOff = false; |
275 bool isClosure = false; | 275 bool isClosure = false; |
276 bool isNotApplyTarget = !member.isFunction || | 276 bool isNotApplyTarget = !member.isFunction || |
277 member.isConstructor || | 277 member.isConstructor || |
278 member.isAccessor; | 278 member.isAccessor; |
279 String tearOffName; | 279 String tearOffName; |
280 | 280 |
281 | 281 |
282 final bool canBeReflected = backend.isAccessibleByReflection(member) || | 282 final bool canBeReflected = backend.isAccessibleByReflection(member) || |
283 // During incremental compilation, we have to assume that reflection | 283 // During incremental compilation, we have to assume that reflection |
284 // *might* get enabled. | 284 // *might* get enabled. |
285 compiler.hasIncrementalSupport; | 285 compiler.hasIncrementalSupport; |
286 | 286 |
287 if (isNotApplyTarget) { | 287 if (isNotApplyTarget) { |
288 canTearOff = false; | 288 canTearOff = false; |
289 } else if (member.isInstanceMember) { | 289 } else if (member.isInstanceMember) { |
290 if (member.enclosingClass.isClosure) { | 290 if (member.enclosingClass.isClosure) { |
291 canTearOff = false; | 291 canTearOff = false; |
292 isClosure = true; | 292 isClosure = true; |
293 } else { | 293 } else { |
294 // Careful with operators. | 294 // Careful with operators. |
295 canTearOff = | 295 canTearOff = |
296 compiler.codegenWorld.hasInvokedGetter(member, compiler.world) || | 296 compiler.codegenWorld.hasInvokedGetter(member, compiler.world) || |
297 (canBeReflected && !member.isOperator); | 297 (canBeReflected && !member.isOperator); |
298 assert(!needsSuperGetter(member) || canTearOff); | 298 assert(!needsSuperGetter(member) || canTearOff); |
299 tearOffName = namer.getterName(member); | 299 tearOffName = namer.getterForElement(member); |
300 } | 300 } |
301 } else { | 301 } else { |
302 canTearOff = | 302 canTearOff = |
303 compiler.codegenWorld.staticFunctionsNeedingGetter.contains(member) || | 303 compiler.codegenWorld.staticFunctionsNeedingGetter.contains(member) || |
304 canBeReflected; | 304 canBeReflected; |
305 tearOffName = namer.getStaticClosureName(member); | 305 tearOffName = namer.getStaticClosureName(member); |
306 } | 306 } |
307 final bool canBeApplied = compiler.enabledFunctionApply && | 307 final bool canBeApplied = compiler.enabledFunctionApply && |
308 compiler.world.getMightBePassedToApply(member); | 308 compiler.world.getMightBePassedToApply(member); |
309 | 309 |
(...skipping 271 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
581 assert(needsStubs != null); | 581 assert(needsStubs != null); |
582 assert(canTearOff != null); | 582 assert(canTearOff != null); |
583 assert(isClosure != null); | 583 assert(isClosure != null); |
584 assert(tearOffName != null || !canTearOff); | 584 assert(tearOffName != null || !canTearOff); |
585 assert(canBeReflected != null); | 585 assert(canBeReflected != null); |
586 assert(canBeApplied != null); | 586 assert(canBeApplied != null); |
587 assert(hasSuperAlias != null); | 587 assert(hasSuperAlias != null); |
588 assert(needStructuredInfo != null); | 588 assert(needStructuredInfo != null); |
589 } | 589 } |
590 } | 590 } |
OLD | NEW |