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 #ifndef V8_TYPES_H_ | 5 #ifndef V8_TYPES_H_ |
6 #define V8_TYPES_H_ | 6 #define V8_TYPES_H_ |
7 | 7 |
8 #include "src/conversions.h" | 8 #include "src/conversions.h" |
9 #include "src/handles.h" | 9 #include "src/handles.h" |
10 #include "src/objects.h" | 10 #include "src/objects.h" |
(...skipping 585 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
596 bitset BitsetLub() { return BitsetType::Lub(this); } | 596 bitset BitsetLub() { return BitsetType::Lub(this); } |
597 | 597 |
598 bool SlowIs(TypeImpl* that); | 598 bool SlowIs(TypeImpl* that); |
599 bool SemanticIs(TypeImpl* that); | 599 bool SemanticIs(TypeImpl* that); |
600 | 600 |
601 struct Limits { | 601 struct Limits { |
602 double min; | 602 double min; |
603 double max; | 603 double max; |
604 Limits(double min, double max) : min(min), max(max) {} | 604 Limits(double min, double max) : min(min), max(max) {} |
605 explicit Limits(RangeType* range) : min(range->Min()), max(range->Max()) {} | 605 explicit Limits(RangeType* range) : min(range->Min()), max(range->Max()) {} |
606 static Limits Empty(Region* region) { return Limits(1, 0); } | 606 bool IsEmpty(); |
| 607 static Limits Empty() { return Limits(1, 0); } |
| 608 static Limits Intersect(Limits lhs, Limits rhs); |
| 609 static Limits Union(Limits lhs, Limits rhs); |
607 }; | 610 }; |
608 | 611 |
609 static bool IsEmpty(Limits lim); | |
610 static Limits Intersect(Limits lhs, Limits rhs); | |
611 static Limits Union(Limits lhs, Limits rhs); | |
612 static bool Overlap(RangeType* lhs, RangeType* rhs); | 612 static bool Overlap(RangeType* lhs, RangeType* rhs); |
613 static bool Contains(RangeType* lhs, RangeType* rhs); | 613 static bool Contains(RangeType* lhs, RangeType* rhs); |
614 static bool Contains(RangeType* range, ConstantType* constant); | 614 static bool Contains(RangeType* range, ConstantType* constant); |
615 static bool Contains(RangeType* range, i::Object* val); | 615 static bool Contains(RangeType* range, i::Object* val); |
616 | 616 |
617 static int UpdateRange( | 617 static int UpdateRange( |
618 RangeHandle type, UnionHandle result, int size, Region* region); | 618 RangeHandle type, UnionHandle result, int size, Region* region); |
619 | 619 |
620 static Limits IntersectRangeAndBitset(TypeHandle range, TypeHandle bits, | 620 static Limits IntersectRangeAndBitset(TypeHandle range, TypeHandle bits, |
621 Region* region); | 621 Region* region); |
(...skipping 545 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1167 bool Narrows(BoundsImpl that) { | 1167 bool Narrows(BoundsImpl that) { |
1168 return that.lower->Is(this->lower) && this->upper->Is(that.upper); | 1168 return that.lower->Is(this->lower) && this->upper->Is(that.upper); |
1169 } | 1169 } |
1170 }; | 1170 }; |
1171 | 1171 |
1172 typedef BoundsImpl<ZoneTypeConfig> Bounds; | 1172 typedef BoundsImpl<ZoneTypeConfig> Bounds; |
1173 | 1173 |
1174 } } // namespace v8::internal | 1174 } } // namespace v8::internal |
1175 | 1175 |
1176 #endif // V8_TYPES_H_ | 1176 #endif // V8_TYPES_H_ |
OLD | NEW |