Use BrowserV8Locker when possible.

This commit is contained in:
Cheng Zhao 2014-04-18 17:25:22 +08:00
Родитель 1dd57bd3a4
Коммит e5176d6a0a
3 изменённых файлов: 6 добавлений и 14 удалений

Просмотреть файл

@ -20,7 +20,7 @@ class PowerMonitor : public mate::EventEmitter,
static mate::Handle<PowerMonitor> Create(v8::Isolate* isolate); static mate::Handle<PowerMonitor> Create(v8::Isolate* isolate);
protected: protected:
explicit PowerMonitor(); PowerMonitor();
virtual ~PowerMonitor(); virtual ~PowerMonitor();
// base::PowerObserver implementations: // base::PowerObserver implementations:

Просмотреть файл

@ -7,6 +7,7 @@
#include <vector> #include <vector>
#include "atom/browser/api/atom_api_event.h" #include "atom/browser/api/atom_api_event.h"
#include "atom/common/browser_v8_locker.h"
#include "atom/common/v8/native_type_conversions.h" #include "atom/common/v8/native_type_conversions.h"
#include "base/logging.h" #include "base/logging.h"
@ -21,13 +22,9 @@ 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.
BrowserV8Locker locker(node_isolate);
v8::HandleScope handle_scope(node_isolate); v8::HandleScope handle_scope(node_isolate);
handle()->SetAlignedPointerInInternalField(0, NULL); handle()->SetAlignedPointerInInternalField(0, NULL);
} }
@ -38,11 +35,7 @@ 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. BrowserV8Locker locker(node_isolate);
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();

Просмотреть файл

@ -7,6 +7,7 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include "atom/common/browser_v8_locker.h"
#include "atom/common/v8/native_type_conversions.h" #include "atom/common/v8/native_type_conversions.h"
#include "base/command_line.h" #include "base/command_line.h"
#include "base/message_loop/message_loop.h" #include "base/message_loop/message_loop.h"
@ -199,9 +200,7 @@ void NodeBindings::UvRunOnce() {
DCHECK(!is_browser_ || BrowserThread::CurrentlyOn(BrowserThread::UI)); DCHECK(!is_browser_ || BrowserThread::CurrentlyOn(BrowserThread::UI));
// Use Locker in browser process. // Use Locker in browser process.
scoped_ptr<v8::Locker> locker; BrowserV8Locker locker(node_isolate);
if (is_browser_)
locker.reset(new v8::Locker(node_isolate));
v8::HandleScope handle_scope(node_isolate); v8::HandleScope handle_scope(node_isolate);