Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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 ssa; | 5 part of ssa; |
| 6 | 6 |
| 7 class SsaCodeGeneratorTask extends CompilerTask { | 7 class SsaCodeGeneratorTask extends CompilerTask { |
| 8 | 8 |
| 9 final JavaScriptBackend backend; | 9 final JavaScriptBackend backend; |
| 10 | 10 |
| (...skipping 1544 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1555 | 1555 |
| 1556 // If we don't know what we're calling or if we are calling a getter, | 1556 // If we don't know what we're calling or if we are calling a getter, |
| 1557 // we need to register that fact that we may be calling a closure | 1557 // we need to register that fact that we may be calling a closure |
| 1558 // with the same arguments. | 1558 // with the same arguments. |
| 1559 Element target = node.element; | 1559 Element target = node.element; |
| 1560 if (target == null || target.isGetter()) { | 1560 if (target == null || target.isGetter()) { |
| 1561 // TODO(kasperl): If we have a typed selector for the call, we | 1561 // TODO(kasperl): If we have a typed selector for the call, we |
| 1562 // may know something about the types of closures that need | 1562 // may know something about the types of closures that need |
| 1563 // the specific closure call method. | 1563 // the specific closure call method. |
| 1564 Selector call = new Selector.callClosureFrom(selector); | 1564 Selector call = new Selector.callClosureFrom(selector); |
| 1565 world.registerDynamicInvocation(call.name, call); | 1565 world.registerDynamicInvocation(call); |
| 1566 } | 1566 } |
| 1567 | 1567 |
| 1568 SourceString name = node.selector.name; | 1568 SourceString name = node.selector.name; |
|
ngeoffray
2013/06/25 12:21:00
Remove line above.
kasperl
2013/06/25 12:28:32
Done.
| |
| 1569 world.registerDynamicInvocation(name, selector); | 1569 world.registerDynamicInvocation(selector); |
| 1570 } | 1570 } |
| 1571 | 1571 |
| 1572 void registerSetter(HInvokeDynamic node) { | 1572 void registerSetter(HInvokeDynamic node) { |
| 1573 Selector selector = getOptimizedSelectorFor(node, node.selector); | 1573 Selector selector = getOptimizedSelectorFor(node, node.selector); |
| 1574 world.registerDynamicSetter(selector.name, selector); | 1574 world.registerDynamicSetter(selector); |
| 1575 HType valueType = node.isInterceptedCall | 1575 HType valueType = node.isInterceptedCall |
| 1576 ? node.inputs[2].instructionType | 1576 ? node.inputs[2].instructionType |
| 1577 : node.inputs[1].instructionType; | 1577 : node.inputs[1].instructionType; |
| 1578 } | 1578 } |
| 1579 | 1579 |
| 1580 void registerGetter(HInvokeDynamic node) { | 1580 void registerGetter(HInvokeDynamic node) { |
| 1581 Selector selector = getOptimizedSelectorFor(node, node.selector); | 1581 Selector selector = getOptimizedSelectorFor(node, node.selector); |
| 1582 world.registerDynamicGetter(selector.name, selector); | 1582 world.registerDynamicGetter(selector); |
| 1583 } | 1583 } |
| 1584 | 1584 |
| 1585 visitInvokeDynamicSetter(HInvokeDynamicSetter node) { | 1585 visitInvokeDynamicSetter(HInvokeDynamicSetter node) { |
| 1586 use(node.receiver); | 1586 use(node.receiver); |
| 1587 String name = backend.namer.invocationName(node.selector); | 1587 String name = backend.namer.invocationName(node.selector); |
| 1588 push(jsPropertyCall(pop(), name, visitArguments(node.inputs)), node); | 1588 push(jsPropertyCall(pop(), name, visitArguments(node.inputs)), node); |
| 1589 registerSetter(node); | 1589 registerSetter(node); |
| 1590 } | 1590 } |
| 1591 | 1591 |
| 1592 visitInvokeDynamicGetter(HInvokeDynamicGetter node) { | 1592 visitInvokeDynamicGetter(HInvokeDynamicGetter node) { |
| 1593 use(node.receiver); | 1593 use(node.receiver); |
| 1594 String name = backend.namer.invocationName(node.selector); | 1594 String name = backend.namer.invocationName(node.selector); |
| 1595 push(jsPropertyCall(pop(), name, visitArguments(node.inputs)), node); | 1595 push(jsPropertyCall(pop(), name, visitArguments(node.inputs)), node); |
| 1596 registerGetter(node); | 1596 registerGetter(node); |
| 1597 } | 1597 } |
| 1598 | 1598 |
| 1599 visitInvokeClosure(HInvokeClosure node) { | 1599 visitInvokeClosure(HInvokeClosure node) { |
| 1600 Selector call = new Selector.callClosureFrom(node.selector); | 1600 Selector call = new Selector.callClosureFrom(node.selector); |
| 1601 use(node.receiver); | 1601 use(node.receiver); |
| 1602 push(jsPropertyCall(pop(), | 1602 push(jsPropertyCall(pop(), |
| 1603 backend.namer.invocationName(call), | 1603 backend.namer.invocationName(call), |
| 1604 visitArguments(node.inputs)), | 1604 visitArguments(node.inputs)), |
| 1605 node); | 1605 node); |
| 1606 world.registerDynamicInvocation(call.name, call); | 1606 world.registerDynamicInvocation(call); |
| 1607 } | 1607 } |
| 1608 | 1608 |
| 1609 visitInvokeStatic(HInvokeStatic node) { | 1609 visitInvokeStatic(HInvokeStatic node) { |
| 1610 Element element = node.element; | 1610 Element element = node.element; |
| 1611 world.registerStaticUse(element); | 1611 world.registerStaticUse(element); |
| 1612 ClassElement cls = element.getEnclosingClass(); | 1612 ClassElement cls = element.getEnclosingClass(); |
| 1613 if (element.isGenerativeConstructor() | 1613 if (element.isGenerativeConstructor() |
| 1614 || (element.isFactoryConstructor() && cls == compiler.listClass)) { | 1614 || (element.isFactoryConstructor() && cls == compiler.listClass)) { |
| 1615 world.registerInstantiatedClass(cls, work.resolutionTree); | 1615 world.registerInstantiatedClass(cls, work.resolutionTree); |
| 1616 } | 1616 } |
| (...skipping 1352 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2969 if (leftType.canBeNull() && rightType.canBeNull()) { | 2969 if (leftType.canBeNull() && rightType.canBeNull()) { |
| 2970 if (left.isConstantNull() || right.isConstantNull() || | 2970 if (left.isConstantNull() || right.isConstantNull() || |
| 2971 (leftType.isPrimitive(compiler) && leftType == rightType)) { | 2971 (leftType.isPrimitive(compiler) && leftType == rightType)) { |
| 2972 return '=='; | 2972 return '=='; |
| 2973 } | 2973 } |
| 2974 return null; | 2974 return null; |
| 2975 } else { | 2975 } else { |
| 2976 return '==='; | 2976 return '==='; |
| 2977 } | 2977 } |
| 2978 } | 2978 } |
| OLD | NEW |