| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/compiler/js-graph.h" | 5 #include "src/compiler/js-graph.h" |
| 6 #include "src/compiler/js-typed-lowering.h" | 6 #include "src/compiler/js-typed-lowering.h" |
| 7 #include "src/compiler/machine-operator.h" | 7 #include "src/compiler/machine-operator.h" |
| 8 #include "src/compiler/node-properties.h" | 8 #include "src/compiler/node-properties.h" |
| 9 #include "src/compiler/opcodes.h" | 9 #include "src/compiler/opcodes.h" |
| 10 #include "src/compiler/operator-properties.h" | 10 #include "src/compiler/operator-properties.h" |
| (...skipping 672 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 683 Type::Union(Type::Number(), Type::String(), R.main_zone())}; | 683 Type::Union(Type::Number(), Type::String(), R.main_zone())}; |
| 684 | 684 |
| 685 for (size_t i = 0; i < arraysize(types); i++) { | 685 for (size_t i = 0; i < arraysize(types); i++) { |
| 686 Node* p0 = R.Parameter(types[i], 0); | 686 Node* p0 = R.Parameter(types[i], 0); |
| 687 | 687 |
| 688 for (size_t j = 0; j < arraysize(types); j++) { | 688 for (size_t j = 0; j < arraysize(types); j++) { |
| 689 Node* p1 = R.Parameter(types[j], 1); | 689 Node* p1 = R.Parameter(types[j], 1); |
| 690 { | 690 { |
| 691 Node* cmp = R.Binop(R.javascript.LessThan(language_mode), p0, p1); | 691 Node* cmp = R.Binop(R.javascript.LessThan(language_mode), p0, p1); |
| 692 Node* r = R.reduce(cmp); | 692 Node* r = R.reduce(cmp); |
| 693 | 693 if (types[i]->Is(Type::String()) && types[j]->Is(Type::String())) { |
| 694 if (!types[i]->Maybe(Type::String()) || | 694 R.CheckPureBinop(R.simplified.StringLessThan(), r); |
| 695 !types[j]->Maybe(Type::String())) { | 695 } else if ((types[i]->Is(Type::Number()) && |
| 696 if (types[i]->Is(Type::String()) && types[j]->Is(Type::String())) { | 696 types[j]->Is(Type::Number())) || |
| 697 R.CheckPureBinop(R.simplified.StringLessThan(), r); | 697 (!is_strong(language_mode) && |
| 698 } else { | 698 (!types[i]->Maybe(Type::String()) || |
| 699 R.CheckPureBinop(R.simplified.NumberLessThan(), r); | 699 !types[j]->Maybe(Type::String())))) { |
| 700 } | 700 R.CheckPureBinop(R.simplified.NumberLessThan(), r); |
| 701 } else { | 701 } else { |
| 702 CHECK_EQ(cmp, r); // No reduction of mixed types. | 702 CHECK_EQ(cmp, r); // No reduction of mixed types. |
| 703 } | 703 } |
| 704 } | 704 } |
| 705 } | 705 } |
| 706 } | 706 } |
| 707 } | 707 } |
| 708 | 708 |
| 709 | 709 |
| 710 TEST_WITH_STRONG(RemoveToNumberEffects) { | 710 TEST_WITH_STRONG(RemoveToNumberEffects) { |
| (...skipping 559 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1270 CHECK_EQ(p1, r->InputAt(0)); | 1270 CHECK_EQ(p1, r->InputAt(0)); |
| 1271 CHECK_EQ(p0, r->InputAt(1)); | 1271 CHECK_EQ(p0, r->InputAt(1)); |
| 1272 } else { | 1272 } else { |
| 1273 CHECK_EQ(p0, r->InputAt(0)); | 1273 CHECK_EQ(p0, r->InputAt(0)); |
| 1274 CHECK_EQ(p1, r->InputAt(1)); | 1274 CHECK_EQ(p1, r->InputAt(1)); |
| 1275 } | 1275 } |
| 1276 } | 1276 } |
| 1277 } | 1277 } |
| 1278 } | 1278 } |
| 1279 } | 1279 } |
| OLD | NEW |