| 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 // Test that branch fusion correctly sets branch environment for comparisons | 5 // Test that branch fusion correctly sets branch environment for comparisons |
| 6 // that require unboxing and does not fuse branches that can deoptimize. | 6 // that require unboxing and does not fuse branches that can deoptimize. |
| 7 | 7 |
| 8 import "package:expect/expect.dart"; |
| 9 |
| 8 var sideEffect = true; | 10 var sideEffect = true; |
| 9 | 11 |
| 10 barDouble(a, b) { | 12 barDouble(a, b) { |
| 11 sideEffect = false; | 13 sideEffect = false; |
| 12 final result = (a == b); | 14 final result = (a == b); |
| 13 sideEffect = !sideEffect; | 15 sideEffect = !sideEffect; |
| 14 return result; | 16 return result; |
| 15 } | 17 } |
| 16 fooDouble(a, b) => barDouble(a, b) ? 1 : 0; | 18 fooDouble(a, b) => barDouble(a, b) ? 1 : 0; |
| 17 | 19 |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 54 Expect.equals(1, fooPoly(x, x)); | 56 Expect.equals(1, fooPoly(x, x)); |
| 55 Expect.equals(0, fooPoly(y, x)); | 57 Expect.equals(0, fooPoly(y, x)); |
| 56 } | 58 } |
| 57 Expect.equals(1, fooDouble(z, z)); | 59 Expect.equals(1, fooDouble(z, z)); |
| 58 Expect.isTrue(sideEffect); | 60 Expect.isTrue(sideEffect); |
| 59 Expect.equals(1, fooMint(z, z)); | 61 Expect.equals(1, fooMint(z, z)); |
| 60 Expect.isTrue(sideEffect); | 62 Expect.isTrue(sideEffect); |
| 61 Expect.equals(1, fooPoly(z, z)); | 63 Expect.equals(1, fooPoly(z, z)); |
| 62 Expect.isTrue(sideEffect); | 64 Expect.isTrue(sideEffect); |
| 63 } | 65 } |
| OLD | NEW |