Check enumerability of array indices correctly in propertyIsEnumerable.
Fix issue 1692. BUG=v8:1692 TEST=mjsunit/regress/regress-1692 Review URL: http://codereview.chromium.org/8113001 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@9503 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
08a85de703
commit
165e105ec9
@ -4704,7 +4704,37 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_IsPropertyEnumerable) {
|
|||||||
|
|
||||||
uint32_t index;
|
uint32_t index;
|
||||||
if (key->AsArrayIndex(&index)) {
|
if (key->AsArrayIndex(&index)) {
|
||||||
return isolate->heap()->ToBoolean(object->HasElement(index));
|
JSObject::LocalElementType type = object->HasLocalElement(index);
|
||||||
|
switch (type) {
|
||||||
|
case JSObject::UNDEFINED_ELEMENT:
|
||||||
|
case JSObject::STRING_CHARACTER_ELEMENT:
|
||||||
|
return isolate->heap()->false_value();
|
||||||
|
case JSObject::INTERCEPTED_ELEMENT:
|
||||||
|
case JSObject::FAST_ELEMENT:
|
||||||
|
return isolate->heap()->true_value();
|
||||||
|
case JSObject::DICTIONARY_ELEMENT: {
|
||||||
|
if (object->IsJSGlobalProxy()) {
|
||||||
|
Object* proto = object->GetPrototype();
|
||||||
|
if (proto->IsNull()) {
|
||||||
|
return isolate->heap()->false_value();
|
||||||
|
}
|
||||||
|
ASSERT(proto->IsJSGlobalObject());
|
||||||
|
object = JSObject::cast(proto);
|
||||||
|
}
|
||||||
|
FixedArray* elements = FixedArray::cast(object->elements());
|
||||||
|
NumberDictionary* dictionary = NULL;
|
||||||
|
if (elements->map() ==
|
||||||
|
isolate->heap()->non_strict_arguments_elements_map()) {
|
||||||
|
dictionary = NumberDictionary::cast(elements->get(1));
|
||||||
|
} else {
|
||||||
|
dictionary = NumberDictionary::cast(elements);
|
||||||
|
}
|
||||||
|
int entry = dictionary->FindEntry(index);
|
||||||
|
ASSERT(entry != NumberDictionary::kNotFound);
|
||||||
|
PropertyDetails details = dictionary->DetailsAt(entry);
|
||||||
|
return isolate->heap()->ToBoolean(!details.IsDontEnum());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PropertyAttributes att = object->GetLocalPropertyAttribute(key);
|
PropertyAttributes att = object->GetLocalPropertyAttribute(key);
|
||||||
|
89
test/mjsunit/regress/regress-1692.js
Normal file
89
test/mjsunit/regress/regress-1692.js
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
// Copyright 2011 the V8 project authors. All rights reserved.
|
||||||
|
// Redistribution and use in source and binary forms, with or without
|
||||||
|
// modification, are permitted provided that the following conditions are
|
||||||
|
// met:
|
||||||
|
//
|
||||||
|
// * Redistributions of source code must retain the above copyright
|
||||||
|
// notice, this list of conditions and the following disclaimer.
|
||||||
|
// * Redistributions in binary form must reproduce the above
|
||||||
|
// copyright notice, this list of conditions and the following
|
||||||
|
// disclaimer in the documentation and/or other materials provided
|
||||||
|
// with the distribution.
|
||||||
|
// * Neither the name of Google Inc. nor the names of its
|
||||||
|
// contributors may be used to endorse or promote products derived
|
||||||
|
// from this software without specific prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
// Test that Object.prototype.propertyIsEnumerable handles array indices
|
||||||
|
// correctly.
|
||||||
|
|
||||||
|
var p = Object.create({}, {
|
||||||
|
a : { value : 42, enumerable : true },
|
||||||
|
b : { value : 42, enumerable : false },
|
||||||
|
1 : { value : 42, enumerable : true },
|
||||||
|
2 : { value : 42, enumerable : false },
|
||||||
|
f : { get: function(){}, enumerable: true },
|
||||||
|
g : { get: function(){}, enumerable: false },
|
||||||
|
11 : { get: function(){}, enumerable: true },
|
||||||
|
12 : { get: function(){}, enumerable: false }
|
||||||
|
});
|
||||||
|
var o = Object.create(p, {
|
||||||
|
c : { value : 42, enumerable : true },
|
||||||
|
d : { value : 42, enumerable : false },
|
||||||
|
3 : { value : 42, enumerable : true },
|
||||||
|
4 : { value : 42, enumerable : false },
|
||||||
|
h : { get: function(){}, enumerable: true },
|
||||||
|
k : { get: function(){}, enumerable: false },
|
||||||
|
13 : { get: function(){}, enumerable: true },
|
||||||
|
14 : { get: function(){}, enumerable: false }
|
||||||
|
});
|
||||||
|
|
||||||
|
// Inherited properties are ignored.
|
||||||
|
assertFalse(o.propertyIsEnumerable("a"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("b"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("1"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("2"));
|
||||||
|
|
||||||
|
// Own properties.
|
||||||
|
assertTrue(o.propertyIsEnumerable("c"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("d"));
|
||||||
|
assertTrue(o.propertyIsEnumerable("3"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("4"));
|
||||||
|
|
||||||
|
// Inherited accessors.
|
||||||
|
assertFalse(o.propertyIsEnumerable("f"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("g"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("11"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("12"));
|
||||||
|
|
||||||
|
// Own accessors.
|
||||||
|
assertTrue(o.propertyIsEnumerable("h"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("k"));
|
||||||
|
assertTrue(o.propertyIsEnumerable("13"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("14"));
|
||||||
|
|
||||||
|
// Nonexisting properties.
|
||||||
|
assertFalse(o.propertyIsEnumerable("xxx"));
|
||||||
|
assertFalse(o.propertyIsEnumerable("999"));
|
||||||
|
|
||||||
|
// String object properties.
|
||||||
|
var o = Object("string");
|
||||||
|
// Non-string property on String object.
|
||||||
|
o[10] = 42;
|
||||||
|
assertTrue(o.propertyIsEnumerable(10));
|
||||||
|
assertFalse(o.propertyIsEnumerable(0));
|
||||||
|
|
||||||
|
// Fast elements.
|
||||||
|
var o = [1,2,3,4,5];
|
||||||
|
assertTrue(o.propertyIsEnumerable(3));
|
Loading…
Reference in New Issue
Block a user