Commit 243fa193 authored by bmeurer's avatar bmeurer Committed by Commit bot

[runtime] Refactor Function object setup into a single place.

No need to distribute the setup of the Function global property across
three different places, instead do everything in a single place during
bootstrapping.

R=verwaest@chromium.org

Review URL: https://codereview.chromium.org/1577703005

Cr-Commit-Position: refs/heads/master@{#33242}
parent 4143a667
...@@ -1117,21 +1117,36 @@ void Genesis::InitializeGlobal(Handle<JSGlobalObject> global_object, ...@@ -1117,21 +1117,36 @@ void Genesis::InitializeGlobal(Handle<JSGlobalObject> global_object,
Handle<JSObject> global(native_context()->global_object()); Handle<JSObject> global(native_context()->global_object());
{ // --- F u n c t i o n --- { // --- F u n c t i o n ---
Handle<JSFunction> function_function = Handle<JSFunction> prototype = empty_function;
Handle<JSFunction> function_fun =
InstallFunction(global, "Function", JS_FUNCTION_TYPE, JSFunction::kSize, InstallFunction(global, "Function", JS_FUNCTION_TYPE, JSFunction::kSize,
empty_function, Builtins::kFunctionConstructor); prototype, Builtins::kFunctionConstructor);
function_function->set_prototype_or_initial_map( function_fun->set_prototype_or_initial_map(
*sloppy_function_map_writable_prototype_); *sloppy_function_map_writable_prototype_);
function_function->shared()->DontAdaptArguments(); function_fun->shared()->DontAdaptArguments();
function_function->shared()->set_construct_stub( function_fun->shared()->set_construct_stub(
*isolate->builtins()->FunctionConstructor()); *isolate->builtins()->FunctionConstructor());
function_function->shared()->set_length(1); function_fun->shared()->set_length(1);
InstallWithIntrinsicDefaultProto(isolate, function_function, InstallWithIntrinsicDefaultProto(isolate, function_fun,
Context::FUNCTION_FUNCTION_INDEX); Context::FUNCTION_FUNCTION_INDEX);
sloppy_function_map_writable_prototype_->SetConstructor(*function_function); // Setup the methods on the %FunctionPrototype%.
strict_function_map_writable_prototype_->SetConstructor(*function_function); SimpleInstallFunction(prototype, factory->apply_string(),
native_context()->strong_function_map()->SetConstructor(*function_function); Builtins::kFunctionPrototypeApply, 2, false);
SimpleInstallFunction(prototype, factory->bind_string(),
Builtins::kFunctionPrototypeBind, 1, false);
SimpleInstallFunction(prototype, factory->call_string(),
Builtins::kFunctionPrototypeCall, 1, false);
SimpleInstallFunction(prototype, factory->toString_string(),
Builtins::kFunctionPrototypeToString, 0, false);
// Install the "constructor" property on the %FunctionPrototype%.
JSObject::AddProperty(prototype, factory->constructor_string(),
function_fun, DONT_ENUM);
sloppy_function_map_writable_prototype_->SetConstructor(*function_fun);
strict_function_map_writable_prototype_->SetConstructor(*function_fun);
native_context()->strong_function_map()->SetConstructor(*function_fun);
} }
{ // --- A r r a y --- { // --- A r r a y ---
...@@ -2684,26 +2699,6 @@ bool Genesis::InstallNatives(ContextType context_type) { ...@@ -2684,26 +2699,6 @@ bool Genesis::InstallNatives(ContextType context_type) {
concat->shared()->set_length(1); concat->shared()->set_length(1);
} }
// Install Function.prototype.apply, bind, call, and toString.
{
Handle<String> key = factory()->Function_string();
Handle<JSFunction> function =
Handle<JSFunction>::cast(Object::GetProperty(
handle(native_context()->global_object()), key).ToHandleChecked());
Handle<JSObject> proto =
Handle<JSObject>(JSObject::cast(function->instance_prototype()));
// Install the apply, bind, call and toString functions.
SimpleInstallFunction(proto, factory()->apply_string(),
Builtins::kFunctionPrototypeApply, 2, false);
SimpleInstallFunction(proto, factory()->bind_string(),
Builtins::kFunctionPrototypeBind, 1, false);
SimpleInstallFunction(proto, factory()->call_string(),
Builtins::kFunctionPrototypeCall, 1, false);
SimpleInstallFunction(proto, factory()->toString_string(),
Builtins::kFunctionPrototypeToString, 0, false);
}
// Set up the Promise constructor. // Set up the Promise constructor.
{ {
Handle<String> key = factory()->Promise_string(); Handle<String> key = factory()->Promise_string();
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
var GlobalArray = global.Array; var GlobalArray = global.Array;
var GlobalBoolean = global.Boolean; var GlobalBoolean = global.Boolean;
var GlobalFunction = global.Function;
var GlobalNumber = global.Number; var GlobalNumber = global.Number;
var GlobalObject = global.Object; var GlobalObject = global.Object;
var InternalArray = utils.InternalArray; var InternalArray = utils.InternalArray;
...@@ -1165,14 +1164,6 @@ utils.InstallFunctions(GlobalNumber, DONT_ENUM, [ ...@@ -1165,14 +1164,6 @@ utils.InstallFunctions(GlobalNumber, DONT_ENUM, [
%SetForceInlineFlag(NumberIsNaN); %SetForceInlineFlag(NumberIsNaN);
// ----------------------------------------------------------------------------
// Function
// ----------------------------------------------------------------------------
%AddNamedProperty(GlobalFunction.prototype, "constructor", GlobalFunction,
DONT_ENUM);
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// Iterator related spec functions. // Iterator related spec functions.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment