| Index: src/objects.cc
|
| diff --git a/src/objects.cc b/src/objects.cc
|
| index 1100adb3fc98d2bee567ea5ed65e78ed7d96d219..0def5286ec3d22d83500452646f5c302c2e4c1f5 100644
|
| --- a/src/objects.cc
|
| +++ b/src/objects.cc
|
| @@ -34,7 +34,7 @@
|
| #include "src/interpreter/bytecodes.h"
|
| #include "src/interpreter/source-position-table.h"
|
| #include "src/isolate-inl.h"
|
| -#include "src/key-accumulator.h"
|
| +#include "src/keys.h"
|
| #include "src/list.h"
|
| #include "src/log.h"
|
| #include "src/lookup.h"
|
| @@ -8239,7 +8239,9 @@ MaybeHandle<Object> JSReceiver::OrdinaryToPrimitive(
|
|
|
|
|
| // TODO(cbruni/jkummerow): Consider moving this into elements.cc.
|
| -bool HasEnumerableElements(JSObject* object) {
|
| +bool JSObject::HasEnumerableElements() {
|
| + // TODO(cbruni): cleanup
|
| + JSObject* object = this;
|
| switch (object->GetElementsKind()) {
|
| case FAST_SMI_ELEMENTS:
|
| case FAST_ELEMENTS:
|
| @@ -8304,7 +8306,6 @@ bool HasEnumerableElements(JSObject* object) {
|
| return true;
|
| }
|
|
|
| -
|
| // Tests for the fast common case for property enumeration:
|
| // - This object and all prototypes has an enum cache (which means that
|
| // it is no proxy, has no interceptors and needs no access checks).
|
| @@ -8321,7 +8322,7 @@ bool JSReceiver::IsSimpleEnum() {
|
| if (current->IsAccessCheckNeeded()) return false;
|
| DCHECK(!current->HasNamedInterceptor());
|
| DCHECK(!current->HasIndexedInterceptor());
|
| - if (HasEnumerableElements(current)) return false;
|
| + if (current->HasEnumerableElements()) return false;
|
| if (current != this && enum_length != 0) return false;
|
| }
|
| return true;
|
| @@ -8385,10 +8386,9 @@ bool Map::OnlyHasSimpleProperties() {
|
| !has_hidden_prototype() && !is_dictionary_map();
|
| }
|
|
|
| -namespace {
|
| -
|
| -Handle<FixedArray> GetFastEnumPropertyKeys(Isolate* isolate,
|
| - Handle<JSObject> object) {
|
| +// static
|
| +Handle<FixedArray> JSObject::GetFastEnumPropertyKeys(Isolate* isolate,
|
| + Handle<JSObject> object) {
|
| Handle<Map> map(object->map());
|
| bool cache_enum_length = map->OnlyHasSimpleProperties();
|
|
|
| @@ -8439,8 +8439,9 @@ Handle<FixedArray> GetFastEnumPropertyKeys(Isolate* isolate,
|
|
|
| for (int i = 0; i < size; i++) {
|
| PropertyDetails details = descs->GetDetails(i);
|
| + if (details.IsDontEnum()) continue;
|
| Object* key = descs->GetKey(i);
|
| - if (details.IsDontEnum() || key->IsSymbol()) continue;
|
| + if (key->IsSymbol()) continue;
|
| storage->set(index, key);
|
| if (!indices.is_null()) {
|
| if (details.type() != DATA) {
|
| @@ -8462,7 +8463,6 @@ Handle<FixedArray> GetFastEnumPropertyKeys(Isolate* isolate,
|
| return storage;
|
| }
|
|
|
| -} // namespace
|
|
|
| Handle<FixedArray> JSObject::GetEnumPropertyKeys(Handle<JSObject> object) {
|
| Isolate* isolate = object->GetIsolate();
|
| @@ -10680,7 +10680,6 @@ Handle<ArrayList> ArrayList::Add(Handle<ArrayList> array, Handle<Object> obj,
|
| return array;
|
| }
|
|
|
| -
|
| Handle<ArrayList> ArrayList::Add(Handle<ArrayList> array, Handle<Object> obj1,
|
| Handle<Object> obj2, AddMode mode) {
|
| int length = array->Length();
|
| @@ -16442,7 +16441,6 @@ void FixedArray::SortPairs(FixedArray* numbers, uint32_t len) {
|
| }
|
| }
|
|
|
| -
|
| void JSObject::CollectOwnPropertyNames(KeyAccumulator* keys,
|
| PropertyFilter filter) {
|
| if (HasFastProperties()) {
|
| @@ -16483,7 +16481,6 @@ int JSObject::NumberOfOwnElements(PropertyFilter filter) {
|
| return GetOwnElementKeys(NULL, filter);
|
| }
|
|
|
| -
|
| void JSObject::CollectOwnElementKeys(Handle<JSObject> object,
|
| KeyAccumulator* keys,
|
| PropertyFilter filter) {
|
| @@ -18491,7 +18488,6 @@ int Dictionary<Derived, Shape, Key>::CopyKeysTo(
|
| return index - start_index;
|
| }
|
|
|
| -
|
| template <typename Derived, typename Shape, typename Key>
|
| void Dictionary<Derived, Shape, Key>::CollectKeysTo(
|
| Handle<Dictionary<Derived, Shape, Key> > dictionary, KeyAccumulator* keys,
|
|
|