Fix initializing V8 on Windows.
This commit is contained in:
parent
56f709ff1f
commit
75c44ca057
5 changed files with 17 additions and 33 deletions
|
@ -23,20 +23,6 @@ AtomBrowserBindings::AtomBrowserBindings() {
|
||||||
AtomBrowserBindings::~AtomBrowserBindings() {
|
AtomBrowserBindings::~AtomBrowserBindings() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomBrowserBindings::AfterLoad() {
|
|
||||||
DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
|
|
||||||
|
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
v8::Handle<v8::Object> global = global_env->context()->Global();
|
|
||||||
v8::Handle<v8::Object> atom = global->Get(ToV8Value("__atom"))->ToObject();
|
|
||||||
DCHECK(!atom.IsEmpty());
|
|
||||||
|
|
||||||
browser_main_parts_.reset(
|
|
||||||
atom->Get(ToV8Value("browserMainParts"))->ToObject());
|
|
||||||
DCHECK(!browser_main_parts_.IsEmpty());
|
|
||||||
}
|
|
||||||
|
|
||||||
void AtomBrowserBindings::OnRendererMessage(int process_id,
|
void AtomBrowserBindings::OnRendererMessage(int process_id,
|
||||||
int routing_id,
|
int routing_id,
|
||||||
const string16& channel,
|
const string16& channel,
|
||||||
|
|
|
@ -26,9 +26,6 @@ class AtomBrowserBindings : public AtomBindings {
|
||||||
AtomBrowserBindings();
|
AtomBrowserBindings();
|
||||||
virtual ~AtomBrowserBindings();
|
virtual ~AtomBrowserBindings();
|
||||||
|
|
||||||
// Called when the node.js main script has been loaded.
|
|
||||||
virtual void AfterLoad();
|
|
||||||
|
|
||||||
// Called when received a message from renderer.
|
// Called when received a message from renderer.
|
||||||
void OnRendererMessage(int process_id,
|
void OnRendererMessage(int process_id,
|
||||||
int routing_id,
|
int routing_id,
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include "browser/atom_browser_context.h"
|
#include "browser/atom_browser_context.h"
|
||||||
#include "browser/browser.h"
|
#include "browser/browser.h"
|
||||||
#include "common/node_bindings.h"
|
#include "common/node_bindings.h"
|
||||||
|
#include "net/proxy/proxy_resolver_v8.h"
|
||||||
|
|
||||||
#include "common/v8/node_common.h"
|
#include "common/v8/node_common.h"
|
||||||
|
|
||||||
|
@ -49,32 +50,20 @@ void AtomBrowserMainParts::PostEarlyInitialization() {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
v8::Local<v8::Context> context = v8::Context::New(node_isolate);
|
v8::Local<v8::Context> context = v8::Context::New(node_isolate);
|
||||||
|
|
||||||
// Wrap whole process in one global context.
|
|
||||||
context->Enter();
|
|
||||||
|
|
||||||
// Create the global environment.
|
// Create the global environment.
|
||||||
global_env = node_bindings_->CreateEnvironment(context);
|
global_env = node_bindings_->CreateEnvironment(context);
|
||||||
|
|
||||||
|
// Wrap whole process in one global context.
|
||||||
|
context->Enter();
|
||||||
|
|
||||||
// Add atom-shell extended APIs.
|
// Add atom-shell extended APIs.
|
||||||
atom_bindings_->BindTo(global_env->process_object());
|
atom_bindings_->BindTo(global_env->process_object());
|
||||||
atom_bindings_->AfterLoad();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomBrowserMainParts::PreMainMessageLoopRun() {
|
void AtomBrowserMainParts::PreMainMessageLoopRun() {
|
||||||
node_bindings_->PrepareMessageLoop();
|
|
||||||
|
|
||||||
brightray::BrowserMainParts::PreMainMessageLoopRun();
|
brightray::BrowserMainParts::PreMainMessageLoopRun();
|
||||||
|
|
||||||
{
|
node_bindings_->PrepareMessageLoop();
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
v8::Context::Scope context_scope(global_env->context());
|
|
||||||
|
|
||||||
v8::Handle<v8::Value> args;
|
|
||||||
node::MakeCallback(atom_bindings_->browser_main_parts(),
|
|
||||||
"preMainMessageLoopRun",
|
|
||||||
0, &args);
|
|
||||||
}
|
|
||||||
|
|
||||||
node_bindings_->RunMessageLoop();
|
node_bindings_->RunMessageLoop();
|
||||||
|
|
||||||
// Make sure the url request job factory is created before the
|
// Make sure the url request job factory is created before the
|
||||||
|
@ -89,4 +78,14 @@ void AtomBrowserMainParts::PreMainMessageLoopRun() {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int AtomBrowserMainParts::PreCreateThreads() {
|
||||||
|
// Note that we are overriding the PreCreateThreads of brightray, since we
|
||||||
|
// are integrating node in browser, we can just be sure that an V8 instance
|
||||||
|
// would be prepared, while the ProxyResolverV8::CreateIsolate() would
|
||||||
|
// try to create a V8 isolate, which messed everything on Windows, so we
|
||||||
|
// have to override and call RememberDefaultIsolate on Windows instead.
|
||||||
|
net::ProxyResolverV8::RememberDefaultIsolate();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -30,6 +30,7 @@ class AtomBrowserMainParts : public brightray::BrowserMainParts {
|
||||||
// Implementations of content::BrowserMainParts.
|
// Implementations of content::BrowserMainParts.
|
||||||
virtual void PostEarlyInitialization() OVERRIDE;
|
virtual void PostEarlyInitialization() OVERRIDE;
|
||||||
virtual void PreMainMessageLoopRun() OVERRIDE;
|
virtual void PreMainMessageLoopRun() OVERRIDE;
|
||||||
|
virtual int PreCreateThreads() OVERRIDE;
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
virtual void PreMainMessageLoopStart() OVERRIDE;
|
virtual void PreMainMessageLoopStart() OVERRIDE;
|
||||||
virtual void PostDestroyThreads() OVERRIDE;
|
virtual void PostDestroyThreads() OVERRIDE;
|
||||||
|
|
|
@ -142,6 +142,7 @@ node::Environment* NodeBindings::CreateEnvironment(
|
||||||
|
|
||||||
// Following code are stripped from node::CreateEnvironment in node.cc:
|
// Following code are stripped from node::CreateEnvironment in node.cc:
|
||||||
HandleScope handle_scope(isolate);
|
HandleScope handle_scope(isolate);
|
||||||
|
Context::Scope context_scope(context);
|
||||||
|
|
||||||
Environment* env = Environment::New(context);
|
Environment* env = Environment::New(context);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue