| Index: src/heap.cc
|
| diff --git a/src/heap.cc b/src/heap.cc
|
| index 6b2f8f7a1cf9f1a9847163468118510ecef64d33..f4578831c877c2782fed75435253db2676988d84 100644
|
| --- a/src/heap.cc
|
| +++ b/src/heap.cc
|
| @@ -3871,7 +3871,7 @@ MaybeObject* Heap::AllocateExternalStringFromAscii(
|
| const ExternalAsciiString::Resource* resource) {
|
| size_t length = resource->length();
|
| if (length > static_cast<size_t>(String::kMaxLength)) {
|
| - v8::internal::Heap::FatalProcessOutOfMemory("invalid string length", true);
|
| + return isolate()->ThrowInvalidStringLength();
|
| }
|
|
|
| Map* map = external_ascii_string_map();
|
| @@ -3893,7 +3893,7 @@ MaybeObject* Heap::AllocateExternalStringFromTwoByte(
|
| const ExternalTwoByteString::Resource* resource) {
|
| size_t length = resource->length();
|
| if (length > static_cast<size_t>(String::kMaxLength)) {
|
| - v8::internal::Heap::FatalProcessOutOfMemory("invalid string length", true);
|
| + return isolate()->ThrowInvalidStringLength();
|
| }
|
|
|
| // For small strings we check whether the resource contains only
|
| @@ -4978,8 +4978,8 @@ MaybeObject* Heap::AllocateInternalizedStringImpl(
|
| int size;
|
| Map* map;
|
|
|
| - if (chars > String::kMaxLength) {
|
| - v8::internal::Heap::FatalProcessOutOfMemory("invalid string length", true);
|
| + if (chars < 0 || chars > String::kMaxLength) {
|
| + return isolate()->ThrowInvalidStringLength();
|
| }
|
| if (is_one_byte) {
|
| map = ascii_internalized_string_map();
|
| @@ -5027,7 +5027,7 @@ MaybeObject* Heap::AllocateInternalizedStringImpl<false>(
|
| MaybeObject* Heap::AllocateRawOneByteString(int length,
|
| PretenureFlag pretenure) {
|
| if (length < 0 || length > String::kMaxLength) {
|
| - v8::internal::Heap::FatalProcessOutOfMemory("invalid string length", true);
|
| + return isolate()->ThrowInvalidStringLength();
|
| }
|
| int size = SeqOneByteString::SizeFor(length);
|
| ASSERT(size <= SeqOneByteString::kMaxSize);
|
| @@ -5051,7 +5051,7 @@ MaybeObject* Heap::AllocateRawOneByteString(int length,
|
| MaybeObject* Heap::AllocateRawTwoByteString(int length,
|
| PretenureFlag pretenure) {
|
| if (length < 0 || length > String::kMaxLength) {
|
| - v8::internal::Heap::FatalProcessOutOfMemory("invalid string length", true);
|
| + return isolate()->ThrowInvalidStringLength();
|
| }
|
| int size = SeqTwoByteString::SizeFor(length);
|
| ASSERT(size <= SeqTwoByteString::kMaxSize);
|
|
|