[runtime] We don't need an actual instance type for JSIteratorResult.
It's fine to use JS_OBJECT_TYPE for JSIteratorResult and only have a preallocated initial map for them to avoid unnecessary polymorphism from generators / builtin iterators. The instance type doesn't provide any advantage, since we always have to treat JSIteratorResult objects as regular JSObjects later. R=yangguo@chromium.org TBR=hpayer@chromium.org Review URL: https://codereview.chromium.org/1680513002 Cr-Commit-Position: refs/heads/master@{#33800}
This commit is contained in:
parent
c404c4ed46
commit
f3b0dbb5e7
@ -1575,7 +1575,7 @@ void Genesis::InitializeGlobal(Handle<JSGlobalObject> global_object,
|
|||||||
|
|
||||||
{ // -- I t e r a t o r R e s u l t
|
{ // -- I t e r a t o r R e s u l t
|
||||||
Handle<Map> map =
|
Handle<Map> map =
|
||||||
factory->NewMap(JS_ITERATOR_RESULT_TYPE, JSIteratorResult::kSize);
|
factory->NewMap(JS_OBJECT_TYPE, JSIteratorResult::kSize);
|
||||||
Map::SetPrototype(map, isolate->initial_object_prototype());
|
Map::SetPrototype(map, isolate->initial_object_prototype());
|
||||||
Map::EnsureDescriptorSlack(map, 2);
|
Map::EnsureDescriptorSlack(map, 2);
|
||||||
|
|
||||||
|
@ -1827,7 +1827,7 @@ HValue* HGraphBuilder::BuildCreateIterResultObject(HValue* value,
|
|||||||
// Allocate the JSIteratorResult object.
|
// Allocate the JSIteratorResult object.
|
||||||
HValue* result =
|
HValue* result =
|
||||||
Add<HAllocate>(Add<HConstant>(JSIteratorResult::kSize), HType::JSObject(),
|
Add<HAllocate>(Add<HConstant>(JSIteratorResult::kSize), HType::JSObject(),
|
||||||
NOT_TENURED, JS_ITERATOR_RESULT_TYPE);
|
NOT_TENURED, JS_OBJECT_TYPE);
|
||||||
|
|
||||||
// Initialize the JSIteratorResult object.
|
// Initialize the JSIteratorResult object.
|
||||||
HValue* native_context = BuildGetNativeContext();
|
HValue* native_context = BuildGetNativeContext();
|
||||||
|
@ -1737,16 +1737,6 @@ Handle<JSSetIterator> Factory::NewJSSetIterator() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Handle<JSIteratorResult> Factory::NewJSIteratorResult(Handle<Object> value,
|
|
||||||
Handle<Object> done) {
|
|
||||||
Handle<JSIteratorResult> result = Handle<JSIteratorResult>::cast(
|
|
||||||
NewJSObjectFromMap(isolate()->iterator_result_map()));
|
|
||||||
result->set_value(*value);
|
|
||||||
result->set_done(*done);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
ElementsKind GetExternalArrayElementsKind(ExternalArrayType type) {
|
ElementsKind GetExternalArrayElementsKind(ExternalArrayType type) {
|
||||||
|
@ -469,11 +469,6 @@ class Factory final {
|
|||||||
Handle<JSMapIterator> NewJSMapIterator();
|
Handle<JSMapIterator> NewJSMapIterator();
|
||||||
Handle<JSSetIterator> NewJSSetIterator();
|
Handle<JSSetIterator> NewJSSetIterator();
|
||||||
|
|
||||||
// Creates a new JSIteratorResult object with the arguments {value} and
|
|
||||||
// {done}. Implemented according to ES6 section 7.4.7 CreateIterResultObject.
|
|
||||||
Handle<JSIteratorResult> NewJSIteratorResult(Handle<Object> value,
|
|
||||||
Handle<Object> done);
|
|
||||||
|
|
||||||
// Allocates a bound function.
|
// Allocates a bound function.
|
||||||
MaybeHandle<JSBoundFunction> NewJSBoundFunction(
|
MaybeHandle<JSBoundFunction> NewJSBoundFunction(
|
||||||
Handle<JSReceiver> target_function, Handle<Object> bound_this,
|
Handle<JSReceiver> target_function, Handle<Object> bound_this,
|
||||||
|
@ -118,7 +118,6 @@ StaticVisitorBase::VisitorId StaticVisitorBase::GetVisitorId(
|
|||||||
case JS_MAP_TYPE:
|
case JS_MAP_TYPE:
|
||||||
case JS_SET_ITERATOR_TYPE:
|
case JS_SET_ITERATOR_TYPE:
|
||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
case JS_PROMISE_TYPE:
|
case JS_PROMISE_TYPE:
|
||||||
case JS_BOUND_FUNCTION_TYPE:
|
case JS_BOUND_FUNCTION_TYPE:
|
||||||
return GetVisitorIdForSize(kVisitJSObject, kVisitJSObjectGeneric,
|
return GetVisitorIdForSize(kVisitJSObject, kVisitJSObjectGeneric,
|
||||||
|
@ -469,7 +469,6 @@ ReturnType BodyDescriptorApply(InstanceType type, T1 p1, T2 p2, T3 p3) {
|
|||||||
case JS_MAP_TYPE:
|
case JS_MAP_TYPE:
|
||||||
case JS_SET_ITERATOR_TYPE:
|
case JS_SET_ITERATOR_TYPE:
|
||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
case JS_REGEXP_TYPE:
|
case JS_REGEXP_TYPE:
|
||||||
case JS_GLOBAL_PROXY_TYPE:
|
case JS_GLOBAL_PROXY_TYPE:
|
||||||
case JS_GLOBAL_OBJECT_TYPE:
|
case JS_GLOBAL_OBJECT_TYPE:
|
||||||
|
@ -150,9 +150,6 @@ void HeapObject::HeapObjectVerify() {
|
|||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
JSMapIterator::cast(this)->JSMapIteratorVerify();
|
JSMapIterator::cast(this)->JSMapIteratorVerify();
|
||||||
break;
|
break;
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
JSIteratorResult::cast(this)->JSIteratorResultVerify();
|
|
||||||
break;
|
|
||||||
case JS_WEAK_MAP_TYPE:
|
case JS_WEAK_MAP_TYPE:
|
||||||
JSWeakMap::cast(this)->JSWeakMapVerify();
|
JSWeakMap::cast(this)->JSWeakMapVerify();
|
||||||
break;
|
break;
|
||||||
@ -764,14 +761,6 @@ void JSMapIterator::JSMapIteratorVerify() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void JSIteratorResult::JSIteratorResultVerify() {
|
|
||||||
CHECK(IsJSIteratorResult());
|
|
||||||
JSObjectVerify();
|
|
||||||
VerifyPointer(done());
|
|
||||||
VerifyPointer(value());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void JSWeakMap::JSWeakMapVerify() {
|
void JSWeakMap::JSWeakMapVerify() {
|
||||||
CHECK(IsJSWeakMap());
|
CHECK(IsJSWeakMap());
|
||||||
JSObjectVerify();
|
JSObjectVerify();
|
||||||
|
@ -710,7 +710,6 @@ TYPE_CHECKER(JSSet, JS_SET_TYPE)
|
|||||||
TYPE_CHECKER(JSMap, JS_MAP_TYPE)
|
TYPE_CHECKER(JSMap, JS_MAP_TYPE)
|
||||||
TYPE_CHECKER(JSSetIterator, JS_SET_ITERATOR_TYPE)
|
TYPE_CHECKER(JSSetIterator, JS_SET_ITERATOR_TYPE)
|
||||||
TYPE_CHECKER(JSMapIterator, JS_MAP_ITERATOR_TYPE)
|
TYPE_CHECKER(JSMapIterator, JS_MAP_ITERATOR_TYPE)
|
||||||
TYPE_CHECKER(JSIteratorResult, JS_ITERATOR_RESULT_TYPE)
|
|
||||||
TYPE_CHECKER(JSWeakMap, JS_WEAK_MAP_TYPE)
|
TYPE_CHECKER(JSWeakMap, JS_WEAK_MAP_TYPE)
|
||||||
TYPE_CHECKER(JSWeakSet, JS_WEAK_SET_TYPE)
|
TYPE_CHECKER(JSWeakSet, JS_WEAK_SET_TYPE)
|
||||||
TYPE_CHECKER(JSContextExtensionObject, JS_CONTEXT_EXTENSION_OBJECT_TYPE)
|
TYPE_CHECKER(JSContextExtensionObject, JS_CONTEXT_EXTENSION_OBJECT_TYPE)
|
||||||
@ -2112,8 +2111,6 @@ int JSObject::GetHeaderSize(InstanceType type) {
|
|||||||
return JSSetIterator::kSize;
|
return JSSetIterator::kSize;
|
||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
return JSMapIterator::kSize;
|
return JSMapIterator::kSize;
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
return JSIteratorResult::kSize;
|
|
||||||
case JS_WEAK_MAP_TYPE:
|
case JS_WEAK_MAP_TYPE:
|
||||||
return JSWeakMap::kSize;
|
return JSWeakMap::kSize;
|
||||||
case JS_WEAK_SET_TYPE:
|
case JS_WEAK_SET_TYPE:
|
||||||
@ -3216,7 +3213,6 @@ CAST_ACCESSOR(JSReceiver)
|
|||||||
CAST_ACCESSOR(JSRegExp)
|
CAST_ACCESSOR(JSRegExp)
|
||||||
CAST_ACCESSOR(JSSet)
|
CAST_ACCESSOR(JSSet)
|
||||||
CAST_ACCESSOR(JSSetIterator)
|
CAST_ACCESSOR(JSSetIterator)
|
||||||
CAST_ACCESSOR(JSIteratorResult)
|
|
||||||
CAST_ACCESSOR(JSTypedArray)
|
CAST_ACCESSOR(JSTypedArray)
|
||||||
CAST_ACCESSOR(JSValue)
|
CAST_ACCESSOR(JSValue)
|
||||||
CAST_ACCESSOR(JSWeakMap)
|
CAST_ACCESSOR(JSWeakMap)
|
||||||
@ -7738,10 +7734,6 @@ Object* JSMapIterator::CurrentValue() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ACCESSORS(JSIteratorResult, done, Object, kDoneOffset)
|
|
||||||
ACCESSORS(JSIteratorResult, value, Object, kValueOffset)
|
|
||||||
|
|
||||||
|
|
||||||
String::SubStringRange::SubStringRange(String* string, int first, int length)
|
String::SubStringRange::SubStringRange(String* string, int first, int length)
|
||||||
: string_(string),
|
: string_(string),
|
||||||
first_(first),
|
first_(first),
|
||||||
|
@ -146,9 +146,6 @@ void HeapObject::HeapObjectPrint(std::ostream& os) { // NOLINT
|
|||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
JSMapIterator::cast(this)->JSMapIteratorPrint(os);
|
JSMapIterator::cast(this)->JSMapIteratorPrint(os);
|
||||||
break;
|
break;
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
JSIteratorResult::cast(this)->JSIteratorResultPrint(os);
|
|
||||||
break;
|
|
||||||
case JS_WEAK_MAP_TYPE:
|
case JS_WEAK_MAP_TYPE:
|
||||||
JSWeakMap::cast(this)->JSWeakMapPrint(os);
|
JSWeakMap::cast(this)->JSWeakMapPrint(os);
|
||||||
break;
|
break;
|
||||||
@ -800,14 +797,6 @@ void JSMapIterator::JSMapIteratorPrint(std::ostream& os) { // NOLINT
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void JSIteratorResult::JSIteratorResultPrint(std::ostream& os) { // NOLINT
|
|
||||||
JSObjectPrintHeader(os, this, "JSIteratorResult");
|
|
||||||
os << "\n - done = " << Brief(done());
|
|
||||||
os << "\n - value = " << Brief(value());
|
|
||||||
os << "\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void JSWeakMap::JSWeakMapPrint(std::ostream& os) { // NOLINT
|
void JSWeakMap::JSWeakMapPrint(std::ostream& os) { // NOLINT
|
||||||
JSObjectPrintHeader(os, this, "JSWeakMap");
|
JSObjectPrintHeader(os, this, "JSWeakMap");
|
||||||
os << "\n - table = " << Brief(table());
|
os << "\n - table = " << Brief(table());
|
||||||
|
@ -13078,7 +13078,6 @@ bool CanSubclassHaveInobjectProperties(InstanceType instance_type) {
|
|||||||
case JS_MAP_TYPE:
|
case JS_MAP_TYPE:
|
||||||
case JS_SET_ITERATOR_TYPE:
|
case JS_SET_ITERATOR_TYPE:
|
||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
case JS_WEAK_MAP_TYPE:
|
case JS_WEAK_MAP_TYPE:
|
||||||
case JS_WEAK_SET_TYPE:
|
case JS_WEAK_SET_TYPE:
|
||||||
case JS_PROMISE_TYPE:
|
case JS_PROMISE_TYPE:
|
||||||
|
@ -429,7 +429,6 @@ const int kStubMinorKeyBits = kSmiValueSize - kStubMajorKeyBits - 1;
|
|||||||
V(JS_MAP_TYPE) \
|
V(JS_MAP_TYPE) \
|
||||||
V(JS_SET_ITERATOR_TYPE) \
|
V(JS_SET_ITERATOR_TYPE) \
|
||||||
V(JS_MAP_ITERATOR_TYPE) \
|
V(JS_MAP_ITERATOR_TYPE) \
|
||||||
V(JS_ITERATOR_RESULT_TYPE) \
|
|
||||||
V(JS_WEAK_MAP_TYPE) \
|
V(JS_WEAK_MAP_TYPE) \
|
||||||
V(JS_WEAK_SET_TYPE) \
|
V(JS_WEAK_SET_TYPE) \
|
||||||
V(JS_PROMISE_TYPE) \
|
V(JS_PROMISE_TYPE) \
|
||||||
@ -723,7 +722,6 @@ enum InstanceType {
|
|||||||
JS_MAP_TYPE,
|
JS_MAP_TYPE,
|
||||||
JS_SET_ITERATOR_TYPE,
|
JS_SET_ITERATOR_TYPE,
|
||||||
JS_MAP_ITERATOR_TYPE,
|
JS_MAP_ITERATOR_TYPE,
|
||||||
JS_ITERATOR_RESULT_TYPE,
|
|
||||||
JS_WEAK_MAP_TYPE,
|
JS_WEAK_MAP_TYPE,
|
||||||
JS_WEAK_SET_TYPE,
|
JS_WEAK_SET_TYPE,
|
||||||
JS_PROMISE_TYPE,
|
JS_PROMISE_TYPE,
|
||||||
@ -963,7 +961,6 @@ template <class C> inline bool Is(Object* obj);
|
|||||||
V(JSMap) \
|
V(JSMap) \
|
||||||
V(JSSetIterator) \
|
V(JSSetIterator) \
|
||||||
V(JSMapIterator) \
|
V(JSMapIterator) \
|
||||||
V(JSIteratorResult) \
|
|
||||||
V(JSWeakCollection) \
|
V(JSWeakCollection) \
|
||||||
V(JSWeakMap) \
|
V(JSWeakMap) \
|
||||||
V(JSWeakSet) \
|
V(JSWeakSet) \
|
||||||
@ -2604,6 +2601,24 @@ class JSDataPropertyDescriptor: public JSObject {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// JSIteratorResult is just a JSObject with a specific initial map.
|
||||||
|
// This initial map adds in-object properties for "done" and "value,
|
||||||
|
// as specified by ES6 section 25.1.1.3 The IteratorResult Interface
|
||||||
|
class JSIteratorResult: public JSObject {
|
||||||
|
public:
|
||||||
|
// Offsets of object fields.
|
||||||
|
static const int kValueOffset = JSObject::kHeaderSize;
|
||||||
|
static const int kDoneOffset = kValueOffset + kPointerSize;
|
||||||
|
static const int kSize = kDoneOffset + kPointerSize;
|
||||||
|
// Indices of in-object properties.
|
||||||
|
static const int kValueIndex = 0;
|
||||||
|
static const int kDoneIndex = 1;
|
||||||
|
|
||||||
|
private:
|
||||||
|
DISALLOW_IMPLICIT_CONSTRUCTORS(JSIteratorResult);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// Common superclass for FixedArrays that allow implementations to share
|
// Common superclass for FixedArrays that allow implementations to share
|
||||||
// common accessors and some code paths.
|
// common accessors and some code paths.
|
||||||
class FixedArrayBase: public HeapObject {
|
class FixedArrayBase: public HeapObject {
|
||||||
@ -9884,40 +9899,6 @@ class JSMapIterator: public OrderedHashTableIterator<JSMapIterator,
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// ES6 section 25.1.1.3 The IteratorResult Interface
|
|
||||||
class JSIteratorResult final : public JSObject {
|
|
||||||
public:
|
|
||||||
// [done]: This is the result status of an iterator next method call. If the
|
|
||||||
// end of the iterator was reached done is true. If the end was not reached
|
|
||||||
// done is false and a [value] is available.
|
|
||||||
DECL_ACCESSORS(done, Object)
|
|
||||||
|
|
||||||
// [value]: If [done] is false, this is the current iteration element value.
|
|
||||||
// If [done] is true, this is the return value of the iterator, if it supplied
|
|
||||||
// one. If the iterator does not have a return value, value is undefined.
|
|
||||||
// In that case, the value property may be absent from the conforming object
|
|
||||||
// if it does not inherit an explicit value property.
|
|
||||||
DECL_ACCESSORS(value, Object)
|
|
||||||
|
|
||||||
// Dispatched behavior.
|
|
||||||
DECLARE_PRINTER(JSIteratorResult)
|
|
||||||
DECLARE_VERIFIER(JSIteratorResult)
|
|
||||||
|
|
||||||
DECLARE_CAST(JSIteratorResult)
|
|
||||||
|
|
||||||
static const int kValueOffset = JSObject::kHeaderSize;
|
|
||||||
static const int kDoneOffset = kValueOffset + kPointerSize;
|
|
||||||
static const int kSize = kDoneOffset + kPointerSize;
|
|
||||||
|
|
||||||
// Indices of in-object properties.
|
|
||||||
static const int kValueIndex = 0;
|
|
||||||
static const int kDoneIndex = 1;
|
|
||||||
|
|
||||||
private:
|
|
||||||
DISALLOW_IMPLICIT_CONSTRUCTORS(JSIteratorResult);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// Base class for both JSWeakMap and JSWeakSet
|
// Base class for both JSWeakMap and JSWeakSet
|
||||||
class JSWeakCollection: public JSObject {
|
class JSWeakCollection: public JSObject {
|
||||||
public:
|
public:
|
||||||
|
@ -1270,7 +1270,11 @@ RUNTIME_FUNCTION(Runtime_CreateIterResultObject) {
|
|||||||
DCHECK_EQ(2, args.length());
|
DCHECK_EQ(2, args.length());
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, value, 0);
|
CONVERT_ARG_HANDLE_CHECKED(Object, value, 0);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, done, 1);
|
CONVERT_ARG_HANDLE_CHECKED(Object, done, 1);
|
||||||
return *isolate->factory()->NewJSIteratorResult(value, done);
|
Handle<JSObject> result =
|
||||||
|
isolate->factory()->NewJSObjectFromMap(isolate->iterator_result_map());
|
||||||
|
result->InObjectPropertyAtPut(JSIteratorResult::kValueIndex, *value);
|
||||||
|
result->InObjectPropertyAtPut(JSIteratorResult::kDoneIndex, *done);
|
||||||
|
return *result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -215,7 +215,6 @@ Type::bitset BitsetType::Lub(i::Map* map) {
|
|||||||
case JS_MAP_TYPE:
|
case JS_MAP_TYPE:
|
||||||
case JS_SET_ITERATOR_TYPE:
|
case JS_SET_ITERATOR_TYPE:
|
||||||
case JS_MAP_ITERATOR_TYPE:
|
case JS_MAP_ITERATOR_TYPE:
|
||||||
case JS_ITERATOR_RESULT_TYPE:
|
|
||||||
case JS_WEAK_MAP_TYPE:
|
case JS_WEAK_MAP_TYPE:
|
||||||
case JS_WEAK_SET_TYPE:
|
case JS_WEAK_SET_TYPE:
|
||||||
case JS_PROMISE_TYPE:
|
case JS_PROMISE_TYPE:
|
||||||
|
Loading…
Reference in New Issue
Block a user