Add AssertNoAllocation to ensure TransitionArray* transitions is safe.
Review URL: https://chromiumcodereview.appspot.com/12583013 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@14066 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
8792cac5cc
commit
2541f2507f
@ -1490,13 +1490,17 @@ MaybeObject* JSObject::AddFastPropertyUsingMap(Map* map) {
|
||||
bool JSObject::TryTransitionToField(Handle<JSObject> object,
|
||||
Handle<Name> key) {
|
||||
if (!object->map()->HasTransitionArray()) return false;
|
||||
TransitionArray* transitions = object->map()->transitions();
|
||||
int transition = transitions->Search(*key);
|
||||
if (transition == TransitionArray::kNotFound) return false;
|
||||
PropertyDetails target_details = transitions->GetTargetDetails(transition);
|
||||
if (target_details.type() != FIELD) return false;
|
||||
if (target_details.attributes() != NONE) return false;
|
||||
Handle<Map> target(transitions->GetTarget(transition));
|
||||
Handle<Map> target;
|
||||
{
|
||||
AssertNoAllocation no_allocation;
|
||||
TransitionArray* transitions = object->map()->transitions();
|
||||
int transition = transitions->Search(*key);
|
||||
if (transition == TransitionArray::kNotFound) return false;
|
||||
PropertyDetails target_details = transitions->GetTargetDetails(transition);
|
||||
if (target_details.type() != FIELD) return false;
|
||||
if (target_details.attributes() != NONE) return false;
|
||||
target = Handle<Map>(transitions->GetTarget(transition));
|
||||
}
|
||||
JSObject::AddFastPropertyUsingMap(object, target);
|
||||
return true;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user