literal-objects-inl.h 4.46 KB
Newer Older
1 2 3 4
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

5 6
#ifndef V8_OBJECTS_LITERAL_OBJECTS_INL_H_
#define V8_OBJECTS_LITERAL_OBJECTS_INL_H_
7 8 9

#include "src/objects/literal-objects.h"

10
#include "src/objects/objects-inl.h"
11

12 13 14 15 16 17
// Has to be the last include (doesn't have include guards):
#include "src/objects/object-macros.h"

namespace v8 {
namespace internal {

18 19 20 21
//
// ObjectBoilerplateDescription
//

22
OBJECT_CONSTRUCTORS_IMPL(ObjectBoilerplateDescription, FixedArray)
23

24 25
CAST_ACCESSOR(ObjectBoilerplateDescription)

26
SMI_ACCESSORS(ObjectBoilerplateDescription, flags,
27
              FixedArray::OffsetOfElementAt(kLiteralTypeOffset))
28

29
Object ObjectBoilerplateDescription::name(int index) const {
30
  const Isolate* isolate = GetIsolateForPtrCompr(*this);
31 32 33
  return name(isolate, index);
}

34 35
Object ObjectBoilerplateDescription::name(const Isolate* isolate,
                                          int index) const {
36 37 38 39 40 41 42
  // get() already checks for out of bounds access, but we do not want to allow
  // access to the last element, if it is the number of properties.
  DCHECK_NE(size(), index);
  return get(isolate, 2 * index + kDescriptionStartIndex);
}

Object ObjectBoilerplateDescription::value(int index) const {
43
  const Isolate* isolate = GetIsolateForPtrCompr(*this);
44 45 46
  return value(isolate, index);
}

47 48
Object ObjectBoilerplateDescription::value(const Isolate* isolate,
                                           int index) const {
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
  return get(isolate, 2 * index + 1 + kDescriptionStartIndex);
}

void ObjectBoilerplateDescription::set_key_value(int index, Object key,
                                                 Object value) {
  DCHECK_LT(index, size());
  DCHECK_GE(index, 0);
  set(2 * index + kDescriptionStartIndex, key);
  set(2 * index + 1 + kDescriptionStartIndex, value);
}

int ObjectBoilerplateDescription::size() const {
  DCHECK_EQ(0, (length() - kDescriptionStartIndex -
                (this->has_number_of_properties() ? 1 : 0)) %
                   2);
  // Rounding is intended.
  return (length() - kDescriptionStartIndex) / 2;
}

bool ObjectBoilerplateDescription::has_number_of_properties() const {
  return (length() - kDescriptionStartIndex) % 2 != 0;
}

int ObjectBoilerplateDescription::backing_store_size() const {
  if (has_number_of_properties()) {
    // If present, the last entry contains the number of properties.
    return Smi::ToInt(this->get(length() - 1));
  }
  // If the number is not given explicitly, we assume there are no
  // properties with computed names.
  return size();
}

void ObjectBoilerplateDescription::set_backing_store_size(
    int backing_store_size) {
  DCHECK(has_number_of_properties());
  DCHECK_NE(size(), backing_store_size);
  CHECK(Smi::IsValid(backing_store_size));
  // TODO(ishell): move this value to the header
  set(length() - 1, Smi::FromInt(backing_store_size));
}

//
// ClassBoilerplate
//

95
OBJECT_CONSTRUCTORS_IMPL(ClassBoilerplate, FixedArray)
96
CAST_ACCESSOR(ClassBoilerplate)
97

98 99
SMI_ACCESSORS(ClassBoilerplate, arguments_count,
              FixedArray::OffsetOfElementAt(kArgumentsCountIndex))
100 101

ACCESSORS(ClassBoilerplate, static_properties_template, Object,
102
          FixedArray::OffsetOfElementAt(kClassPropertiesTemplateIndex))
103 104

ACCESSORS(ClassBoilerplate, static_elements_template, Object,
105
          FixedArray::OffsetOfElementAt(kClassElementsTemplateIndex))
106

107
ACCESSORS(ClassBoilerplate, static_computed_properties, FixedArray,
108
          FixedArray::OffsetOfElementAt(kClassComputedPropertiesIndex))
109 110

ACCESSORS(ClassBoilerplate, instance_properties_template, Object,
111
          FixedArray::OffsetOfElementAt(kPrototypePropertiesTemplateIndex))
112 113

ACCESSORS(ClassBoilerplate, instance_elements_template, Object,
114
          FixedArray::OffsetOfElementAt(kPrototypeElementsTemplateIndex))
115

116
ACCESSORS(ClassBoilerplate, instance_computed_properties, FixedArray,
117
          FixedArray::OffsetOfElementAt(kPrototypeComputedPropertiesIndex))
118

119 120 121 122
//
// ArrayBoilerplateDescription
//

123
TQ_OBJECT_CONSTRUCTORS_IMPL(ArrayBoilerplateDescription)
124

125 126 127 128 129 130 131 132 133
ElementsKind ArrayBoilerplateDescription::elements_kind() const {
  return static_cast<ElementsKind>(flags());
}

void ArrayBoilerplateDescription::set_elements_kind(ElementsKind kind) {
  set_flags(kind);
}

bool ArrayBoilerplateDescription::is_empty() const {
134
  return constant_elements().length() == 0;
135
}
136

137 138 139 140 141
}  // namespace internal
}  // namespace v8

#include "src/objects/object-macros-undef.h"

142
#endif  // V8_OBJECTS_LITERAL_OBJECTS_INL_H_