Commit 8535c648 authored by verwaest@chromium.org's avatar verwaest@chromium.org

Set length only after retrieving the element succeeded

Review URL: https://chromiumcodereview.appspot.com/11417006

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@12974 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 11163035
...@@ -673,14 +673,17 @@ BUILTIN(ArrayPop) { ...@@ -673,14 +673,17 @@ BUILTIN(ArrayPop) {
ElementsAccessor* accessor = array->GetElementsAccessor(); ElementsAccessor* accessor = array->GetElementsAccessor();
int new_length = len - 1; int new_length = len - 1;
Object* result; MaybeObject* maybe_result;
MaybeObject* maybe_result = accessor->Get(array, array, new_length); if (accessor->HasElement(array, array, new_length, elms_obj)) {
if (!maybe_result->To(&result)) return maybe_result; maybe_result = accessor->Get(array, array, new_length, elms_obj);
} else {
maybe_result = array->GetPrototype()->GetElement(len - 1);
}
if (maybe_result->IsFailure()) return maybe_result;
MaybeObject* maybe_failure = MaybeObject* maybe_failure =
accessor->SetLength(array, Smi::FromInt(new_length)); accessor->SetLength(array, Smi::FromInt(new_length));
if (maybe_failure->IsFailure()) return maybe_failure; if (maybe_failure->IsFailure()) return maybe_failure;
if (!result->IsTheHole()) return result; return maybe_result;
return array->GetPrototype()->GetElement(len - 1);
} }
......
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