Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: src/builtins.cc

Issue 204103008: ArrayPop builtin handlified. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Addressing review notes Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | test/cctest/test-heap.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 335 matching lines...) Expand 10 before | Expand all | Expand 10 after
346 } 346 }
347 if (target_kind != origin_kind) { 347 if (target_kind != origin_kind) {
348 MaybeObject* maybe_failure = array->TransitionElementsKind(target_kind); 348 MaybeObject* maybe_failure = array->TransitionElementsKind(target_kind);
349 if (maybe_failure->IsFailure()) return maybe_failure; 349 if (maybe_failure->IsFailure()) return maybe_failure;
350 return array->elements(); 350 return array->elements();
351 } 351 }
352 return elms; 352 return elms;
353 } 353 }
354 354
355 355
356 // TODO(ishell): Temporary wrapper until handlified.
357 MUST_USE_RESULT
358 static inline Handle<Object> EnsureJSArrayWithWritableFastElementsWrapper(
359 Isolate* isolate,
360 Handle<Object> receiver,
361 Arguments* args,
362 int first_added_arg) {
363 CALL_HEAP_FUNCTION(isolate,
364 EnsureJSArrayWithWritableFastElements(
365 isolate->heap(), *receiver, args, first_added_arg),
366 Object);
367 }
368
369
356 static inline bool IsJSArrayFastElementMovingAllowed(Heap* heap, 370 static inline bool IsJSArrayFastElementMovingAllowed(Heap* heap,
357 JSArray* receiver) { 371 JSArray* receiver) {
358 if (!FLAG_clever_optimizations) return false; 372 if (!FLAG_clever_optimizations) return false;
359 Context* native_context = heap->isolate()->context()->native_context(); 373 Context* native_context = heap->isolate()->context()->native_context();
360 JSObject* array_proto = 374 JSObject* array_proto =
361 JSObject::cast(native_context->array_function()->prototype()); 375 JSObject::cast(native_context->array_function()->prototype());
362 return receiver->GetPrototype() == array_proto && 376 return receiver->GetPrototype() == array_proto &&
363 ArrayPrototypeHasNoElements(heap, native_context, array_proto); 377 ArrayPrototypeHasNoElements(heap, native_context, array_proto);
364 } 378 }
365 379
(...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after
499 array->set_elements(new_elms); 513 array->set_elements(new_elms);
500 } 514 }
501 515
502 // Set the length. 516 // Set the length.
503 array->set_length(Smi::FromInt(new_length)); 517 array->set_length(Smi::FromInt(new_length));
504 return Smi::FromInt(new_length); 518 return Smi::FromInt(new_length);
505 } 519 }
506 } 520 }
507 521
508 522
523 // TODO(ishell): Temporary wrapper until handlified.
524 static bool ElementsAccessorHasElementWrapper(
525 ElementsAccessor* accessor,
526 Handle<Object> receiver,
527 Handle<JSObject> holder,
528 uint32_t key,
529 Handle<FixedArrayBase> backing_store = Handle<FixedArrayBase>::null()) {
530 return accessor->HasElement(*receiver, *holder, key,
531 backing_store.is_null() ? *backing_store : NULL);
532 }
533
534
535 // TODO(ishell): Temporary wrapper until handlified.
536 static Handle<Object> ElementsAccessorGetWrapper(
537 Isolate* isolate,
538 ElementsAccessor* accessor,
539 Handle<Object> receiver,
540 Handle<JSObject> holder,
541 uint32_t key,
542 Handle<FixedArrayBase> backing_store = Handle<FixedArrayBase>::null()) {
543 CALL_HEAP_FUNCTION(isolate,
544 accessor->Get(*receiver, *holder, key,
545 backing_store.is_null()
546 ? *backing_store : NULL),
547 Object);
548 }
549
550
551 // TODO(ishell): Temporary wrapper until handlified.
509 static Handle<Object> ElementsAccessorSetLengthWrapper( 552 static Handle<Object> ElementsAccessorSetLengthWrapper(
510 Isolate* isolate, 553 Isolate* isolate,
511 ElementsAccessor* accessor, 554 ElementsAccessor* accessor,
512 Handle<JSArray> array, 555 Handle<JSArray> array,
513 int new_length) { 556 int new_length) {
514 CALL_HEAP_FUNCTION(isolate, 557 CALL_HEAP_FUNCTION(isolate,
515 accessor->SetLength(*array, Smi::FromInt(new_length)), 558 accessor->SetLength(*array, Smi::FromInt(new_length)),
516 Object); 559 Object);
517 } 560 }
518 561
519 562
520 BUILTIN(ArrayPop) { 563 BUILTIN(ArrayPop) {
521 Heap* heap = isolate->heap(); 564 HandleScope scope(isolate);
522 Object* receiver = *args.receiver(); 565 Handle<Object> receiver = args.receiver();
523 FixedArrayBase* elms_obj; 566 Handle<Object> elms_or_null =
524 MaybeObject* maybe_elms = 567 EnsureJSArrayWithWritableFastElementsWrapper(isolate, receiver, NULL, 0);
525 EnsureJSArrayWithWritableFastElements(heap, receiver, NULL, 0); 568 RETURN_IF_EMPTY_HANDLE(isolate, elms_or_null);
526 if (maybe_elms == NULL) return CallJsBuiltin(isolate, "ArrayPop", args); 569 if (*elms_or_null == NULL) return CallJsBuiltin(isolate, "ArrayPop", args);
527 if (!maybe_elms->To(&elms_obj)) return maybe_elms;
528 570
529 JSArray* array = JSArray::cast(receiver); 571 Handle<FixedArrayBase> elms_obj = Handle<FixedArrayBase>::cast(elms_or_null);
572 Handle<JSArray> array = Handle<JSArray>::cast(receiver);
530 ASSERT(!array->map()->is_observed()); 573 ASSERT(!array->map()->is_observed());
531 574
532 int len = Smi::cast(array->length())->value(); 575 int len = Smi::cast(array->length())->value();
533 if (len == 0) return heap->undefined_value(); 576 if (len == 0) return isolate->heap()->undefined_value();
534 577
535 ElementsAccessor* accessor = array->GetElementsAccessor(); 578 ElementsAccessor* accessor = array->GetElementsAccessor();
536 int new_length = len - 1; 579 int new_length = len - 1;
537 if (accessor->HasElement(array, array, new_length, elms_obj)) { 580 Handle<Object> element;
538 MaybeObject* maybe_result = 581 if (ElementsAccessorHasElementWrapper(
539 accessor->Get(array, array, new_length, elms_obj); 582 accessor, array, array, new_length, elms_obj)) {
540 if (maybe_result->IsFailure()) return maybe_result; 583 element = ElementsAccessorGetWrapper(
541 MaybeObject* maybe_failure = 584 isolate, accessor, array, array, new_length, elms_obj);
542 accessor->SetLength(array, Smi::FromInt(new_length));
543 if (maybe_failure->IsFailure()) return maybe_failure;
544 return maybe_result;
545 } else { 585 } else {
546 // TODO(yangguo): handlify all once ElementsAccessors are handlified.
547 HandleScope scope(isolate);
548 Handle<Object> proto(array->GetPrototype(), isolate); 586 Handle<Object> proto(array->GetPrototype(), isolate);
549 Handle<Object> element = Object::GetElement(isolate, proto, len - 1); 587 element = Object::GetElement(isolate, proto, len - 1);
550 RETURN_IF_EMPTY_HANDLE(isolate, element);
551 Handle<JSArray> array_handle(array, isolate);
552 RETURN_IF_EMPTY_HANDLE(isolate,
553 ElementsAccessorSetLengthWrapper(
554 isolate, accessor, array_handle, new_length));
555 return *element;
556 } 588 }
589 RETURN_IF_EMPTY_HANDLE(isolate, element);
590 RETURN_IF_EMPTY_HANDLE(isolate,
591 ElementsAccessorSetLengthWrapper(
592 isolate, accessor, array, new_length));
593 return *element;
557 } 594 }
558 595
559 596
560 BUILTIN(ArrayShift) { 597 BUILTIN(ArrayShift) {
561 Heap* heap = isolate->heap(); 598 Heap* heap = isolate->heap();
562 Object* receiver = *args.receiver(); 599 Object* receiver = *args.receiver();
563 FixedArrayBase* elms_obj; 600 FixedArrayBase* elms_obj;
564 MaybeObject* maybe_elms_obj = 601 MaybeObject* maybe_elms_obj =
565 EnsureJSArrayWithWritableFastElements(heap, receiver, NULL, 0); 602 EnsureJSArrayWithWritableFastElements(heap, receiver, NULL, 0);
566 if (maybe_elms_obj == NULL) 603 if (maybe_elms_obj == NULL)
(...skipping 1190 matching lines...) Expand 10 before | Expand all | Expand 10 after
1757 } 1794 }
1758 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C) 1795 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C)
1759 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A) 1796 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A)
1760 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H) 1797 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H)
1761 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A) 1798 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A)
1762 #undef DEFINE_BUILTIN_ACCESSOR_C 1799 #undef DEFINE_BUILTIN_ACCESSOR_C
1763 #undef DEFINE_BUILTIN_ACCESSOR_A 1800 #undef DEFINE_BUILTIN_ACCESSOR_A
1764 1801
1765 1802
1766 } } // namespace v8::internal 1803 } } // namespace v8::internal
OLDNEW
« no previous file with comments | « no previous file | test/cctest/test-heap.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698