| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/builtins.h" | 5 #include "src/builtins.h" |
| 6 | 6 |
| 7 #include "src/api.h" | 7 #include "src/api.h" |
| 8 #include "src/api-natives.h" | 8 #include "src/api-natives.h" |
| 9 #include "src/arguments.h" | 9 #include "src/arguments.h" |
| 10 #include "src/base/once.h" | 10 #include "src/base/once.h" |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 if (index >= length()) { | 52 if (index >= length()) { |
| 53 return isolate->factory()->undefined_value(); | 53 return isolate->factory()->undefined_value(); |
| 54 } | 54 } |
| 55 return at<Object>(index); | 55 return at<Object>(index); |
| 56 } | 56 } |
| 57 | 57 |
| 58 Handle<Object> receiver() { | 58 Handle<Object> receiver() { |
| 59 return Arguments::at<Object>(0); | 59 return Arguments::at<Object>(0); |
| 60 } | 60 } |
| 61 | 61 |
| 62 template <class S> | 62 Handle<JSFunction> target(); |
| 63 Handle<S> target(); | |
| 64 Handle<HeapObject> new_target(); | 63 Handle<HeapObject> new_target(); |
| 65 | 64 |
| 66 // Gets the total number of arguments including the receiver (but | 65 // Gets the total number of arguments including the receiver (but |
| 67 // excluding extra arguments). | 66 // excluding extra arguments). |
| 68 int length() const; | 67 int length() const; |
| 69 }; | 68 }; |
| 70 | 69 |
| 71 | 70 |
| 72 // Specialize BuiltinArguments for the extra arguments. | 71 // Specialize BuiltinArguments for the extra arguments. |
| 73 | 72 |
| 74 template <> | 73 template <> |
| 75 int BuiltinArguments<BuiltinExtraArguments::kNone>::length() const { | 74 int BuiltinArguments<BuiltinExtraArguments::kNone>::length() const { |
| 76 return Arguments::length(); | 75 return Arguments::length(); |
| 77 } | 76 } |
| 78 | 77 |
| 79 template <> | 78 template <> |
| 80 int BuiltinArguments<BuiltinExtraArguments::kTarget>::length() const { | 79 int BuiltinArguments<BuiltinExtraArguments::kTarget>::length() const { |
| 81 return Arguments::length() - 1; | 80 return Arguments::length() - 1; |
| 82 } | 81 } |
| 83 | 82 |
| 84 template <> | 83 template <> |
| 85 template <class S> | 84 Handle<JSFunction> BuiltinArguments<BuiltinExtraArguments::kTarget>::target() { |
| 86 Handle<S> BuiltinArguments<BuiltinExtraArguments::kTarget>::target() { | 85 return Arguments::at<JSFunction>(Arguments::length() - 1); |
| 87 return Arguments::at<S>(Arguments::length() - 1); | |
| 88 } | 86 } |
| 89 | 87 |
| 90 template <> | 88 template <> |
| 91 int BuiltinArguments<BuiltinExtraArguments::kNewTarget>::length() const { | 89 int BuiltinArguments<BuiltinExtraArguments::kNewTarget>::length() const { |
| 92 return Arguments::length() - 1; | 90 return Arguments::length() - 1; |
| 93 } | 91 } |
| 94 | 92 |
| 95 template <> | 93 template <> |
| 96 Handle<HeapObject> | 94 Handle<HeapObject> |
| 97 BuiltinArguments<BuiltinExtraArguments::kNewTarget>::new_target() { | 95 BuiltinArguments<BuiltinExtraArguments::kNewTarget>::new_target() { |
| 98 return Arguments::at<HeapObject>(Arguments::length() - 1); | 96 return Arguments::at<HeapObject>(Arguments::length() - 1); |
| 99 } | 97 } |
| 100 | 98 |
| 101 template <> | 99 template <> |
| 102 int BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::length() | 100 int BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::length() |
| 103 const { | 101 const { |
| 104 return Arguments::length() - 2; | 102 return Arguments::length() - 2; |
| 105 } | 103 } |
| 106 | 104 |
| 107 template <> | 105 template <> |
| 108 template <class S> | 106 Handle<JSFunction> |
| 109 Handle<S> | |
| 110 BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::target() { | 107 BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::target() { |
| 111 return Arguments::at<S>(Arguments::length() - 2); | 108 return Arguments::at<JSFunction>(Arguments::length() - 2); |
| 112 } | 109 } |
| 113 | 110 |
| 114 template <> | 111 template <> |
| 115 Handle<HeapObject> | 112 Handle<HeapObject> |
| 116 BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::new_target() { | 113 BuiltinArguments<BuiltinExtraArguments::kTargetAndNewTarget>::new_target() { |
| 117 return Arguments::at<HeapObject>(Arguments::length() - 1); | 114 return Arguments::at<HeapObject>(Arguments::length() - 1); |
| 118 } | 115 } |
| 119 | 116 |
| 120 | 117 |
| 121 #define DEF_ARG_TYPE(name, spec) \ | 118 #define DEF_ARG_TYPE(name, spec) \ |
| (...skipping 1813 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1935 RelocInfo::kNoPosition); | 1932 RelocInfo::kNoPosition); |
| 1936 } | 1933 } |
| 1937 | 1934 |
| 1938 } // namespace | 1935 } // namespace |
| 1939 | 1936 |
| 1940 | 1937 |
| 1941 // ES6 section 18.2.1 eval (x) | 1938 // ES6 section 18.2.1 eval (x) |
| 1942 BUILTIN(GlobalEval) { | 1939 BUILTIN(GlobalEval) { |
| 1943 HandleScope scope(isolate); | 1940 HandleScope scope(isolate); |
| 1944 Handle<Object> x = args.atOrUndefined(isolate, 1); | 1941 Handle<Object> x = args.atOrUndefined(isolate, 1); |
| 1945 Handle<JSFunction> target = args.target<JSFunction>(); | 1942 Handle<JSFunction> target = args.target(); |
| 1946 Handle<JSObject> target_global_proxy(target->global_proxy(), isolate); | 1943 Handle<JSObject> target_global_proxy(target->global_proxy(), isolate); |
| 1947 if (!x->IsString()) return *x; | 1944 if (!x->IsString()) return *x; |
| 1948 Handle<JSFunction> function; | 1945 Handle<JSFunction> function; |
| 1949 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 1946 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
| 1950 isolate, function, | 1947 isolate, function, |
| 1951 CompileString(handle(target->native_context(), isolate), | 1948 CompileString(handle(target->native_context(), isolate), |
| 1952 Handle<String>::cast(x), NO_PARSE_RESTRICTION)); | 1949 Handle<String>::cast(x), NO_PARSE_RESTRICTION)); |
| 1953 Handle<Object> result; | 1950 Handle<Object> result; |
| 1954 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 1951 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
| 1955 isolate, result, | 1952 isolate, result, |
| (...skipping 475 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2431 Vector<char> str(buffer, arraysize(buffer)); | 2428 Vector<char> str(buffer, arraysize(buffer)); |
| 2432 ToDateString(time_val, str, isolate->date_cache()); | 2429 ToDateString(time_val, str, isolate->date_cache()); |
| 2433 return *isolate->factory()->NewStringFromAsciiChecked(str.start()); | 2430 return *isolate->factory()->NewStringFromAsciiChecked(str.start()); |
| 2434 } | 2431 } |
| 2435 | 2432 |
| 2436 | 2433 |
| 2437 // ES6 section 20.3.2 The Date Constructor for the [[Construct]] case. | 2434 // ES6 section 20.3.2 The Date Constructor for the [[Construct]] case. |
| 2438 BUILTIN(DateConstructor_ConstructStub) { | 2435 BUILTIN(DateConstructor_ConstructStub) { |
| 2439 HandleScope scope(isolate); | 2436 HandleScope scope(isolate); |
| 2440 int const argc = args.length() - 1; | 2437 int const argc = args.length() - 1; |
| 2441 Handle<JSFunction> target = args.target<JSFunction>(); | 2438 Handle<JSFunction> target = args.target(); |
| 2442 Handle<JSReceiver> new_target = Handle<JSReceiver>::cast(args.new_target()); | 2439 Handle<JSReceiver> new_target = Handle<JSReceiver>::cast(args.new_target()); |
| 2443 double time_val; | 2440 double time_val; |
| 2444 if (argc == 0) { | 2441 if (argc == 0) { |
| 2445 time_val = JSDate::CurrentTimeValue(isolate); | 2442 time_val = JSDate::CurrentTimeValue(isolate); |
| 2446 } else if (argc == 1) { | 2443 } else if (argc == 1) { |
| 2447 Handle<Object> value = args.at<Object>(1); | 2444 Handle<Object> value = args.at<Object>(1); |
| 2448 if (value->IsJSDate()) { | 2445 if (value->IsJSDate()) { |
| 2449 time_val = Handle<JSDate>::cast(value)->value()->Number(); | 2446 time_val = Handle<JSDate>::cast(value)->value()->Number(); |
| 2450 } else { | 2447 } else { |
| 2451 ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, value, | 2448 ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, value, |
| (...skipping 863 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3315 // conversions are done. | 3312 // conversions are done. |
| 3316 if (parenthesis_in_arg_string) { | 3313 if (parenthesis_in_arg_string) { |
| 3317 THROW_NEW_ERROR(isolate, | 3314 THROW_NEW_ERROR(isolate, |
| 3318 NewSyntaxError(MessageTemplate::kParenthesisInArgString), | 3315 NewSyntaxError(MessageTemplate::kParenthesisInArgString), |
| 3319 JSFunction); | 3316 JSFunction); |
| 3320 } | 3317 } |
| 3321 } | 3318 } |
| 3322 | 3319 |
| 3323 // Compile the string in the constructor and not a helper so that errors to | 3320 // Compile the string in the constructor and not a helper so that errors to |
| 3324 // come from here. | 3321 // come from here. |
| 3325 Handle<JSFunction> target = args.target<JSFunction>(); | 3322 Handle<JSFunction> target = args.target(); |
| 3326 Handle<JSObject> target_global_proxy(target->global_proxy(), isolate); | 3323 Handle<JSObject> target_global_proxy(target->global_proxy(), isolate); |
| 3327 Handle<JSFunction> function; | 3324 Handle<JSFunction> function; |
| 3328 { | 3325 { |
| 3329 ASSIGN_RETURN_ON_EXCEPTION( | 3326 ASSIGN_RETURN_ON_EXCEPTION( |
| 3330 isolate, function, | 3327 isolate, function, |
| 3331 CompileString(handle(target->native_context(), isolate), source, | 3328 CompileString(handle(target->native_context(), isolate), source, |
| 3332 ONLY_SINGLE_FUNCTION_LITERAL), | 3329 ONLY_SINGLE_FUNCTION_LITERAL), |
| 3333 JSFunction); | 3330 JSFunction); |
| 3334 Handle<Object> result; | 3331 Handle<Object> result; |
| 3335 ASSIGN_RETURN_ON_EXCEPTION( | 3332 ASSIGN_RETURN_ON_EXCEPTION( |
| (...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3500 Handle<String> result; | 3497 Handle<String> result; |
| 3501 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | 3498 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( |
| 3502 isolate, result, JSObject::ObjectProtoToString(isolate, object)); | 3499 isolate, result, JSObject::ObjectProtoToString(isolate, object)); |
| 3503 return *result; | 3500 return *result; |
| 3504 } | 3501 } |
| 3505 | 3502 |
| 3506 | 3503 |
| 3507 // ES6 section 24.1.2.1 ArrayBuffer ( length ) for the [[Call]] case. | 3504 // ES6 section 24.1.2.1 ArrayBuffer ( length ) for the [[Call]] case. |
| 3508 BUILTIN(ArrayBufferConstructor) { | 3505 BUILTIN(ArrayBufferConstructor) { |
| 3509 HandleScope scope(isolate); | 3506 HandleScope scope(isolate); |
| 3510 Handle<JSFunction> target = args.target<JSFunction>(); | 3507 Handle<JSFunction> target = args.target(); |
| 3511 DCHECK(*target == target->native_context()->array_buffer_fun() || | 3508 DCHECK(*target == target->native_context()->array_buffer_fun() || |
| 3512 *target == target->native_context()->shared_array_buffer_fun()); | 3509 *target == target->native_context()->shared_array_buffer_fun()); |
| 3513 THROW_NEW_ERROR_RETURN_FAILURE( | 3510 THROW_NEW_ERROR_RETURN_FAILURE( |
| 3514 isolate, NewTypeError(MessageTemplate::kConstructorNotFunction, | 3511 isolate, NewTypeError(MessageTemplate::kConstructorNotFunction, |
| 3515 handle(target->shared()->name(), isolate))); | 3512 handle(target->shared()->name(), isolate))); |
| 3516 } | 3513 } |
| 3517 | 3514 |
| 3518 | 3515 |
| 3519 // ES6 section 24.1.2.1 ArrayBuffer ( length ) for the [[Construct]] case. | 3516 // ES6 section 24.1.2.1 ArrayBuffer ( length ) for the [[Construct]] case. |
| 3520 BUILTIN(ArrayBufferConstructor_ConstructStub) { | 3517 BUILTIN(ArrayBufferConstructor_ConstructStub) { |
| 3521 HandleScope scope(isolate); | 3518 HandleScope scope(isolate); |
| 3522 Handle<JSFunction> target = args.target<JSFunction>(); | 3519 Handle<JSFunction> target = args.target(); |
| 3523 Handle<JSReceiver> new_target = Handle<JSReceiver>::cast(args.new_target()); | 3520 Handle<JSReceiver> new_target = Handle<JSReceiver>::cast(args.new_target()); |
| 3524 Handle<Object> length = args.atOrUndefined(isolate, 1); | 3521 Handle<Object> length = args.atOrUndefined(isolate, 1); |
| 3525 DCHECK(*target == target->native_context()->array_buffer_fun() || | 3522 DCHECK(*target == target->native_context()->array_buffer_fun() || |
| 3526 *target == target->native_context()->shared_array_buffer_fun()); | 3523 *target == target->native_context()->shared_array_buffer_fun()); |
| 3527 Handle<Object> number_length; | 3524 Handle<Object> number_length; |
| 3528 ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, number_length, | 3525 ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, number_length, |
| 3529 Object::ToInteger(isolate, length)); | 3526 Object::ToInteger(isolate, length)); |
| 3530 if (number_length->Number() < 0.0) { | 3527 if (number_length->Number() < 0.0) { |
| 3531 THROW_NEW_ERROR_RETURN_FAILURE( | 3528 THROW_NEW_ERROR_RETURN_FAILURE( |
| 3532 isolate, NewRangeError(MessageTemplate::kInvalidArrayBufferLength)); | 3529 isolate, NewRangeError(MessageTemplate::kInvalidArrayBufferLength)); |
| (...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3609 // ----------------------------------------------------------------------------- | 3606 // ----------------------------------------------------------------------------- |
| 3610 // | 3607 // |
| 3611 | 3608 |
| 3612 | 3609 |
| 3613 namespace { | 3610 namespace { |
| 3614 | 3611 |
| 3615 template <bool is_construct> | 3612 template <bool is_construct> |
| 3616 MUST_USE_RESULT MaybeHandle<Object> HandleApiCallHelper( | 3613 MUST_USE_RESULT MaybeHandle<Object> HandleApiCallHelper( |
| 3617 Isolate* isolate, BuiltinArguments<BuiltinExtraArguments::kTarget> args) { | 3614 Isolate* isolate, BuiltinArguments<BuiltinExtraArguments::kTarget> args) { |
| 3618 HandleScope scope(isolate); | 3615 HandleScope scope(isolate); |
| 3619 Handle<HeapObject> function = args.target<HeapObject>(); | 3616 Handle<JSFunction> function = args.target(); |
| 3620 Handle<JSReceiver> receiver; | 3617 Handle<JSReceiver> receiver; |
| 3621 // TODO(ishell): turn this back to a DCHECK. | 3618 // TODO(ishell): turn this back to a DCHECK. |
| 3622 CHECK(function->IsFunctionTemplateInfo() || | 3619 CHECK(function->shared()->IsApiFunction()); |
| 3623 Handle<JSFunction>::cast(function)->shared()->IsApiFunction()); | |
| 3624 | 3620 |
| 3625 Handle<FunctionTemplateInfo> fun_data = | 3621 Handle<FunctionTemplateInfo> fun_data( |
| 3626 function->IsFunctionTemplateInfo() | 3622 function->shared()->get_api_func_data(), isolate); |
| 3627 ? Handle<FunctionTemplateInfo>::cast(function) | |
| 3628 : handle(JSFunction::cast(*function)->shared()->get_api_func_data()); | |
| 3629 if (is_construct) { | 3623 if (is_construct) { |
| 3630 DCHECK(args.receiver()->IsTheHole()); | 3624 DCHECK(args.receiver()->IsTheHole()); |
| 3631 if (fun_data->instance_template()->IsUndefined()) { | 3625 if (fun_data->instance_template()->IsUndefined()) { |
| 3632 v8::Local<ObjectTemplate> templ = | 3626 v8::Local<ObjectTemplate> templ = |
| 3633 ObjectTemplate::New(reinterpret_cast<v8::Isolate*>(isolate), | 3627 ObjectTemplate::New(reinterpret_cast<v8::Isolate*>(isolate), |
| 3634 ToApiHandle<v8::FunctionTemplate>(fun_data)); | 3628 ToApiHandle<v8::FunctionTemplate>(fun_data)); |
| 3635 fun_data->set_instance_template(*Utils::OpenHandle(*templ)); | 3629 fun_data->set_instance_template(*Utils::OpenHandle(*templ)); |
| 3636 } | 3630 } |
| 3637 Handle<ObjectTemplateInfo> instance_template( | 3631 Handle<ObjectTemplateInfo> instance_template( |
| 3638 ObjectTemplateInfo::cast(fun_data->instance_template()), isolate); | 3632 ObjectTemplateInfo::cast(fun_data->instance_template()), isolate); |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3805 if (length() == 0) return; | 3799 if (length() == 0) return; |
| 3806 v->VisitPointers(lowest_address(), highest_address() + 1); | 3800 v->VisitPointers(lowest_address(), highest_address() + 1); |
| 3807 } | 3801 } |
| 3808 | 3802 |
| 3809 private: | 3803 private: |
| 3810 DISALLOW_COPY_AND_ASSIGN(RelocatableArguments); | 3804 DISALLOW_COPY_AND_ASSIGN(RelocatableArguments); |
| 3811 }; | 3805 }; |
| 3812 | 3806 |
| 3813 } // namespace | 3807 } // namespace |
| 3814 | 3808 |
| 3815 MaybeHandle<Object> Builtins::InvokeApiFunction(Handle<HeapObject> function, | 3809 |
| 3810 MaybeHandle<Object> Builtins::InvokeApiFunction(Handle<JSFunction> function, |
| 3816 Handle<Object> receiver, | 3811 Handle<Object> receiver, |
| 3817 int argc, | 3812 int argc, |
| 3818 Handle<Object> args[]) { | 3813 Handle<Object> args[]) { |
| 3819 // Construct BuiltinArguments object: function, arguments reversed, receiver. | 3814 // Construct BuiltinArguments object: function, arguments reversed, receiver. |
| 3820 const int kBufferSize = 32; | 3815 const int kBufferSize = 32; |
| 3821 Object* small_argv[kBufferSize]; | 3816 Object* small_argv[kBufferSize]; |
| 3822 Object** argv; | 3817 Object** argv; |
| 3823 if (argc + 2 <= kBufferSize) { | 3818 if (argc + 2 <= kBufferSize) { |
| 3824 argv = small_argv; | 3819 argv = small_argv; |
| 3825 } else { | 3820 } else { |
| (...skipping 436 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4262 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C) | 4257 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C) |
| 4263 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A) | 4258 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A) |
| 4264 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H) | 4259 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H) |
| 4265 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A) | 4260 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A) |
| 4266 #undef DEFINE_BUILTIN_ACCESSOR_C | 4261 #undef DEFINE_BUILTIN_ACCESSOR_C |
| 4267 #undef DEFINE_BUILTIN_ACCESSOR_A | 4262 #undef DEFINE_BUILTIN_ACCESSOR_A |
| 4268 | 4263 |
| 4269 | 4264 |
| 4270 } // namespace internal | 4265 } // namespace internal |
| 4271 } // namespace v8 | 4266 } // namespace v8 |
| OLD | NEW |