diff options
Diffstat (limited to 'deps/v8/src/property.h')
-rw-r--r-- | deps/v8/src/property.h | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/deps/v8/src/property.h b/deps/v8/src/property.h index e7d9fc5345..ee2e8c844e 100644 --- a/deps/v8/src/property.h +++ b/deps/v8/src/property.h @@ -115,11 +115,9 @@ class MapTransitionDescriptor: public Descriptor { class ElementsTransitionDescriptor: public Descriptor { public: ElementsTransitionDescriptor(String* key, - Map* map, - ElementsKind elements_kind) - : Descriptor(key, map, PropertyDetails(NONE, - ELEMENTS_TRANSITION, - elements_kind)) { } + Object* map_or_array) + : Descriptor(key, map_or_array, PropertyDetails(NONE, + ELEMENTS_TRANSITION)) { } }; // Marks a field name in a map so that adding the field is guaranteed @@ -202,9 +200,9 @@ class LookupResult BASE_EMBEDDED { number_ = entry; } - void HandlerResult() { + void HandlerResult(JSProxy* proxy) { lookup_type_ = HANDLER_TYPE; - holder_ = NULL; + holder_ = proxy; details_ = PropertyDetails(NONE, HANDLER); cacheable_ = false; } @@ -221,7 +219,12 @@ class LookupResult BASE_EMBEDDED { JSObject* holder() { ASSERT(IsFound()); - return holder_; + return JSObject::cast(holder_); + } + + JSProxy* proxy() { + ASSERT(IsFound()); + return JSProxy::cast(holder_); } PropertyType type() { @@ -354,7 +357,7 @@ class LookupResult BASE_EMBEDDED { CONSTANT_TYPE } lookup_type_; - JSObject* holder_; + JSReceiver* holder_; int number_; bool cacheable_; PropertyDetails details_; |