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/v8.h" | 5 #include "src/v8.h" |
6 #include "test/cctest/cctest.h" | 6 #include "test/cctest/cctest.h" |
7 | 7 |
8 #include "src/compiler/graph-inl.h" | 8 #include "src/compiler/graph-inl.h" |
9 #include "src/compiler/js-typed-lowering.h" | 9 #include "src/compiler/js-typed-lowering.h" |
10 #include "src/compiler/node-properties-inl.h" | 10 #include "src/compiler/node-properties-inl.h" |
(...skipping 455 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
466 { // ToBoolean(null) | 466 { // ToBoolean(null) |
467 Node* r = R.ReduceUnop(op, Type::Null()); | 467 Node* r = R.ReduceUnop(op, Type::Null()); |
468 R.CheckFalse(r); | 468 R.CheckFalse(r); |
469 } | 469 } |
470 | 470 |
471 { // ToBoolean(boolean) | 471 { // ToBoolean(boolean) |
472 Node* r = R.ReduceUnop(op, Type::Boolean()); | 472 Node* r = R.ReduceUnop(op, Type::Boolean()); |
473 CHECK_EQ(IrOpcode::kParameter, r->opcode()); | 473 CHECK_EQ(IrOpcode::kParameter, r->opcode()); |
474 } | 474 } |
475 | 475 |
476 { // ToBoolean(number) | 476 { // ToBoolean(ordered-number) |
477 Node* r = R.ReduceUnop(op, Type::Number()); | 477 Node* r = R.ReduceUnop(op, Type::OrderedNumber()); |
478 CHECK_EQ(IrOpcode::kBooleanNot, r->opcode()); | 478 CHECK_EQ(IrOpcode::kBooleanNot, r->opcode()); |
479 Node* i = r->InputAt(0); | 479 Node* i = r->InputAt(0); |
480 CHECK_EQ(IrOpcode::kNumberEqual, i->opcode()); | 480 CHECK_EQ(IrOpcode::kNumberEqual, i->opcode()); |
481 // ToBoolean(number) => BooleanNot(NumberEqual(x, #0)) | 481 // ToBoolean(number) => BooleanNot(NumberEqual(x, #0)) |
482 } | 482 } |
483 | 483 |
484 { // ToBoolean(string) | 484 { // ToBoolean(string) |
485 Node* r = R.ReduceUnop(op, Type::String()); | 485 Node* r = R.ReduceUnop(op, Type::String()); |
486 // TODO(titzer): test will break with better js-typed-lowering | 486 // TODO(titzer): test will break with better js-typed-lowering |
487 CHECK_EQ(IrOpcode::kJSToBoolean, r->opcode()); | 487 CHECK_EQ(IrOpcode::kJSToBoolean, r->opcode()); |
(...skipping 13 matching lines...) Expand all Loading... |
501 Node* r = R.ReduceUnop(op, Type::Object()); | 501 Node* r = R.ReduceUnop(op, Type::Object()); |
502 CHECK_EQ(IrOpcode::kJSToBoolean, r->opcode()); | 502 CHECK_EQ(IrOpcode::kJSToBoolean, r->opcode()); |
503 } | 503 } |
504 } | 504 } |
505 | 505 |
506 | 506 |
507 TEST(JSToBoolean_replacement) { | 507 TEST(JSToBoolean_replacement) { |
508 JSTypedLoweringTester R; | 508 JSTypedLoweringTester R; |
509 | 509 |
510 Type* types[] = {Type::Null(), Type::Undefined(), | 510 Type* types[] = {Type::Null(), Type::Undefined(), |
511 Type::Boolean(), Type::Number(), | 511 Type::Boolean(), Type::OrderedNumber(), |
512 Type::DetectableObject(), Type::Undetectable()}; | 512 Type::DetectableObject(), Type::Undetectable()}; |
513 | 513 |
514 for (size_t i = 0; i < arraysize(types); i++) { | 514 for (size_t i = 0; i < arraysize(types); i++) { |
515 Node* n = R.Parameter(types[i]); | 515 Node* n = R.Parameter(types[i]); |
516 Node* c = R.graph.NewNode(R.javascript.ToBoolean(), n, R.context(), | 516 Node* c = R.graph.NewNode(R.javascript.ToBoolean(), n, R.context(), |
517 R.start(), R.start()); | 517 R.start(), R.start()); |
518 Node* effect_use = R.UseForEffect(c); | 518 Node* effect_use = R.UseForEffect(c); |
519 Node* add = R.graph.NewNode(R.simplified.ReferenceEqual(Type::Any()), n, c); | 519 Node* add = R.graph.NewNode(R.simplified.ReferenceEqual(Type::Any()), n, c); |
520 | 520 |
521 R.CheckEffectInput(c, effect_use); | 521 R.CheckEffectInput(c, effect_use); |
522 Node* r = R.reduce(c); | 522 Node* r = R.reduce(c); |
523 | 523 |
524 if (types[i]->Is(Type::Boolean())) { | 524 if (types[i]->Is(Type::Boolean())) { |
525 CHECK_EQ(n, r); | 525 CHECK_EQ(n, r); |
526 } else if (types[i]->Is(Type::Number())) { | 526 } else if (types[i]->Is(Type::OrderedNumber())) { |
527 CHECK_EQ(IrOpcode::kBooleanNot, r->opcode()); | 527 CHECK_EQ(IrOpcode::kBooleanNot, r->opcode()); |
528 } else { | 528 } else { |
529 CHECK_EQ(IrOpcode::kHeapConstant, r->opcode()); | 529 CHECK_EQ(IrOpcode::kHeapConstant, r->opcode()); |
530 } | 530 } |
531 | 531 |
532 CHECK_EQ(n, add->InputAt(0)); | 532 CHECK_EQ(n, add->InputAt(0)); |
533 CHECK_EQ(r, add->InputAt(1)); | 533 CHECK_EQ(r, add->InputAt(1)); |
534 R.CheckEffectInput(R.start(), effect_use); | 534 R.CheckEffectInput(R.start(), effect_use); |
535 } | 535 } |
536 } | 536 } |
(...skipping 807 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1344 CHECK_EQ(p1, r->InputAt(0)); | 1344 CHECK_EQ(p1, r->InputAt(0)); |
1345 CHECK_EQ(p0, r->InputAt(1)); | 1345 CHECK_EQ(p0, r->InputAt(1)); |
1346 } else { | 1346 } else { |
1347 CHECK_EQ(p0, r->InputAt(0)); | 1347 CHECK_EQ(p0, r->InputAt(0)); |
1348 CHECK_EQ(p1, r->InputAt(1)); | 1348 CHECK_EQ(p1, r->InputAt(1)); |
1349 } | 1349 } |
1350 } | 1350 } |
1351 } | 1351 } |
1352 } | 1352 } |
1353 } | 1353 } |
OLD | NEW |