Chromium Code Reviews| Index: src/factory.cc | 
| diff --git a/src/factory.cc b/src/factory.cc | 
| index 495313953eb0916376891f06ad795320794d811e..1a4efcf1f30122eced8bd800e714d7779225dbfb 100644 | 
| --- a/src/factory.cc | 
| +++ b/src/factory.cc | 
| @@ -892,9 +892,9 @@ Handle<String> Factory::SymbolFromString(Handle<String> value) { | 
| } | 
| -Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors( | 
| - Handle<DescriptorArray> array, | 
| - Handle<Object> descriptors) { | 
| +void Factory::CopyAppendCallbackDescriptors(Handle<Map> map, | 
| + Handle<Object> descriptors) { | 
| + Handle<DescriptorArray> array(map->instance_descriptors()); | 
| v8::NeanderArray callbacks(descriptors); | 
| int nof_callbacks = callbacks.length(); | 
| int descriptor_count = array->number_of_descriptors(); | 
| @@ -922,10 +922,7 @@ Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors( | 
| Handle<String> key = | 
| SymbolFromString(Handle<String>(String::cast(entry->name()))); | 
| // Check if a descriptor with this name already exists before writing. | 
| - if (LinearSearch(*result, | 
| - EXPECT_UNSORTED, | 
| - *key, | 
| - result->NumberOfSetDescriptors()) == | 
| + if (LinearSearch(*result, *key, result->NumberOfSetDescriptors()) == | 
| DescriptorArray::kNotFound) { | 
| CallbacksDescriptor desc(*key, *entry, entry->property_attributes()); | 
| result->Append(&desc, witness); | 
| @@ -934,7 +931,7 @@ Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors( | 
| int new_number_of_descriptors = result->NumberOfSetDescriptors(); | 
| // Return the old descriptor array if there were no new elements. | 
| 
 
Jakob Kummerow
2012/07/18 15:17:55
nit: outdated comment. Suggestion: s/Return the ol
 
 | 
| - if (new_number_of_descriptors == descriptor_count) return array; | 
| + if (new_number_of_descriptors == descriptor_count) return; | 
| // If duplicates were detected, allocate a result of the right size | 
| // and transfer the elements. | 
| @@ -944,12 +941,11 @@ Handle<DescriptorArray> Factory::CopyAppendCallbackDescriptors( | 
| for (int i = 0; i < new_number_of_descriptors; i++) { | 
| new_result->CopyFrom(i, *result, i, witness); | 
| } | 
| + new_result->SetLastAdded(result->LastAdded()); | 
| result = new_result; | 
| } | 
| - // Sort the result before returning. | 
| - result->Sort(witness); | 
| - return result; | 
| + map->set_instance_descriptors(*result); | 
| } | 
| @@ -1337,20 +1333,15 @@ Handle<JSFunction> Factory::CreateApiFunction( | 
| result->shared()->DontAdaptArguments(); | 
| // Recursively copy parent templates' accessors, 'data' may be modified. | 
| - Handle<DescriptorArray> array = | 
| - Handle<DescriptorArray>(map->instance_descriptors()); | 
| while (true) { | 
| Handle<Object> props = Handle<Object>(obj->property_accessors()); | 
| if (!props->IsUndefined()) { | 
| - array = CopyAppendCallbackDescriptors(array, props); | 
| + CopyAppendCallbackDescriptors(map, props); | 
| } | 
| Handle<Object> parent = Handle<Object>(obj->parent_template()); | 
| if (parent->IsUndefined()) break; | 
| obj = Handle<FunctionTemplateInfo>::cast(parent); | 
| } | 
| - if (!array->IsEmpty()) { | 
| - map->set_instance_descriptors(*array); | 
| - } | 
| ASSERT(result->shared()->IsApiFunction()); | 
| return result; |