Handlify GlobalObject::EnsurePropertyCell method.

R=rossberg@chromium.org

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

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@15508 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent d00a1439
...@@ -106,6 +106,13 @@ inline Handle<T> handle(T* t, Isolate* isolate) { ...@@ -106,6 +106,13 @@ inline Handle<T> handle(T* t, Isolate* isolate) {
} }
// Convenience wrapper.
template<class T>
inline Handle<T> handle(T* t) {
return Handle<T>(t, t->GetIsolate());
}
class DeferredHandles; class DeferredHandles;
class HandleScopeImplementer; class HandleScopeImplementer;
......
...@@ -14243,39 +14243,36 @@ PropertyCell* GlobalObject::GetPropertyCell(LookupResult* result) { ...@@ -14243,39 +14243,36 @@ PropertyCell* GlobalObject::GetPropertyCell(LookupResult* result) {
} }
Handle<PropertyCell> GlobalObject::EnsurePropertyCell( // TODO(mstarzinger): Temporary wrapper until handlified.
Handle<GlobalObject> global, static Handle<NameDictionary> NameDictionaryAdd(Handle<NameDictionary> dict,
Handle<Name> name) { Handle<Name> name,
Isolate* isolate = global->GetIsolate(); Handle<Object> value,
CALL_HEAP_FUNCTION(isolate, PropertyDetails details) {
global->EnsurePropertyCell(*name), CALL_HEAP_FUNCTION(dict->GetIsolate(),
PropertyCell); dict->Add(*name, *value, details),
NameDictionary);
} }
MaybeObject* GlobalObject::EnsurePropertyCell(Name* name) { Handle<PropertyCell> GlobalObject::EnsurePropertyCell(
ASSERT(!HasFastProperties()); Handle<GlobalObject> global,
int entry = property_dictionary()->FindEntry(name); Handle<Name> name) {
ASSERT(!global->HasFastProperties());
int entry = global->property_dictionary()->FindEntry(*name);
if (entry == NameDictionary::kNotFound) { if (entry == NameDictionary::kNotFound) {
Heap* heap = GetHeap(); Isolate* isolate = global->GetIsolate();
Object* cell; Handle<PropertyCell> cell = isolate->factory()->NewPropertyCell(
{ MaybeObject* maybe_cell = isolate->factory()->the_hole_value());
heap->AllocatePropertyCell(heap->the_hole_value());
if (!maybe_cell->ToObject(&cell)) return maybe_cell;
}
PropertyDetails details(NONE, NORMAL, 0); PropertyDetails details(NONE, NORMAL, 0);
details = details.AsDeleted(); details = details.AsDeleted();
Object* dictionary; Handle<NameDictionary> dictionary = NameDictionaryAdd(
{ MaybeObject* maybe_dictionary = handle(global->property_dictionary()), name, cell, details);
property_dictionary()->Add(name, cell, details); global->set_properties(*dictionary);
if (!maybe_dictionary->ToObject(&dictionary)) return maybe_dictionary;
}
set_properties(NameDictionary::cast(dictionary));
return cell; return cell;
} else { } else {
Object* value = property_dictionary()->ValueAt(entry); Object* value = global->property_dictionary()->ValueAt(entry);
ASSERT(value->IsPropertyCell()); ASSERT(value->IsPropertyCell());
return value; return handle(PropertyCell::cast(value));
} }
} }
......
...@@ -6820,12 +6820,8 @@ class GlobalObject: public JSObject { ...@@ -6820,12 +6820,8 @@ class GlobalObject: public JSObject {
} }
// Ensure that the global object has a cell for the given property name. // Ensure that the global object has a cell for the given property name.
static Handle<PropertyCell> EnsurePropertyCell( static Handle<PropertyCell> EnsurePropertyCell(Handle<GlobalObject> global,
Handle<GlobalObject> global, Handle<Name> name);
Handle<Name> name);
// TODO(kmillikin): This function can be eliminated once the stub cache is
// fully handlified (and the static helper can be written directly).
MUST_USE_RESULT MaybeObject* EnsurePropertyCell(Name* name);
// Casting. // Casting.
static inline GlobalObject* cast(Object* obj); static inline GlobalObject* cast(Object* obj);
......
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