| 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/typer.h" | 5 #include "src/compiler/typer.h" |
| 6 | 6 |
| 7 #include "src/base/flags.h" | 7 #include "src/base/flags.h" |
| 8 #include "src/bootstrapper.h" | 8 #include "src/bootstrapper.h" |
| 9 #include "src/compilation-dependencies.h" | 9 #include "src/compilation-dependencies.h" |
| 10 #include "src/compiler/common-operator.h" | 10 #include "src/compiler/common-operator.h" |
| (...skipping 632 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 643 | 643 |
| 644 Type* Typer::Visitor::TypeTypedStateValues(Node* node) { | 644 Type* Typer::Visitor::TypeTypedStateValues(Node* node) { |
| 645 return Type::Internal(zone()); | 645 return Type::Internal(zone()); |
| 646 } | 646 } |
| 647 | 647 |
| 648 | 648 |
| 649 Type* Typer::Visitor::TypeCall(Node* node) { return Type::Any(); } | 649 Type* Typer::Visitor::TypeCall(Node* node) { return Type::Any(); } |
| 650 | 650 |
| 651 | 651 |
| 652 Type* Typer::Visitor::TypeProjection(Node* node) { | 652 Type* Typer::Visitor::TypeProjection(Node* node) { |
| 653 // TODO(bmeurer): Make this beautiful! Use tuple type here. | 653 Type* const type = Operand(node, 0); |
| 654 if (node->InputAt(0)->opcode() == IrOpcode::kJSForInPrepare && | 654 if (type->Is(Type::None())) return Type::None(); |
| 655 ProjectionIndexOf(node->op()) == 2) { | 655 int const index = static_cast<int>(ProjectionIndexOf(node->op())); |
| 656 return typer_->cache_.kSmi; | 656 if (type->IsTuple() && index < type->AsTuple()->Arity()) { |
| 657 return type->AsTuple()->Element(index); |
| 657 } | 658 } |
| 658 // TODO(titzer): use the output type of the input to determine the bounds. | |
| 659 return Type::Any(); | 659 return Type::Any(); |
| 660 } | 660 } |
| 661 | 661 |
| 662 | 662 |
| 663 Type* Typer::Visitor::TypeDead(Node* node) { return Type::Any(); } | 663 Type* Typer::Visitor::TypeDead(Node* node) { return Type::Any(); } |
| 664 | 664 |
| 665 | 665 |
| 666 // JS comparison operators. | 666 // JS comparison operators. |
| 667 | 667 |
| 668 | 668 |
| (...skipping 942 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1611 return Type::Receiver(); | 1611 return Type::Receiver(); |
| 1612 } | 1612 } |
| 1613 | 1613 |
| 1614 | 1614 |
| 1615 Type* Typer::Visitor::TypeJSForInNext(Node* node) { | 1615 Type* Typer::Visitor::TypeJSForInNext(Node* node) { |
| 1616 return Type::Union(Type::Name(), Type::Undefined(), zone()); | 1616 return Type::Union(Type::Name(), Type::Undefined(), zone()); |
| 1617 } | 1617 } |
| 1618 | 1618 |
| 1619 | 1619 |
| 1620 Type* Typer::Visitor::TypeJSForInPrepare(Node* node) { | 1620 Type* Typer::Visitor::TypeJSForInPrepare(Node* node) { |
| 1621 // TODO(bmeurer): Return a tuple type here. | 1621 STATIC_ASSERT(Map::EnumLengthBits::kMax <= FixedArray::kMaxLength); |
| 1622 return Type::Any(); | 1622 Factory* const f = isolate()->factory(); |
| 1623 Type* const cache_type = Type::Union( |
| 1624 typer_->cache_.kSmi, Type::Class(f->meta_map(), zone()), zone()); |
| 1625 Type* const cache_array = Type::Class(f->fixed_array_map(), zone()); |
| 1626 Type* const cache_length = typer_->cache_.kFixedArrayLengthType; |
| 1627 return Type::Tuple(cache_type, cache_array, cache_length, zone()); |
| 1623 } | 1628 } |
| 1624 | 1629 |
| 1625 | 1630 |
| 1626 Type* Typer::Visitor::TypeJSForInDone(Node* node) { | 1631 Type* Typer::Visitor::TypeJSForInDone(Node* node) { |
| 1627 return Type::Boolean(zone()); | 1632 return Type::Boolean(zone()); |
| 1628 } | 1633 } |
| 1629 | 1634 |
| 1630 | 1635 |
| 1631 Type* Typer::Visitor::TypeJSForInStep(Node* node) { | 1636 Type* Typer::Visitor::TypeJSForInStep(Node* node) { |
| 1632 STATIC_ASSERT(Map::EnumLengthBits::kMax <= FixedArray::kMaxLength); | 1637 STATIC_ASSERT(Map::EnumLengthBits::kMax <= FixedArray::kMaxLength); |
| (...skipping 813 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2446 } | 2451 } |
| 2447 if (Type::IsInteger(*value)) { | 2452 if (Type::IsInteger(*value)) { |
| 2448 return Type::Range(value->Number(), value->Number(), zone()); | 2453 return Type::Range(value->Number(), value->Number(), zone()); |
| 2449 } | 2454 } |
| 2450 return Type::Constant(value, zone()); | 2455 return Type::Constant(value, zone()); |
| 2451 } | 2456 } |
| 2452 | 2457 |
| 2453 } // namespace compiler | 2458 } // namespace compiler |
| 2454 } // namespace internal | 2459 } // namespace internal |
| 2455 } // namespace v8 | 2460 } // namespace v8 |
| OLD | NEW |