| 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 252 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 263 pattern, | 263 pattern, |
| 264 flags, | 264 flags, |
| 265 match_pattern); | 265 match_pattern); |
| 266 } | 266 } |
| 267 | 267 |
| 268 | 268 |
| 269 static void SetAtomLastCapture(FixedArray* array, | 269 static void SetAtomLastCapture(FixedArray* array, |
| 270 String* subject, | 270 String* subject, |
| 271 int from, | 271 int from, |
| 272 int to) { | 272 int to) { |
| 273 NoHandleAllocation no_handles(array->GetIsolate()); | 273 SealHandleScope shs(array->GetIsolate()); |
| 274 RegExpImpl::SetLastCaptureCount(array, 2); | 274 RegExpImpl::SetLastCaptureCount(array, 2); |
| 275 RegExpImpl::SetLastSubject(array, subject); | 275 RegExpImpl::SetLastSubject(array, subject); |
| 276 RegExpImpl::SetLastInput(array, subject); | 276 RegExpImpl::SetLastInput(array, subject); |
| 277 RegExpImpl::SetCapture(array, 0, from); | 277 RegExpImpl::SetCapture(array, 0, from); |
| 278 RegExpImpl::SetCapture(array, 1, to); | 278 RegExpImpl::SetCapture(array, 1, to); |
| 279 } | 279 } |
| 280 | 280 |
| 281 | 281 |
| 282 int RegExpImpl::AtomExecRaw(Handle<JSRegExp> regexp, | 282 int RegExpImpl::AtomExecRaw(Handle<JSRegExp> regexp, |
| 283 Handle<String> subject, | 283 Handle<String> subject, |
| 284 int index, | 284 int index, |
| 285 int32_t* output, | 285 int32_t* output, |
| 286 int output_size) { | 286 int output_size) { |
| 287 Isolate* isolate = regexp->GetIsolate(); | 287 Isolate* isolate = regexp->GetIsolate(); |
| 288 | 288 |
| 289 ASSERT(0 <= index); | 289 ASSERT(0 <= index); |
| 290 ASSERT(index <= subject->length()); | 290 ASSERT(index <= subject->length()); |
| 291 | 291 |
| 292 if (!subject->IsFlat()) FlattenString(subject); | 292 if (!subject->IsFlat()) FlattenString(subject); |
| 293 AssertNoAllocation no_heap_allocation; // ensure vectors stay valid | 293 DisallowHeapAllocation no_gc; // ensure vectors stay valid |
| 294 | 294 |
| 295 String* needle = String::cast(regexp->DataAt(JSRegExp::kAtomPatternIndex)); | 295 String* needle = String::cast(regexp->DataAt(JSRegExp::kAtomPatternIndex)); |
| 296 int needle_len = needle->length(); | 296 int needle_len = needle->length(); |
| 297 ASSERT(needle->IsFlat()); | 297 ASSERT(needle->IsFlat()); |
| 298 ASSERT_LT(0, needle_len); | 298 ASSERT_LT(0, needle_len); |
| 299 | 299 |
| 300 if (index + needle_len > subject->length()) { | 300 if (index + needle_len > subject->length()) { |
| 301 return RegExpImpl::RE_FAILURE; | 301 return RegExpImpl::RE_FAILURE; |
| 302 } | 302 } |
| 303 | 303 |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 346 | 346 |
| 347 static const int kNumRegisters = 2; | 347 static const int kNumRegisters = 2; |
| 348 STATIC_ASSERT(kNumRegisters <= Isolate::kJSRegexpStaticOffsetsVectorSize); | 348 STATIC_ASSERT(kNumRegisters <= Isolate::kJSRegexpStaticOffsetsVectorSize); |
| 349 int32_t* output_registers = isolate->jsregexp_static_offsets_vector(); | 349 int32_t* output_registers = isolate->jsregexp_static_offsets_vector(); |
| 350 | 350 |
| 351 int res = AtomExecRaw(re, subject, index, output_registers, kNumRegisters); | 351 int res = AtomExecRaw(re, subject, index, output_registers, kNumRegisters); |
| 352 | 352 |
| 353 if (res == RegExpImpl::RE_FAILURE) return isolate->factory()->null_value(); | 353 if (res == RegExpImpl::RE_FAILURE) return isolate->factory()->null_value(); |
| 354 | 354 |
| 355 ASSERT_EQ(res, RegExpImpl::RE_SUCCESS); | 355 ASSERT_EQ(res, RegExpImpl::RE_SUCCESS); |
| 356 NoHandleAllocation no_handles(isolate); | 356 SealHandleScope shs(isolate); |
| 357 FixedArray* array = FixedArray::cast(last_match_info->elements()); | 357 FixedArray* array = FixedArray::cast(last_match_info->elements()); |
| 358 SetAtomLastCapture(array, *subject, output_registers[0], output_registers[1]); | 358 SetAtomLastCapture(array, *subject, output_registers[0], output_registers[1]); |
| 359 return last_match_info; | 359 return last_match_info; |
| 360 } | 360 } |
| 361 | 361 |
| 362 | 362 |
| 363 // Irregexp implementation. | 363 // Irregexp implementation. |
| 364 | 364 |
| 365 // Ensures that the regexp object contains a compiled version of the | 365 // Ensures that the regexp object contains a compiled version of the |
| 366 // source for either ASCII or non-ASCII strings. | 366 // source for either ASCII or non-ASCII strings. |
| (...skipping 317 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 684 } | 684 } |
| 685 | 685 |
| 686 | 686 |
| 687 Handle<JSArray> RegExpImpl::SetLastMatchInfo(Handle<JSArray> last_match_info, | 687 Handle<JSArray> RegExpImpl::SetLastMatchInfo(Handle<JSArray> last_match_info, |
| 688 Handle<String> subject, | 688 Handle<String> subject, |
| 689 int capture_count, | 689 int capture_count, |
| 690 int32_t* match) { | 690 int32_t* match) { |
| 691 ASSERT(last_match_info->HasFastObjectElements()); | 691 ASSERT(last_match_info->HasFastObjectElements()); |
| 692 int capture_register_count = (capture_count + 1) * 2; | 692 int capture_register_count = (capture_count + 1) * 2; |
| 693 last_match_info->EnsureSize(capture_register_count + kLastMatchOverhead); | 693 last_match_info->EnsureSize(capture_register_count + kLastMatchOverhead); |
| 694 AssertNoAllocation no_gc; | 694 DisallowHeapAllocation no_allocation; |
| 695 FixedArray* array = FixedArray::cast(last_match_info->elements()); | 695 FixedArray* array = FixedArray::cast(last_match_info->elements()); |
| 696 if (match != NULL) { | 696 if (match != NULL) { |
| 697 for (int i = 0; i < capture_register_count; i += 2) { | 697 for (int i = 0; i < capture_register_count; i += 2) { |
| 698 SetCapture(array, i, match[i]); | 698 SetCapture(array, i, match[i]); |
| 699 SetCapture(array, i + 1, match[i + 1]); | 699 SetCapture(array, i + 1, match[i + 1]); |
| 700 } | 700 } |
| 701 } | 701 } |
| 702 SetLastCaptureCount(array, capture_register_count); | 702 SetLastCaptureCount(array, capture_register_count); |
| 703 SetLastSubject(array, *subject); | 703 SetLastSubject(array, *subject); |
| 704 SetLastInput(array, *subject); | 704 SetLastInput(array, *subject); |
| (...skipping 5417 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 6122 } | 6122 } |
| 6123 | 6123 |
| 6124 return compiler.Assemble(¯o_assembler, | 6124 return compiler.Assemble(¯o_assembler, |
| 6125 node, | 6125 node, |
| 6126 data->capture_count, | 6126 data->capture_count, |
| 6127 pattern); | 6127 pattern); |
| 6128 } | 6128 } |
| 6129 | 6129 |
| 6130 | 6130 |
| 6131 }} // namespace v8::internal | 6131 }} // namespace v8::internal |
| OLD | NEW |