Commit e4c3c439 authored by verwaest@chromium.org's avatar verwaest@chromium.org

Get rid of the NONEXISTENT PropertyType

BUG=

Review URL: https://codereview.chromium.org/492433005

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@23260 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 4f8e5f07
...@@ -2464,7 +2464,6 @@ void Genesis::TransferNamedProperties(Handle<JSObject> from, ...@@ -2464,7 +2464,6 @@ void Genesis::TransferNamedProperties(Handle<JSObject> from,
// Do not occur since the from object has fast properties. // Do not occur since the from object has fast properties.
case HANDLER: case HANDLER:
case INTERCEPTOR: case INTERCEPTOR:
case NONEXISTENT:
// No element in instance descriptors have proxy or interceptor type. // No element in instance descriptors have proxy or interceptor type.
UNREACHABLE(); UNREACHABLE();
break; break;
......
...@@ -1700,9 +1700,6 @@ void V8HeapExplorer::ExtractPropertyReferences(JSObject* js_obj, int entry) { ...@@ -1700,9 +1700,6 @@ void V8HeapExplorer::ExtractPropertyReferences(JSObject* js_obj, int entry) {
case HANDLER: // only in lookup results, not in descriptors case HANDLER: // only in lookup results, not in descriptors
case INTERCEPTOR: // only in lookup results, not in descriptors case INTERCEPTOR: // only in lookup results, not in descriptors
break; break;
case NONEXISTENT:
UNREACHABLE();
break;
} }
} }
} else { } else {
......
...@@ -1597,7 +1597,6 @@ Handle<Code> StoreIC::CompileStoreHandler(LookupResult* lookup, ...@@ -1597,7 +1597,6 @@ Handle<Code> StoreIC::CompileStoreHandler(LookupResult* lookup,
} }
case CONSTANT: case CONSTANT:
break; break;
case NONEXISTENT:
case HANDLER: case HANDLER:
UNREACHABLE(); UNREACHABLE();
break; break;
......
...@@ -100,7 +100,6 @@ bool LookupIterator::HasProperty() { ...@@ -100,7 +100,6 @@ bool LookupIterator::HasProperty() {
property_kind_ = ACCESSOR; property_kind_ = ACCESSOR;
break; break;
case v8::internal::HANDLER: case v8::internal::HANDLER:
case v8::internal::NONEXISTENT:
case v8::internal::INTERCEPTOR: case v8::internal::INTERCEPTOR:
UNREACHABLE(); UNREACHABLE();
} }
......
...@@ -70,7 +70,7 @@ class LookupIterator V8_FINAL BASE_EMBEDDED { ...@@ -70,7 +70,7 @@ class LookupIterator V8_FINAL BASE_EMBEDDED {
state_(NOT_FOUND), state_(NOT_FOUND),
property_kind_(DATA), property_kind_(DATA),
property_encoding_(DESCRIPTOR), property_encoding_(DESCRIPTOR),
property_details_(NONE, NONEXISTENT, Representation::None()), property_details_(NONE, NORMAL, Representation::None()),
isolate_(name->GetIsolate()), isolate_(name->GetIsolate()),
name_(name), name_(name),
maybe_receiver_(receiver), maybe_receiver_(receiver),
...@@ -88,7 +88,7 @@ class LookupIterator V8_FINAL BASE_EMBEDDED { ...@@ -88,7 +88,7 @@ class LookupIterator V8_FINAL BASE_EMBEDDED {
state_(NOT_FOUND), state_(NOT_FOUND),
property_kind_(DATA), property_kind_(DATA),
property_encoding_(DESCRIPTOR), property_encoding_(DESCRIPTOR),
property_details_(NONE, NONEXISTENT, Representation::None()), property_details_(NONE, NORMAL, Representation::None()),
isolate_(name->GetIsolate()), isolate_(name->GetIsolate()),
name_(name), name_(name),
holder_map_(holder->map()), holder_map_(holder->map()),
......
...@@ -179,7 +179,6 @@ PropertyType.Constant = 2; ...@@ -179,7 +179,6 @@ PropertyType.Constant = 2;
PropertyType.Callbacks = 3; PropertyType.Callbacks = 3;
PropertyType.Handler = 4; PropertyType.Handler = 4;
PropertyType.Interceptor = 5; PropertyType.Interceptor = 5;
PropertyType.Nonexistent = 6;
// Different attributes for a property. // Different attributes for a property.
......
...@@ -242,8 +242,6 @@ void JSObject::PrintProperties(OStream& os) { // NOLINT ...@@ -242,8 +242,6 @@ void JSObject::PrintProperties(OStream& os) { // NOLINT
case NORMAL: // only in slow mode case NORMAL: // only in slow mode
case HANDLER: // only in lookup results, not in descriptors case HANDLER: // only in lookup results, not in descriptors
case INTERCEPTOR: // only in lookup results, not in descriptors case INTERCEPTOR: // only in lookup results, not in descriptors
// There are no transitions in the descriptor array.
case NONEXISTENT:
UNREACHABLE(); UNREACHABLE();
break; break;
} }
...@@ -377,7 +375,6 @@ void JSObject::PrintTransitions(OStream& os) { // NOLINT ...@@ -377,7 +375,6 @@ void JSObject::PrintTransitions(OStream& os) { // NOLINT
case NORMAL: case NORMAL:
case HANDLER: case HANDLER:
case INTERCEPTOR: case INTERCEPTOR:
case NONEXISTENT:
UNREACHABLE(); UNREACHABLE();
break; break;
} }
...@@ -1107,7 +1104,6 @@ void TransitionArray::PrintTransitions(OStream& os) { // NOLINT ...@@ -1107,7 +1104,6 @@ void TransitionArray::PrintTransitions(OStream& os) { // NOLINT
case NORMAL: case NORMAL:
case HANDLER: case HANDLER:
case INTERCEPTOR: case INTERCEPTOR:
case NONEXISTENT:
UNREACHABLE(); UNREACHABLE();
break; break;
} }
......
...@@ -2774,7 +2774,6 @@ MaybeHandle<Map> Map::TryUpdateInternal(Handle<Map> old_map) { ...@@ -2774,7 +2774,6 @@ MaybeHandle<Map> Map::TryUpdateInternal(Handle<Map> old_map) {
case NORMAL: case NORMAL:
case HANDLER: case HANDLER:
case INTERCEPTOR: case INTERCEPTOR:
case NONEXISTENT:
UNREACHABLE(); UNREACHABLE();
} }
} }
...@@ -4264,7 +4263,6 @@ void JSObject::MigrateFastToSlow(Handle<JSObject> object, ...@@ -4264,7 +4263,6 @@ void JSObject::MigrateFastToSlow(Handle<JSObject> object,
break; break;
case HANDLER: case HANDLER:
case NORMAL: case NORMAL:
case NONEXISTENT:
UNREACHABLE(); UNREACHABLE();
break; break;
} }
...@@ -6823,7 +6821,6 @@ bool DescriptorArray::CanHoldValue(int descriptor, Object* value) { ...@@ -6823,7 +6821,6 @@ bool DescriptorArray::CanHoldValue(int descriptor, Object* value) {
case NORMAL: case NORMAL:
case INTERCEPTOR: case INTERCEPTOR:
case HANDLER: case HANDLER:
case NONEXISTENT:
break; break;
} }
......
...@@ -46,16 +46,14 @@ class TypeInfo; ...@@ -46,16 +46,14 @@ class TypeInfo;
// A copy of this is in mirror-debugger.js. // A copy of this is in mirror-debugger.js.
enum PropertyType { enum PropertyType {
// Only in slow mode. // Only in slow mode.
NORMAL = 0, NORMAL = 0,
// Only in fast mode. // Only in fast mode.
FIELD = 1, FIELD = 1,
CONSTANT = 2, CONSTANT = 2,
CALLBACKS = 3, CALLBACKS = 3,
// Only in lookup results, not in descriptors. // Only in lookup results, not in descriptors.
HANDLER = 4, HANDLER = 4,
INTERCEPTOR = 5, INTERCEPTOR = 5
// Only used as a marker in LookupResult.
NONEXISTENT = 6
}; };
......
...@@ -47,9 +47,6 @@ OStream& operator<<(OStream& os, const LookupResult& r) { ...@@ -47,9 +47,6 @@ OStream& operator<<(OStream& os, const LookupResult& r) {
return os << " -type = lookup proxy\n"; return os << " -type = lookup proxy\n";
case INTERCEPTOR: case INTERCEPTOR:
return os << " -type = lookup interceptor\n"; return os << " -type = lookup interceptor\n";
case NONEXISTENT:
UNREACHABLE();
break;
} }
return os; return os;
} }
......
...@@ -120,7 +120,7 @@ class LookupResult V8_FINAL BASE_EMBEDDED { ...@@ -120,7 +120,7 @@ class LookupResult V8_FINAL BASE_EMBEDDED {
holder_(NULL), holder_(NULL),
transition_(NULL), transition_(NULL),
cacheable_(true), cacheable_(true),
details_(NONE, NONEXISTENT, Representation::None()) { details_(NONE, NORMAL, Representation::None()) {
isolate->set_top_lookup_result(this); isolate->set_top_lookup_result(this);
} }
...@@ -158,8 +158,6 @@ class LookupResult V8_FINAL BASE_EMBEDDED { ...@@ -158,8 +158,6 @@ class LookupResult V8_FINAL BASE_EMBEDDED {
case HANDLER: case HANDLER:
case INTERCEPTOR: case INTERCEPTOR:
return true; return true;
case NONEXISTENT:
UNREACHABLE();
} }
UNREACHABLE(); UNREACHABLE();
return true; return true;
...@@ -198,7 +196,7 @@ class LookupResult V8_FINAL BASE_EMBEDDED { ...@@ -198,7 +196,7 @@ class LookupResult V8_FINAL BASE_EMBEDDED {
void NotFound() { void NotFound() {
lookup_type_ = NOT_FOUND; lookup_type_ = NOT_FOUND;
details_ = PropertyDetails(NONE, NONEXISTENT, Representation::None()); details_ = PropertyDetails(NONE, NORMAL, Representation::None());
holder_ = NULL; holder_ = NULL;
transition_ = NULL; transition_ = NULL;
} }
...@@ -220,13 +218,11 @@ class LookupResult V8_FINAL BASE_EMBEDDED { ...@@ -220,13 +218,11 @@ class LookupResult V8_FINAL BASE_EMBEDDED {
Representation representation() const { Representation representation() const {
DCHECK(IsFound()); DCHECK(IsFound());
DCHECK(details_.type() != NONEXISTENT);
return details_.representation(); return details_.representation();
} }
PropertyAttributes GetAttributes() const { PropertyAttributes GetAttributes() const {
DCHECK(IsFound()); DCHECK(IsFound());
DCHECK(details_.type() != NONEXISTENT);
return details_.attributes(); return details_.attributes();
} }
...@@ -247,7 +243,6 @@ class LookupResult V8_FINAL BASE_EMBEDDED { ...@@ -247,7 +243,6 @@ class LookupResult V8_FINAL BASE_EMBEDDED {
bool IsReadOnly() const { bool IsReadOnly() const {
DCHECK(IsFound()); DCHECK(IsFound());
DCHECK(details_.type() != NONEXISTENT);
return details_.IsReadOnly(); return details_.IsReadOnly();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment