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); |