Add --js-flags support for main thread.

Allow use of flags that must be set before V8 is initialized, such as
"--harmony_proxies", e.g. --js-flags="--harmony_proxies
--harmony_collections"
This commit is contained in:
Shawn K 2015-11-12 01:00:41 -08:00
parent ce0167756e
commit fb5beb9af5

View file

@ -2,6 +2,8 @@
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include <string>
#include "atom/browser/javascript_environment.h"
#include "base/command_line.h"
@ -27,8 +29,18 @@ bool JavascriptEnvironment::Initialize() {
const char expose_debug_as[] = "--expose_debug_as=v8debug";
v8::V8::SetFlagsFromString(expose_debug_as, sizeof(expose_debug_as) - 1);
}
const std::string js_flags_switch = "js-flags";
if (cmd->HasSwitch(js_flags_switch)) {
const char *js_flags_value =
(cmd->GetSwitchValueASCII(js_flags_switch)).c_str();
v8::V8::SetFlagsFromString(js_flags_value, strlen(js_flags_value));
}
gin::IsolateHolder::Initialize(gin::IsolateHolder::kNonStrictMode,
gin::ArrayBufferAllocator::SharedInstance());
return true;
}