| Index: src/objects.h
|
| diff --git a/src/objects.h b/src/objects.h
|
| index 4eb4539af116cb7715d60e15a8420a1822b4d0e0..94ec8cb89570a64d50a127799944ccfc80920ded 100644
|
| --- a/src/objects.h
|
| +++ b/src/objects.h
|
| @@ -863,8 +863,8 @@ enum CompareResult {
|
| inline void set_##name(type* value, \
|
| WriteBarrierMode mode = UPDATE_WRITE_BARRIER); \
|
|
|
| -
|
| class AccessorPair;
|
| +class AllocationSiteContext;
|
| class DictionaryElementsAccessor;
|
| class ElementsAccessor;
|
| class Failure;
|
| @@ -2541,8 +2541,13 @@ class JSObject: public JSReceiver {
|
| MUST_USE_RESULT MaybeObject* SetObserved(Isolate* isolate);
|
|
|
| // Copy object.
|
| + static Handle<JSObject> Copy(Handle<JSObject> object,
|
| + AllocationSiteContext* site_context);
|
| static Handle<JSObject> Copy(Handle<JSObject> object);
|
| - static Handle<JSObject> DeepCopy(Handle<JSObject> object);
|
| + static Handle<JSObject> DeepCopy(Handle<JSObject> object,
|
| + AllocationSiteContext* site_context);
|
| + static Handle<JSObject> DeepWalk(Handle<JSObject> object,
|
| + AllocationSiteContext* site_context);
|
|
|
| // Casting.
|
| static inline JSObject* cast(Object* obj);
|
| @@ -7908,8 +7913,15 @@ class AllocationSite: public Struct {
|
|
|
| inline void Initialize();
|
|
|
| + bool HasNestedSites() {
|
| + return nested_site()->IsAllocationSite();
|
| + }
|
| +
|
| + // This method is expensive, it should only be called for reporting.
|
| + bool IsNestedSite();
|
| +
|
| ElementsKind GetElementsKind() {
|
| - ASSERT(!IsLiteralSite());
|
| + ASSERT(!SitePointsToLiteral());
|
| return static_cast<ElementsKind>(Smi::cast(transition_info())->value());
|
| }
|
|
|
| @@ -7917,11 +7929,11 @@ class AllocationSite: public Struct {
|
| set_transition_info(Smi::FromInt(static_cast<int>(kind)));
|
| }
|
|
|
| - bool IsLiteralSite() {
|
| + bool SitePointsToLiteral() {
|
| // If transition_info is a smi, then it represents an ElementsKind
|
| // for a constructed array. Otherwise, it must be a boilerplate
|
| - // for an array literal
|
| - return transition_info()->IsJSArray();
|
| + // for an object or array literal.
|
| + return transition_info()->IsJSArray() || transition_info()->IsJSObject();
|
| }
|
|
|
| DECLARE_PRINTER(AllocationSite)
|
|
|