Index: src/lookup-inl.h |
diff --git a/src/lookup-inl.h b/src/lookup-inl.h |
index 50f0d3e095ef93596f72938ac58a4b9102b33cf6..3e43f11a0d4f6a336b7744077d34b691f1e9dd56 100644 |
--- a/src/lookup-inl.h |
+++ b/src/lookup-inl.h |
@@ -58,11 +58,16 @@ LookupIterator::State LookupIterator::LookupInHolder(Map* const map, |
// Fall through. |
case INTERCEPTOR: |
if (IsElement()) { |
+ // TODO(verwaest): Optimize. |
JSObject* js_object = JSObject::cast(holder); |
ElementsAccessor* accessor = js_object->GetElementsAccessor(); |
FixedArrayBase* backing_store = js_object->elements(); |
number_ = accessor->GetIndexForKey(backing_store, index_); |
if (number_ == kMaxUInt32) return NOT_FOUND; |
+ if (accessor->GetAttributes(js_object, index_, backing_store) == |
+ ABSENT) { |
+ return NOT_FOUND; |
+ } |
property_details_ = accessor->GetDetails(backing_store, number_); |
} else if (map->is_dictionary_map()) { |
NameDictionary* dict = JSObject::cast(holder)->property_dictionary(); |