Adding hidden values always turned the object slow case because the
hidden symbol is not an identifier. Make sure to keep objects fast case when adding hidden values if possible. Review URL: http://codereview.chromium.org/93004 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@1758 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
5b394bf4d1
commit
7d4fed590f
@ -1129,9 +1129,10 @@ Object* JSObject::AddFastPropertyUsingMap(Map* new_map,
|
|||||||
Object* JSObject::AddFastProperty(String* name,
|
Object* JSObject::AddFastProperty(String* name,
|
||||||
Object* value,
|
Object* value,
|
||||||
PropertyAttributes attributes) {
|
PropertyAttributes attributes) {
|
||||||
// Normalize the object if the name is not a real identifier.
|
// Normalize the object if the name is an actual string (not the
|
||||||
|
// hidden symbols) and is not a real identifier.
|
||||||
StringInputBuffer buffer(name);
|
StringInputBuffer buffer(name);
|
||||||
if (!Scanner::IsIdentifier(&buffer)) {
|
if (!Scanner::IsIdentifier(&buffer) && name != Heap::hidden_symbol()) {
|
||||||
Object* obj = NormalizeProperties(CLEAR_INOBJECT_PROPERTIES);
|
Object* obj = NormalizeProperties(CLEAR_INOBJECT_PROPERTIES);
|
||||||
if (obj->IsFailure()) return obj;
|
if (obj->IsFailure()) return obj;
|
||||||
return AddSlowProperty(name, value, attributes);
|
return AddSlowProperty(name, value, attributes);
|
||||||
@ -5172,19 +5173,15 @@ bool JSObject::HasLocalElement(uint32_t index) {
|
|||||||
Object* JSObject::GetHiddenProperties(bool create_if_needed) {
|
Object* JSObject::GetHiddenProperties(bool create_if_needed) {
|
||||||
String* key = Heap::hidden_symbol();
|
String* key = Heap::hidden_symbol();
|
||||||
if (this->HasFastProperties()) {
|
if (this->HasFastProperties()) {
|
||||||
// If the object has fast properties, check whether the first slot in the
|
// If the object has fast properties, check whether the first slot
|
||||||
// descriptor array matches the hidden symbol. Since the hidden symbols
|
// in the descriptor array matches the hidden symbol. Since the
|
||||||
// hash code is zero it will always occupy the first entry if present.
|
// hidden symbols hash code is zero (and no other string has hash
|
||||||
|
// code zero) it will always occupy the first entry if present.
|
||||||
DescriptorArray* descriptors = this->map()->instance_descriptors();
|
DescriptorArray* descriptors = this->map()->instance_descriptors();
|
||||||
if (descriptors->number_of_descriptors() > 0) {
|
DescriptorReader r(descriptors);
|
||||||
if (descriptors->GetKey(0) == key) {
|
if (!r.eos() && (r.GetKey() == key) && r.IsProperty()) {
|
||||||
#ifdef DEBUG
|
ASSERT(r.type() == FIELD);
|
||||||
PropertyDetails details(descriptors->GetDetails(0));
|
return FastPropertyAt(r.GetFieldIndex());
|
||||||
ASSERT(details.type() == FIELD);
|
|
||||||
#endif // DEBUG
|
|
||||||
Object* value = descriptors->GetValue(0);
|
|
||||||
return FastPropertyAt(Descriptor::IndexFromValue(value));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user