Forbid using protocol module before app is ready, fixes #661

This commit is contained in:
Cheng Zhao 2014-10-30 22:27:29 +08:00
parent c0cd8fca80
commit 9ed6ad8165
2 changed files with 11 additions and 13 deletions

View file

@ -148,20 +148,15 @@ void App::SetDesktopName(const std::string& desktop_name) {
mate::ObjectTemplateBuilder App::GetObjectTemplateBuilder( mate::ObjectTemplateBuilder App::GetObjectTemplateBuilder(
v8::Isolate* isolate) { v8::Isolate* isolate) {
Browser* browser = Browser::Get(); auto browser = base::Unretained(Browser::Get());
return mate::ObjectTemplateBuilder(isolate) return mate::ObjectTemplateBuilder(isolate)
.SetMethod("quit", base::Bind(&Browser::Quit, .SetMethod("quit", base::Bind(&Browser::Quit, browser))
base::Unretained(browser))) .SetMethod("focus", base::Bind(&Browser::Focus, browser))
.SetMethod("focus", base::Bind(&Browser::Focus, .SetMethod("getVersion", base::Bind(&Browser::GetVersion, browser))
base::Unretained(browser))) .SetMethod("setVersion", base::Bind(&Browser::SetVersion, browser))
.SetMethod("getVersion", base::Bind(&Browser::GetVersion, .SetMethod("getName", base::Bind(&Browser::GetName, browser))
base::Unretained(browser))) .SetMethod("setName", base::Bind(&Browser::SetName, browser))
.SetMethod("setVersion", base::Bind(&Browser::SetVersion, .SetMethod("isReady", base::Bind(&Browser::is_ready, browser))
base::Unretained(browser)))
.SetMethod("getName", base::Bind(&Browser::GetName,
base::Unretained(browser)))
.SetMethod("setName", base::Bind(&Browser::SetName,
base::Unretained(browser)))
.SetMethod("getDataPath", &App::GetDataPath) .SetMethod("getDataPath", &App::GetDataPath)
.SetMethod("resolveProxy", &App::ResolveProxy) .SetMethod("resolveProxy", &App::ResolveProxy)
.SetMethod("setDesktopName", &App::SetDesktopName); .SetMethod("setDesktopName", &App::SetDesktopName);

View file

@ -1,3 +1,6 @@
app = require 'app'
throw new Error('Can not initialize protocol module before app is ready') unless app.isReady()
protocol = process.atomBinding('protocol').protocol protocol = process.atomBinding('protocol').protocol
EventEmitter = require('events').EventEmitter EventEmitter = require('events').EventEmitter