Index: src/lookup.cc |
diff --git a/src/lookup.cc b/src/lookup.cc |
index 3921e1657c8511b5de5a1d96b6f802ae1649bbf0..b6c0b92a1751fdb7711b4a6a8ab2466159db9f09 100644 |
--- a/src/lookup.cc |
+++ b/src/lookup.cc |
@@ -307,6 +307,11 @@ void LookupIterator::PrepareTransitionToDataProperty( |
PropertyAttributes attributes, Object::StoreFromKeyed store_mode) { |
DCHECK(receiver.is_identical_to(GetStoreTarget())); |
if (state_ == TRANSITION) return; |
+ |
+ if (!IsElement() && name()->IsPrivate()) { |
+ attributes = static_cast<PropertyAttributes>(attributes | DONT_ENUM); |
+ } |
+ |
DCHECK(state_ != LookupIterator::ACCESSOR || |
(GetAccessors()->IsAccessorInfo() && |
AccessorInfo::cast(*GetAccessors())->is_special_data_property())); |
@@ -441,6 +446,9 @@ void LookupIterator::TransitionToAccessorProperty( |
// handled via a trap. Adding properties to primitive values is not |
// observable. |
Handle<JSObject> receiver = GetStoreTarget(); |
+ if (!IsElement() && name()->IsPrivate()) { |
+ attributes = static_cast<PropertyAttributes>(attributes | DONT_ENUM); |
+ } |
if (!IsElement() && !receiver->map()->is_dictionary_map()) { |
Handle<Map> old_map(receiver->map(), isolate_); |