| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 2972 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2983 ZoneScope zonescope(zone, DELETE_ON_EXIT); | 2983 ZoneScope zonescope(zone, DELETE_ON_EXIT); |
| 2984 CompiledReplacement compiled_replacement(zone); | 2984 CompiledReplacement compiled_replacement(zone); |
| 2985 bool simple_replace = compiled_replacement.Compile(replacement, | 2985 bool simple_replace = compiled_replacement.Compile(replacement, |
| 2986 capture_count, | 2986 capture_count, |
| 2987 subject_length); | 2987 subject_length); |
| 2988 | 2988 |
| 2989 // Shortcut for simple non-regexp global replacements | 2989 // Shortcut for simple non-regexp global replacements |
| 2990 if (is_global && | 2990 if (is_global && |
| 2991 regexp->TypeTag() == JSRegExp::ATOM && | 2991 regexp->TypeTag() == JSRegExp::ATOM && |
| 2992 simple_replace) { | 2992 simple_replace) { |
| 2993 if (subject->HasOnlyAsciiChars() && replacement->HasOnlyAsciiChars()) { | 2993 if (subject->IsOneByteConvertible() && |
| 2994 replacement->IsOneByteConvertible()) { |
| 2994 return StringReplaceAtomRegExpWithString<SeqOneByteString>( | 2995 return StringReplaceAtomRegExpWithString<SeqOneByteString>( |
| 2995 isolate, subject, regexp, replacement, last_match_info); | 2996 isolate, subject, regexp, replacement, last_match_info); |
| 2996 } else { | 2997 } else { |
| 2997 return StringReplaceAtomRegExpWithString<SeqTwoByteString>( | 2998 return StringReplaceAtomRegExpWithString<SeqTwoByteString>( |
| 2998 isolate, subject, regexp, replacement, last_match_info); | 2999 isolate, subject, regexp, replacement, last_match_info); |
| 2999 } | 3000 } |
| 3000 } | 3001 } |
| 3001 | 3002 |
| 3002 RegExpImpl::GlobalCache global_cache(regexp, subject, is_global, isolate); | 3003 RegExpImpl::GlobalCache global_cache(regexp, subject, is_global, isolate); |
| 3003 if (global_cache.HasException()) return Failure::Exception(); | 3004 if (global_cache.HasException()) return Failure::Exception(); |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3074 Handle<JSRegExp> regexp, | 3075 Handle<JSRegExp> regexp, |
| 3075 Handle<JSArray> last_match_info) { | 3076 Handle<JSArray> last_match_info) { |
| 3076 ASSERT(subject->IsFlat()); | 3077 ASSERT(subject->IsFlat()); |
| 3077 | 3078 |
| 3078 bool is_global = regexp->GetFlags().is_global(); | 3079 bool is_global = regexp->GetFlags().is_global(); |
| 3079 | 3080 |
| 3080 // Shortcut for simple non-regexp global replacements | 3081 // Shortcut for simple non-regexp global replacements |
| 3081 if (is_global && | 3082 if (is_global && |
| 3082 regexp->TypeTag() == JSRegExp::ATOM) { | 3083 regexp->TypeTag() == JSRegExp::ATOM) { |
| 3083 Handle<String> empty_string = isolate->factory()->empty_string(); | 3084 Handle<String> empty_string = isolate->factory()->empty_string(); |
| 3084 if (subject->HasOnlyAsciiChars()) { | 3085 if (subject->IsOneByteRepresentation()) { |
| 3085 return StringReplaceAtomRegExpWithString<SeqOneByteString>( | 3086 return StringReplaceAtomRegExpWithString<SeqOneByteString>( |
| 3086 isolate, | 3087 isolate, |
| 3087 subject, | 3088 subject, |
| 3088 regexp, | 3089 regexp, |
| 3089 empty_string, | 3090 empty_string, |
| 3090 last_match_info); | 3091 last_match_info); |
| 3091 } else { | 3092 } else { |
| 3092 return StringReplaceAtomRegExpWithString<SeqTwoByteString>( | 3093 return StringReplaceAtomRegExpWithString<SeqTwoByteString>( |
| 3093 isolate, | 3094 isolate, |
| 3094 subject, | 3095 subject, |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3203 CONVERT_ARG_HANDLE_CHECKED(JSRegExp, regexp, 1); | 3204 CONVERT_ARG_HANDLE_CHECKED(JSRegExp, regexp, 1); |
| 3204 CONVERT_ARG_HANDLE_CHECKED(JSArray, last_match_info, 3); | 3205 CONVERT_ARG_HANDLE_CHECKED(JSArray, last_match_info, 3); |
| 3205 | 3206 |
| 3206 if (!subject->IsFlat()) subject = FlattenGetString(subject); | 3207 if (!subject->IsFlat()) subject = FlattenGetString(subject); |
| 3207 | 3208 |
| 3208 if (!replacement->IsFlat()) replacement = FlattenGetString(replacement); | 3209 if (!replacement->IsFlat()) replacement = FlattenGetString(replacement); |
| 3209 | 3210 |
| 3210 ASSERT(last_match_info->HasFastObjectElements()); | 3211 ASSERT(last_match_info->HasFastObjectElements()); |
| 3211 | 3212 |
| 3212 if (replacement->length() == 0) { | 3213 if (replacement->length() == 0) { |
| 3213 if (subject->HasOnlyAsciiChars()) { | 3214 if (subject->IsOneByteConvertible()) { |
| 3214 return StringReplaceRegExpWithEmptyString<SeqOneByteString>( | 3215 return StringReplaceRegExpWithEmptyString<SeqOneByteString>( |
| 3215 isolate, subject, regexp, last_match_info); | 3216 isolate, subject, regexp, last_match_info); |
| 3216 } else { | 3217 } else { |
| 3217 return StringReplaceRegExpWithEmptyString<SeqTwoByteString>( | 3218 return StringReplaceRegExpWithEmptyString<SeqTwoByteString>( |
| 3218 isolate, subject, regexp, last_match_info); | 3219 isolate, subject, regexp, last_match_info); |
| 3219 } | 3220 } |
| 3220 } | 3221 } |
| 3221 | 3222 |
| 3222 return StringReplaceRegExpWithString( | 3223 return StringReplaceRegExpWithString( |
| 3223 isolate, subject, regexp, replacement, last_match_info); | 3224 isolate, subject, regexp, replacement, last_match_info); |
| (...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3370 static int StringMatchBackwards(Vector<const schar> subject, | 3371 static int StringMatchBackwards(Vector<const schar> subject, |
| 3371 Vector<const pchar> pattern, | 3372 Vector<const pchar> pattern, |
| 3372 int idx) { | 3373 int idx) { |
| 3373 int pattern_length = pattern.length(); | 3374 int pattern_length = pattern.length(); |
| 3374 ASSERT(pattern_length >= 1); | 3375 ASSERT(pattern_length >= 1); |
| 3375 ASSERT(idx + pattern_length <= subject.length()); | 3376 ASSERT(idx + pattern_length <= subject.length()); |
| 3376 | 3377 |
| 3377 if (sizeof(schar) == 1 && sizeof(pchar) > 1) { | 3378 if (sizeof(schar) == 1 && sizeof(pchar) > 1) { |
| 3378 for (int i = 0; i < pattern_length; i++) { | 3379 for (int i = 0; i < pattern_length; i++) { |
| 3379 uc16 c = pattern[i]; | 3380 uc16 c = pattern[i]; |
| 3380 if (c > String::kMaxAsciiCharCode) { | 3381 if (c > String::kMaxOneByteCharCode) { |
| 3381 return -1; | 3382 return -1; |
| 3382 } | 3383 } |
| 3383 } | 3384 } |
| 3384 } | 3385 } |
| 3385 | 3386 |
| 3386 pchar pattern_first_char = pattern[0]; | 3387 pchar pattern_first_char = pattern[0]; |
| 3387 for (int i = idx; i >= 0; i--) { | 3388 for (int i = idx; i >= 0; i--) { |
| 3388 if (subject[i] != pattern_first_char) continue; | 3389 if (subject[i] != pattern_first_char) continue; |
| 3389 int j = 1; | 3390 int j = 1; |
| 3390 while (j < pattern_length) { | 3391 while (j < pattern_length) { |
| (...skipping 1860 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5251 } | 5252 } |
| 5252 | 5253 |
| 5253 | 5254 |
| 5254 RUNTIME_FUNCTION(MaybeObject*, Runtime_URIUnescape) { | 5255 RUNTIME_FUNCTION(MaybeObject*, Runtime_URIUnescape) { |
| 5255 NoHandleAllocation ha; | 5256 NoHandleAllocation ha; |
| 5256 ASSERT(args.length() == 1); | 5257 ASSERT(args.length() == 1); |
| 5257 CONVERT_ARG_CHECKED(String, source, 0); | 5258 CONVERT_ARG_CHECKED(String, source, 0); |
| 5258 | 5259 |
| 5259 source->TryFlatten(); | 5260 source->TryFlatten(); |
| 5260 | 5261 |
| 5261 bool ascii = true; | 5262 bool one_byte = true; |
| 5262 int length = source->length(); | 5263 int length = source->length(); |
| 5263 | 5264 |
| 5264 int unescaped_length = 0; | 5265 int unescaped_length = 0; |
| 5265 for (int i = 0; i < length; unescaped_length++) { | 5266 for (int i = 0; i < length; unescaped_length++) { |
| 5266 int step; | 5267 int step; |
| 5267 if (Unescape(source, i, length, &step) > String::kMaxAsciiCharCode) { | 5268 if (Unescape(source, i, length, &step) > String::kMaxOneByteCharCode) { |
| 5268 ascii = false; | 5269 one_byte = false; |
| 5269 } | 5270 } |
| 5270 i += step; | 5271 i += step; |
| 5271 } | 5272 } |
| 5272 | 5273 |
| 5273 // No length change implies no change. Return original string if no change. | 5274 // No length change implies no change. Return original string if no change. |
| 5274 if (unescaped_length == length) | 5275 if (unescaped_length == length) |
| 5275 return source; | 5276 return source; |
| 5276 | 5277 |
| 5277 Object* o; | 5278 Object* o; |
| 5278 { MaybeObject* maybe_o = | 5279 { MaybeObject* maybe_o = |
| 5279 ascii ? | 5280 one_byte ? |
| 5280 isolate->heap()->AllocateRawOneByteString(unescaped_length) : | 5281 isolate->heap()->AllocateRawOneByteString(unescaped_length) : |
| 5281 isolate->heap()->AllocateRawTwoByteString(unescaped_length); | 5282 isolate->heap()->AllocateRawTwoByteString(unescaped_length); |
| 5282 if (!maybe_o->ToObject(&o)) return maybe_o; | 5283 if (!maybe_o->ToObject(&o)) return maybe_o; |
| 5283 } | 5284 } |
| 5284 String* destination = String::cast(o); | 5285 String* destination = String::cast(o); |
| 5285 | 5286 |
| 5286 int dest_position = 0; | 5287 int dest_position = 0; |
| 5287 for (int i = 0; i < length; dest_position++) { | 5288 for (int i = 0; i < length; dest_position++) { |
| 5288 int step; | 5289 int step; |
| 5289 destination->Set(dest_position, Unescape(source, i, length, &step)); | 5290 destination->Set(dest_position, Unescape(source, i, length, &step)); |
| (...skipping 636 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5926 Isolate* isolate, | 5927 Isolate* isolate, |
| 5927 unibrow::Mapping<typename ConvertTraits::UnibrowConverter, 128>* mapping) { | 5928 unibrow::Mapping<typename ConvertTraits::UnibrowConverter, 128>* mapping) { |
| 5928 NoHandleAllocation ha; | 5929 NoHandleAllocation ha; |
| 5929 CONVERT_ARG_CHECKED(String, s, 0); | 5930 CONVERT_ARG_CHECKED(String, s, 0); |
| 5930 s = s->TryFlattenGetString(); | 5931 s = s->TryFlattenGetString(); |
| 5931 | 5932 |
| 5932 const int length = s->length(); | 5933 const int length = s->length(); |
| 5933 // Assume that the string is not empty; we need this assumption later | 5934 // Assume that the string is not empty; we need this assumption later |
| 5934 if (length == 0) return s; | 5935 if (length == 0) return s; |
| 5935 | 5936 |
| 5937 #ifndef ENABLE_LATIN_1 |
| 5936 // Simpler handling of ASCII strings. | 5938 // Simpler handling of ASCII strings. |
| 5937 // | 5939 // |
| 5938 // NOTE: This assumes that the upper/lower case of an ASCII | 5940 // NOTE: This assumes that the upper/lower case of an ASCII |
| 5939 // character is also ASCII. This is currently the case, but it | 5941 // character is also ASCII. This is currently the case, but it |
| 5940 // might break in the future if we implement more context and locale | 5942 // might break in the future if we implement more context and locale |
| 5941 // dependent upper/lower conversions. | 5943 // dependent upper/lower conversions. |
| 5942 if (s->IsSeqOneByteString()) { | 5944 if (s->IsSeqOneByteString()) { |
| 5943 Object* o; | 5945 Object* o; |
| 5944 { MaybeObject* maybe_o = isolate->heap()->AllocateRawOneByteString(length); | 5946 { MaybeObject* maybe_o = isolate->heap()->AllocateRawOneByteString(length); |
| 5945 if (!maybe_o->ToObject(&o)) return maybe_o; | 5947 if (!maybe_o->ToObject(&o)) return maybe_o; |
| 5946 } | 5948 } |
| 5947 SeqOneByteString* result = SeqOneByteString::cast(o); | 5949 SeqOneByteString* result = SeqOneByteString::cast(o); |
| 5948 bool has_changed_character = ConvertTraits::AsciiConverter::Convert( | 5950 bool has_changed_character = ConvertTraits::AsciiConverter::Convert( |
| 5949 result->GetChars(), SeqOneByteString::cast(s)->GetChars(), length); | 5951 result->GetChars(), SeqOneByteString::cast(s)->GetChars(), length); |
| 5950 return has_changed_character ? result : s; | 5952 return has_changed_character ? result : s; |
| 5951 } | 5953 } |
| 5954 #endif |
| 5952 | 5955 |
| 5953 Object* answer; | 5956 Object* answer; |
| 5954 { MaybeObject* maybe_answer = | 5957 { MaybeObject* maybe_answer = |
| 5955 ConvertCaseHelper(isolate, s, length, length, mapping); | 5958 ConvertCaseHelper(isolate, s, length, length, mapping); |
| 5956 if (!maybe_answer->ToObject(&answer)) return maybe_answer; | 5959 if (!maybe_answer->ToObject(&answer)) return maybe_answer; |
| 5957 } | 5960 } |
| 5958 if (answer->IsSmi()) { | 5961 if (answer->IsSmi()) { |
| 5959 // Retry with correct length. | 5962 // Retry with correct length. |
| 5960 { MaybeObject* maybe_answer = | 5963 { MaybeObject* maybe_answer = |
| 5961 ConvertCaseHelper(isolate, | 5964 ConvertCaseHelper(isolate, |
| (...skipping 492 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 6454 array_length = fixed_array->length(); | 6457 array_length = fixed_array->length(); |
| 6455 } | 6458 } |
| 6456 | 6459 |
| 6457 if (array_length == 0) { | 6460 if (array_length == 0) { |
| 6458 return isolate->heap()->empty_string(); | 6461 return isolate->heap()->empty_string(); |
| 6459 } else if (array_length == 1) { | 6462 } else if (array_length == 1) { |
| 6460 Object* first = fixed_array->get(0); | 6463 Object* first = fixed_array->get(0); |
| 6461 if (first->IsString()) return first; | 6464 if (first->IsString()) return first; |
| 6462 } | 6465 } |
| 6463 | 6466 |
| 6464 bool ascii = special->HasOnlyAsciiChars(); | 6467 bool one_byte = special->IsOneByteConvertible(); |
| 6465 int position = 0; | 6468 int position = 0; |
| 6466 for (int i = 0; i < array_length; i++) { | 6469 for (int i = 0; i < array_length; i++) { |
| 6467 int increment = 0; | 6470 int increment = 0; |
| 6468 Object* elt = fixed_array->get(i); | 6471 Object* elt = fixed_array->get(i); |
| 6469 if (elt->IsSmi()) { | 6472 if (elt->IsSmi()) { |
| 6470 // Smi encoding of position and length. | 6473 // Smi encoding of position and length. |
| 6471 int smi_value = Smi::cast(elt)->value(); | 6474 int smi_value = Smi::cast(elt)->value(); |
| 6472 int pos; | 6475 int pos; |
| 6473 int len; | 6476 int len; |
| 6474 if (smi_value > 0) { | 6477 if (smi_value > 0) { |
| (...skipping 20 matching lines...) Expand all Loading... |
| 6495 ASSERT(pos >= 0); | 6498 ASSERT(pos >= 0); |
| 6496 ASSERT(len >= 0); | 6499 ASSERT(len >= 0); |
| 6497 if (pos > special_length || len > special_length - pos) { | 6500 if (pos > special_length || len > special_length - pos) { |
| 6498 return isolate->Throw(isolate->heap()->illegal_argument_symbol()); | 6501 return isolate->Throw(isolate->heap()->illegal_argument_symbol()); |
| 6499 } | 6502 } |
| 6500 increment = len; | 6503 increment = len; |
| 6501 } else if (elt->IsString()) { | 6504 } else if (elt->IsString()) { |
| 6502 String* element = String::cast(elt); | 6505 String* element = String::cast(elt); |
| 6503 int element_length = element->length(); | 6506 int element_length = element->length(); |
| 6504 increment = element_length; | 6507 increment = element_length; |
| 6505 if (ascii && !element->HasOnlyAsciiChars()) { | 6508 if (one_byte && !element->IsOneByteConvertible()) { |
| 6506 ascii = false; | 6509 one_byte = false; |
| 6507 } | 6510 } |
| 6508 } else { | 6511 } else { |
| 6509 ASSERT(!elt->IsTheHole()); | 6512 ASSERT(!elt->IsTheHole()); |
| 6510 return isolate->Throw(isolate->heap()->illegal_argument_symbol()); | 6513 return isolate->Throw(isolate->heap()->illegal_argument_symbol()); |
| 6511 } | 6514 } |
| 6512 if (increment > String::kMaxLength - position) { | 6515 if (increment > String::kMaxLength - position) { |
| 6513 isolate->context()->mark_out_of_memory(); | 6516 isolate->context()->mark_out_of_memory(); |
| 6514 return Failure::OutOfMemoryException(); | 6517 return Failure::OutOfMemoryException(); |
| 6515 } | 6518 } |
| 6516 position += increment; | 6519 position += increment; |
| 6517 } | 6520 } |
| 6518 | 6521 |
| 6519 int length = position; | 6522 int length = position; |
| 6520 Object* object; | 6523 Object* object; |
| 6521 | 6524 |
| 6522 if (ascii) { | 6525 if (one_byte) { |
| 6523 { MaybeObject* maybe_object = | 6526 { MaybeObject* maybe_object = |
| 6524 isolate->heap()->AllocateRawOneByteString(length); | 6527 isolate->heap()->AllocateRawOneByteString(length); |
| 6525 if (!maybe_object->ToObject(&object)) return maybe_object; | 6528 if (!maybe_object->ToObject(&object)) return maybe_object; |
| 6526 } | 6529 } |
| 6527 SeqOneByteString* answer = SeqOneByteString::cast(object); | 6530 SeqOneByteString* answer = SeqOneByteString::cast(object); |
| 6528 StringBuilderConcatHelper(special, | 6531 StringBuilderConcatHelper(special, |
| 6529 answer->GetChars(), | 6532 answer->GetChars(), |
| 6530 fixed_array, | 6533 fixed_array, |
| 6531 array_length); | 6534 array_length); |
| 6532 return answer; | 6535 return answer; |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 6617 sink += separator_length; | 6620 sink += separator_length; |
| 6618 | 6621 |
| 6619 String* element = String::cast(fixed_array->get(i)); | 6622 String* element = String::cast(fixed_array->get(i)); |
| 6620 int element_length = element->length(); | 6623 int element_length = element->length(); |
| 6621 ASSERT(sink + element_length <= end); | 6624 ASSERT(sink + element_length <= end); |
| 6622 String::WriteToFlat(element, sink, 0, element_length); | 6625 String::WriteToFlat(element, sink, 0, element_length); |
| 6623 sink += element_length; | 6626 sink += element_length; |
| 6624 } | 6627 } |
| 6625 ASSERT(sink == end); | 6628 ASSERT(sink == end); |
| 6626 | 6629 |
| 6627 ASSERT(!answer->HasOnlyAsciiChars()); // Use %_FastAsciiArrayJoin instead. | 6630 // Use %_FastAsciiArrayJoin instead. |
| 6631 ASSERT(!answer->IsOneByteRepresentation()); |
| 6628 return answer; | 6632 return answer; |
| 6629 } | 6633 } |
| 6630 | 6634 |
| 6631 template <typename Char> | 6635 template <typename Char> |
| 6632 static void JoinSparseArrayWithSeparator(FixedArray* elements, | 6636 static void JoinSparseArrayWithSeparator(FixedArray* elements, |
| 6633 int elements_length, | 6637 int elements_length, |
| 6634 uint32_t array_length, | 6638 uint32_t array_length, |
| 6635 String* separator, | 6639 String* separator, |
| 6636 Vector<Char> buffer) { | 6640 Vector<Char> buffer) { |
| 6637 int previous_separator_position = 0; | 6641 int previous_separator_position = 0; |
| (...skipping 1371 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 8009 RUNTIME_ASSERT(args.length() == 1 || args.length() == 2); | 8013 RUNTIME_ASSERT(args.length() == 1 || args.length() == 2); |
| 8010 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); | 8014 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); |
| 8011 | 8015 |
| 8012 if (!function->IsOptimizable()) return isolate->heap()->undefined_value(); | 8016 if (!function->IsOptimizable()) return isolate->heap()->undefined_value(); |
| 8013 function->MarkForLazyRecompilation(); | 8017 function->MarkForLazyRecompilation(); |
| 8014 | 8018 |
| 8015 Code* unoptimized = function->shared()->code(); | 8019 Code* unoptimized = function->shared()->code(); |
| 8016 if (args.length() == 2 && | 8020 if (args.length() == 2 && |
| 8017 unoptimized->kind() == Code::FUNCTION) { | 8021 unoptimized->kind() == Code::FUNCTION) { |
| 8018 CONVERT_ARG_HANDLE_CHECKED(String, type, 1); | 8022 CONVERT_ARG_HANDLE_CHECKED(String, type, 1); |
| 8019 CHECK(type->IsEqualTo(CStrVector("osr"))); | 8023 CHECK(type->IsOneByteEqualTo(STATIC_ASCII_VECTOR("osr"))); |
| 8020 isolate->runtime_profiler()->AttemptOnStackReplacement(*function); | 8024 isolate->runtime_profiler()->AttemptOnStackReplacement(*function); |
| 8021 unoptimized->set_allow_osr_at_loop_nesting_level( | 8025 unoptimized->set_allow_osr_at_loop_nesting_level( |
| 8022 Code::kMaxLoopNestingMarker); | 8026 Code::kMaxLoopNestingMarker); |
| 8023 } | 8027 } |
| 8024 | 8028 |
| 8025 return isolate->heap()->undefined_value(); | 8029 return isolate->heap()->undefined_value(); |
| 8026 } | 8030 } |
| 8027 | 8031 |
| 8028 | 8032 |
| 8029 RUNTIME_FUNCTION(MaybeObject*, Runtime_GetOptimizationStatus) { | 8033 RUNTIME_FUNCTION(MaybeObject*, Runtime_GetOptimizationStatus) { |
| (...skipping 5590 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 13620 // Handle last resort GC and make sure to allow future allocations | 13624 // Handle last resort GC and make sure to allow future allocations |
| 13621 // to grow the heap without causing GCs (if possible). | 13625 // to grow the heap without causing GCs (if possible). |
| 13622 isolate->counters()->gc_last_resort_from_js()->Increment(); | 13626 isolate->counters()->gc_last_resort_from_js()->Increment(); |
| 13623 isolate->heap()->CollectAllGarbage(Heap::kNoGCFlags, | 13627 isolate->heap()->CollectAllGarbage(Heap::kNoGCFlags, |
| 13624 "Runtime::PerformGC"); | 13628 "Runtime::PerformGC"); |
| 13625 } | 13629 } |
| 13626 } | 13630 } |
| 13627 | 13631 |
| 13628 | 13632 |
| 13629 } } // namespace v8::internal | 13633 } } // namespace v8::internal |
| OLD | NEW |