Merge pull request #166 from atom/cz-v8-locker
Wrap callbacks with v8 locker in browser process
This commit is contained in:
commit
96cb4fd6d7
19 changed files with 32 additions and 40 deletions
|
@ -174,8 +174,6 @@ void App::DockGetBadgeText(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void App::Initialize(v8::Handle<v8::Object> target) {
|
void App::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(v8::Isolate::GetCurrent());
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
t->SetClassName(v8::String::NewSymbol("Application"));
|
t->SetClassName(v8::String::NewSymbol("Application"));
|
||||||
|
|
|
@ -47,8 +47,6 @@ void AutoUpdater::ReadyForUpdateOnQuit(const std::string& version,
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void AutoUpdater::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void AutoUpdater::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
if (!args.IsConstructCall())
|
if (!args.IsConstructCall())
|
||||||
return node::ThrowError("Require constructor call");
|
return node::ThrowError("Require constructor call");
|
||||||
|
|
||||||
|
@ -102,8 +100,6 @@ void AutoUpdater::QuitAndInstall(
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void AutoUpdater::Initialize(v8::Handle<v8::Object> target) {
|
void AutoUpdater::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(v8::Isolate::GetCurrent());
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t(
|
v8::Local<v8::FunctionTemplate> t(
|
||||||
v8::FunctionTemplate::New(AutoUpdater::New));
|
v8::FunctionTemplate::New(AutoUpdater::New));
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
|
|
|
@ -19,7 +19,9 @@ namespace {
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
void CallV8Function(const RefCountedV8Function& callback, T arg) {
|
void CallV8Function(const RefCountedV8Function& callback, T arg) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
v8::Handle<v8::Value> value = ToV8Value(arg);
|
v8::Handle<v8::Value> value = ToV8Value(arg);
|
||||||
callback->NewHandle(node_isolate)->Call(
|
callback->NewHandle(node_isolate)->Call(
|
||||||
v8::Context::GetCurrent()->Global(), 1, &value);
|
v8::Context::GetCurrent()->Global(), 1, &value);
|
||||||
|
@ -34,8 +36,6 @@ void CallV8Function2(const RefCountedV8Function& callback, bool result, T arg) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Initialize(v8::Handle<v8::Object> target) {
|
void Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
NODE_SET_METHOD(target, "showMessageBox", ShowMessageBox);
|
NODE_SET_METHOD(target, "showMessageBox", ShowMessageBox);
|
||||||
NODE_SET_METHOD(target, "showOpenDialog", ShowOpenDialog);
|
NODE_SET_METHOD(target, "showOpenDialog", ShowOpenDialog);
|
||||||
NODE_SET_METHOD(target, "showSaveDialog", ShowSaveDialog);
|
NODE_SET_METHOD(target, "showSaveDialog", ShowSaveDialog);
|
||||||
|
|
|
@ -24,6 +24,7 @@ v8::Handle<v8::Value> CallDelegate(v8::Handle<v8::Value> default_value,
|
||||||
v8::Handle<v8::Object> menu,
|
v8::Handle<v8::Object> menu,
|
||||||
const char* method,
|
const char* method,
|
||||||
int command_id) {
|
int command_id) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
v8::Handle<v8::Value> delegate = menu->Get(v8::String::New("delegate"));
|
v8::Handle<v8::Value> delegate = menu->Get(v8::String::New("delegate"));
|
||||||
|
@ -52,6 +53,7 @@ Menu::~Menu() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Menu::IsCommandIdChecked(int command_id) const {
|
bool Menu::IsCommandIdChecked(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return CallDelegate(v8::False(),
|
return CallDelegate(v8::False(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -60,6 +62,7 @@ bool Menu::IsCommandIdChecked(int command_id) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Menu::IsCommandIdEnabled(int command_id) const {
|
bool Menu::IsCommandIdEnabled(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return CallDelegate(v8::True(),
|
return CallDelegate(v8::True(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -68,6 +71,7 @@ bool Menu::IsCommandIdEnabled(int command_id) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Menu::IsCommandIdVisible(int command_id) const {
|
bool Menu::IsCommandIdVisible(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return CallDelegate(v8::True(),
|
return CallDelegate(v8::True(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -77,6 +81,7 @@ bool Menu::IsCommandIdVisible(int command_id) const {
|
||||||
|
|
||||||
bool Menu::GetAcceleratorForCommandId(int command_id,
|
bool Menu::GetAcceleratorForCommandId(int command_id,
|
||||||
ui::Accelerator* accelerator) {
|
ui::Accelerator* accelerator) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
v8::Handle<v8::Value> shortcut = CallDelegate(v8::Undefined(),
|
v8::Handle<v8::Value> shortcut = CallDelegate(v8::Undefined(),
|
||||||
handle(),
|
handle(),
|
||||||
|
@ -91,6 +96,7 @@ bool Menu::GetAcceleratorForCommandId(int command_id,
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Menu::IsItemForCommandIdDynamic(int command_id) const {
|
bool Menu::IsItemForCommandIdDynamic(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return CallDelegate(v8::False(),
|
return CallDelegate(v8::False(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -99,6 +105,7 @@ bool Menu::IsItemForCommandIdDynamic(int command_id) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
string16 Menu::GetLabelForCommandId(int command_id) const {
|
string16 Menu::GetLabelForCommandId(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return FromV8Value(CallDelegate(v8::False(),
|
return FromV8Value(CallDelegate(v8::False(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -107,6 +114,7 @@ string16 Menu::GetLabelForCommandId(int command_id) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
string16 Menu::GetSublabelForCommandId(int command_id) const {
|
string16 Menu::GetSublabelForCommandId(int command_id) const {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
return FromV8Value(CallDelegate(v8::False(),
|
return FromV8Value(CallDelegate(v8::False(),
|
||||||
const_cast<Menu*>(this)->handle(),
|
const_cast<Menu*>(this)->handle(),
|
||||||
|
@ -115,14 +123,13 @@ string16 Menu::GetSublabelForCommandId(int command_id) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Menu::ExecuteCommand(int command_id, int event_flags) {
|
void Menu::ExecuteCommand(int command_id, int event_flags) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
CallDelegate(v8::False(), handle(), "executeCommand", command_id);
|
CallDelegate(v8::False(), handle(), "executeCommand", command_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Menu::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void Menu::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
if (!args.IsConstructCall())
|
if (!args.IsConstructCall())
|
||||||
return node::ThrowError("Require constructor call");
|
return node::ThrowError("Require constructor call");
|
||||||
|
|
||||||
|
@ -307,8 +314,6 @@ void Menu::Popup(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Menu::Initialize(v8::Handle<v8::Object> target) {
|
void Menu::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t(v8::FunctionTemplate::New(Menu::New));
|
v8::Local<v8::FunctionTemplate> t(v8::FunctionTemplate::New(Menu::New));
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
t->SetClassName(v8::String::NewSymbol("Menu"));
|
t->SetClassName(v8::String::NewSymbol("Menu"));
|
||||||
|
|
|
@ -74,8 +74,6 @@ void MenuMac::SendActionToFirstResponder(const std::string& action) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Menu::SetApplicationMenu(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void Menu::SetApplicationMenu(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
if (!args[0]->IsObject())
|
if (!args[0]->IsObject())
|
||||||
return node::ThrowTypeError("Bad argument");
|
return node::ThrowTypeError("Bad argument");
|
||||||
|
|
||||||
|
@ -94,8 +92,6 @@ void Menu::SetApplicationMenu(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
// static
|
// static
|
||||||
void Menu::SendActionToFirstResponder(
|
void Menu::SendActionToFirstResponder(
|
||||||
const v8::FunctionCallbackInfo<v8::Value>& args) {
|
const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
std::string action;
|
std::string action;
|
||||||
if (!FromV8Arguments(args, &action))
|
if (!FromV8Arguments(args, &action))
|
||||||
return node::ThrowTypeError("Bad argument");
|
return node::ThrowTypeError("Bad argument");
|
||||||
|
|
|
@ -31,8 +31,6 @@ void MenuWin::Popup(NativeWindow* native_window) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Menu::AttachToWindow(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void Menu::AttachToWindow(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
Menu* self = ObjectWrap::Unwrap<Menu>(args.This());
|
Menu* self = ObjectWrap::Unwrap<Menu>(args.This());
|
||||||
if (self == NULL)
|
if (self == NULL)
|
||||||
return node::ThrowError("Menu is already destroyed");
|
return node::ThrowError("Menu is already destroyed");
|
||||||
|
|
|
@ -39,8 +39,6 @@ void PowerMonitor::OnResume() {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void PowerMonitor::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void PowerMonitor::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
if (!args.IsConstructCall())
|
if (!args.IsConstructCall())
|
||||||
return node::ThrowError("Require constructor call");
|
return node::ThrowError("Require constructor call");
|
||||||
|
|
||||||
|
@ -49,8 +47,6 @@ void PowerMonitor::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void PowerMonitor::Initialize(v8::Handle<v8::Object> target) {
|
void PowerMonitor::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
base::PowerMonitorDeviceSource::AllocateSystemIOPorts();
|
base::PowerMonitorDeviceSource::AllocateSystemIOPorts();
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -35,6 +35,7 @@ static const char* kEarlyUseProtocolError = "This method can only be used"
|
||||||
|
|
||||||
// Emit an event for the protocol module.
|
// Emit an event for the protocol module.
|
||||||
void EmitEventInUI(const std::string& event, const std::string& parameter) {
|
void EmitEventInUI(const std::string& event, const std::string& parameter) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
v8::Handle<v8::Value> argv[] = {
|
v8::Handle<v8::Value> argv[] = {
|
||||||
|
@ -72,6 +73,7 @@ class CustomProtocolRequestJob : public AdapterRequestJob {
|
||||||
virtual void GetJobTypeInUI() OVERRIDE {
|
virtual void GetJobTypeInUI() OVERRIDE {
|
||||||
DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
|
DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
|
||||||
|
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
// Call the JS handler.
|
// Call the JS handler.
|
||||||
|
|
|
@ -92,6 +92,7 @@ void Window::OnRendererCrashed() {
|
||||||
|
|
||||||
void Window::OnCapturePageDone(const RefCountedV8Function& callback,
|
void Window::OnCapturePageDone(const RefCountedV8Function& callback,
|
||||||
const std::vector<unsigned char>& data) {
|
const std::vector<unsigned char>& data) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
v8::Local<v8::Value> buffer = node::Buffer::New(
|
v8::Local<v8::Value> buffer = node::Buffer::New(
|
||||||
|
@ -103,8 +104,6 @@ void Window::OnCapturePageDone(const RefCountedV8Function& callback,
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Window::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
void Window::New(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
if (!args.IsConstructCall())
|
if (!args.IsConstructCall())
|
||||||
return node::ThrowError("Require constructor call");
|
return node::ThrowError("Require constructor call");
|
||||||
|
|
||||||
|
@ -625,8 +624,6 @@ void Window::ReloadIgnoringCache(
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Window::Initialize(v8::Handle<v8::Object> target) {
|
void Window::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(Window::New);
|
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(Window::New);
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
t->SetClassName(v8::String::NewSymbol("BrowserWindow"));
|
t->SetClassName(v8::String::NewSymbol("BrowserWindow"));
|
||||||
|
|
|
@ -25,6 +25,7 @@ void AtomBrowserBindings::OnRendererMessage(int process_id,
|
||||||
int routing_id,
|
int routing_id,
|
||||||
const string16& channel,
|
const string16& channel,
|
||||||
const base::ListValue& args) {
|
const base::ListValue& args) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
||||||
|
@ -58,6 +59,7 @@ void AtomBrowserBindings::OnRendererMessageSync(
|
||||||
const base::ListValue& args,
|
const base::ListValue& args,
|
||||||
NativeWindow* sender,
|
NativeWindow* sender,
|
||||||
IPC::Message* message) {
|
IPC::Message* message) {
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
||||||
|
|
|
@ -51,6 +51,7 @@ void AtomBrowserMainParts::PostEarlyInitialization() {
|
||||||
v8::V8::Initialize();
|
v8::V8::Initialize();
|
||||||
|
|
||||||
// Create context.
|
// Create context.
|
||||||
|
v8::Locker locker(node_isolate);
|
||||||
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);
|
||||||
|
|
||||||
|
|
|
@ -74,8 +74,6 @@ void Clipboard::Clear(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Clipboard::Initialize(v8::Handle<v8::Object> target) {
|
void Clipboard::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
NODE_SET_METHOD(target, "has", Has);
|
NODE_SET_METHOD(target, "has", Has);
|
||||||
NODE_SET_METHOD(target, "read", Read);
|
NODE_SET_METHOD(target, "read", Read);
|
||||||
NODE_SET_METHOD(target, "readText", ReadText);
|
NODE_SET_METHOD(target, "readText", ReadText);
|
||||||
|
|
|
@ -21,6 +21,11 @@ EventEmitter::EventEmitter(v8::Handle<v8::Object> wrapper) {
|
||||||
}
|
}
|
||||||
|
|
||||||
EventEmitter::~EventEmitter() {
|
EventEmitter::~EventEmitter() {
|
||||||
|
// Use Locker in browser process.
|
||||||
|
scoped_ptr<v8::Locker> locker;
|
||||||
|
if (node::g_standalone_mode)
|
||||||
|
locker.reset(new v8::Locker(node_isolate));
|
||||||
|
|
||||||
// Clear the aligned pointer, it should have been done by ObjectWrap but
|
// Clear the aligned pointer, it should have been done by ObjectWrap but
|
||||||
// somehow node v0.11.x changed this behaviour.
|
// somehow node v0.11.x changed this behaviour.
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
@ -33,6 +38,11 @@ bool EventEmitter::Emit(const std::string& name) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EventEmitter::Emit(const std::string& name, base::ListValue* args) {
|
bool EventEmitter::Emit(const std::string& name, base::ListValue* args) {
|
||||||
|
// Use Locker in browser process.
|
||||||
|
scoped_ptr<v8::Locker> locker;
|
||||||
|
if (node::g_standalone_mode)
|
||||||
|
locker.reset(new v8::Locker(node_isolate));
|
||||||
|
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
v8::Handle<v8::Context> context = v8::Context::GetCurrent();
|
v8::Handle<v8::Context> context = v8::Context::GetCurrent();
|
||||||
|
|
|
@ -122,8 +122,6 @@ void IDWeakMap::Remove(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void IDWeakMap::Initialize(v8::Handle<v8::Object> target) {
|
void IDWeakMap::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
t->SetClassName(v8::String::NewSymbol("IDWeakMap"));
|
t->SetClassName(v8::String::NewSymbol("IDWeakMap"));
|
||||||
|
|
|
@ -67,8 +67,6 @@ void Screen::GetPrimaryDisplay(
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Screen::Initialize(v8::Handle<v8::Object> target) {
|
void Screen::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(v8::Isolate::GetCurrent());
|
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(New);
|
||||||
t->InstanceTemplate()->SetInternalFieldCount(1);
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
t->SetClassName(v8::String::NewSymbol("Screen"));
|
t->SetClassName(v8::String::NewSymbol("Screen"));
|
||||||
|
|
|
@ -60,8 +60,6 @@ void Shell::Beep(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Shell::Initialize(v8::Handle<v8::Object> target) {
|
void Shell::Initialize(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
NODE_SET_METHOD(target, "showItemInFolder", ShowItemInFolder);
|
NODE_SET_METHOD(target, "showItemInFolder", ShowItemInFolder);
|
||||||
NODE_SET_METHOD(target, "openItem", OpenItem);
|
NODE_SET_METHOD(target, "openItem", OpenItem);
|
||||||
NODE_SET_METHOD(target, "openExternal", OpenExternal);
|
NODE_SET_METHOD(target, "openExternal", OpenExternal);
|
||||||
|
|
|
@ -46,8 +46,6 @@ void TakeHeapSnapshot(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
void InitializeV8Util(v8::Handle<v8::Object> target) {
|
void InitializeV8Util(v8::Handle<v8::Object> target) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
NODE_SET_METHOD(target, "createObjectWithName", CreateObjectWithName);
|
NODE_SET_METHOD(target, "createObjectWithName", CreateObjectWithName);
|
||||||
NODE_SET_METHOD(target, "getHiddenValue", GetHiddenValue);
|
NODE_SET_METHOD(target, "getHiddenValue", GetHiddenValue);
|
||||||
NODE_SET_METHOD(target, "setHiddenValue", SetHiddenValue);
|
NODE_SET_METHOD(target, "setHiddenValue", SetHiddenValue);
|
||||||
|
|
|
@ -90,8 +90,6 @@ AtomBindings::~AtomBindings() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomBindings::BindTo(v8::Handle<v8::Object> process) {
|
void AtomBindings::BindTo(v8::Handle<v8::Object> process) {
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
|
||||||
|
|
||||||
NODE_SET_METHOD(process, "atomBinding", Binding);
|
NODE_SET_METHOD(process, "atomBinding", Binding);
|
||||||
NODE_SET_METHOD(process, "crash", Crash);
|
NODE_SET_METHOD(process, "crash", Crash);
|
||||||
NODE_SET_METHOD(process, "activateUvLoop", ActivateUVLoop);
|
NODE_SET_METHOD(process, "activateUvLoop", ActivateUVLoop);
|
||||||
|
@ -170,8 +168,6 @@ void AtomBindings::Log(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
// static
|
// static
|
||||||
void AtomBindings::GetCurrentStackTrace(
|
void AtomBindings::GetCurrentStackTrace(
|
||||||
const v8::FunctionCallbackInfo<v8::Value>& args) {
|
const v8::FunctionCallbackInfo<v8::Value>& args) {
|
||||||
v8::HandleScope handle_scope(args.GetIsolate());
|
|
||||||
|
|
||||||
int stack_limit = kMaxCallStackSize;
|
int stack_limit = kMaxCallStackSize;
|
||||||
FromV8Arguments(args, &stack_limit);
|
FromV8Arguments(args, &stack_limit);
|
||||||
|
|
||||||
|
|
|
@ -194,6 +194,11 @@ void NodeBindings::RunMessageLoop() {
|
||||||
void NodeBindings::UvRunOnce() {
|
void NodeBindings::UvRunOnce() {
|
||||||
DCHECK(!is_browser_ || BrowserThread::CurrentlyOn(BrowserThread::UI));
|
DCHECK(!is_browser_ || BrowserThread::CurrentlyOn(BrowserThread::UI));
|
||||||
|
|
||||||
|
// Use Locker in browser process.
|
||||||
|
scoped_ptr<v8::Locker> locker;
|
||||||
|
if (is_browser_)
|
||||||
|
locker.reset(new v8::Locker(node_isolate));
|
||||||
|
|
||||||
v8::HandleScope handle_scope(node_isolate);
|
v8::HandleScope handle_scope(node_isolate);
|
||||||
|
|
||||||
// Enter node context while dealing with uv events, by default the global
|
// Enter node context while dealing with uv events, by default the global
|
||||||
|
|
Loading…
Reference in a new issue