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 2594 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2605 if (inputLength > maxBailoutParameters) { | 2605 if (inputLength > maxBailoutParameters) { |
2606 maxBailoutParameters = inputLength; | 2606 maxBailoutParameters = inputLength; |
2607 } | 2607 } |
2608 }); | 2608 }); |
2609 } | 2609 } |
2610 HInstruction input = guard.guarded; | 2610 HInstruction input = guard.guarded; |
2611 HBailoutTarget target = guard.bailoutTarget; | 2611 HBailoutTarget target = guard.bailoutTarget; |
2612 Namer namer = backend.namer; | 2612 Namer namer = backend.namer; |
2613 Element element = work.element; | 2613 Element element = work.element; |
2614 List<js.Expression> arguments = <js.Expression>[]; | 2614 List<js.Expression> arguments = <js.Expression>[]; |
| 2615 if (element.isInstanceMember()) { |
| 2616 arguments.add(new js.This()); |
| 2617 } |
2615 arguments.add(new js.LiteralNumber("${guard.state}")); | 2618 arguments.add(new js.LiteralNumber("${guard.state}")); |
2616 // TODO(ngeoffray): try to put a variable at a deterministic | 2619 // TODO(ngeoffray): try to put a variable at a deterministic |
2617 // location, so that multiple bailout calls put the variable at | 2620 // location, so that multiple bailout calls put the variable at |
2618 // the same parameter index. | 2621 // the same parameter index. |
2619 int i = 0; | 2622 int i = 0; |
2620 for (; i < target.inputs.length; i++) { | 2623 for (; i < target.inputs.length; i++) { |
2621 assert(guard.inputs.indexOf(target.inputs[i]) >= 0); | 2624 assert(guard.inputs.indexOf(target.inputs[i]) >= 0); |
2622 use(target.inputs[i]); | 2625 use(target.inputs[i]); |
2623 arguments.add(pop()); | 2626 arguments.add(pop()); |
2624 } | 2627 } |
2625 | 2628 |
2626 js.Expression bailoutTarget; | 2629 js.Call call; |
2627 if (element.isInstanceMember()) { | 2630 if (element.isInstanceMember()) { |
2628 // TODO(ngeoffray): This does not work in case we come from a | 2631 String className = |
2629 // super call. We must make bailout names unique. | 2632 backend.namer.isolateAccess(element.getEnclosingClass()); |
| 2633 js.VariableUse classReference = new js.VariableUse(className); |
| 2634 js.PropertyAccess prototype = |
| 2635 new js.PropertyAccess.field(classReference, "prototype"); |
2630 String bailoutName = namer.getBailoutName(element); | 2636 String bailoutName = namer.getBailoutName(element); |
2631 bailoutTarget = new js.PropertyAccess.field(new js.This(), bailoutName); | 2637 js.PropertyAccess method = |
| 2638 new js.PropertyAccess.field(prototype, bailoutName); |
| 2639 call = jsPropertyCall(method, "call", arguments); |
2632 } else { | 2640 } else { |
2633 assert(!element.isField()); | 2641 assert(!element.isField()); |
2634 bailoutTarget = new js.VariableUse(namer.isolateBailoutAccess(element)); | 2642 js.Expression bailoutTarget |
| 2643 = new js.VariableUse(namer.isolateBailoutAccess(element)); |
| 2644 call = new js.Call(bailoutTarget, arguments); |
2635 } | 2645 } |
2636 js.Call call = new js.Call(bailoutTarget, arguments); | |
2637 attachLocation(call, guard); | 2646 attachLocation(call, guard); |
2638 return new js.Return(call); | 2647 return new js.Return(call); |
2639 } | 2648 } |
2640 | 2649 |
2641 void visitTypeGuard(HTypeGuard node) { | 2650 void visitTypeGuard(HTypeGuard node) { |
2642 HInstruction input = node.guarded; | 2651 HInstruction input = node.guarded; |
2643 DartType indexingBehavior = | 2652 DartType indexingBehavior = |
2644 backend.jsIndexingBehaviorInterface.computeType(compiler); | 2653 backend.jsIndexingBehaviorInterface.computeType(compiler); |
2645 if (node.isInteger(types)) { | 2654 if (node.isInteger(types)) { |
2646 // if (input is !int) bailout | 2655 // if (input is !int) bailout |
(...skipping 457 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3104 if (leftType.canBeNull() && rightType.canBeNull()) { | 3113 if (leftType.canBeNull() && rightType.canBeNull()) { |
3105 if (left.isConstantNull() || right.isConstantNull() || | 3114 if (left.isConstantNull() || right.isConstantNull() || |
3106 (leftType.isPrimitive() && leftType == rightType)) { | 3115 (leftType.isPrimitive() && leftType == rightType)) { |
3107 return '=='; | 3116 return '=='; |
3108 } | 3117 } |
3109 return null; | 3118 return null; |
3110 } else { | 3119 } else { |
3111 return '==='; | 3120 return '==='; |
3112 } | 3121 } |
3113 } | 3122 } |
OLD | NEW |