Activate uv loop when uv loop's watcher queue changes, fixes #159.

This commit is contained in:
Cheng Zhao 2014-01-18 16:56:46 +08:00
parent a2bf1b3907
commit 4a1f8cf1c9
3 changed files with 23 additions and 1 deletions

View file

@ -26,6 +26,23 @@ NodeBindingsMac::NodeBindingsMac(bool is_browser)
NodeBindingsMac::~NodeBindingsMac() { NodeBindingsMac::~NodeBindingsMac() {
} }
void NodeBindingsMac::RunMessageLoop() {
// Get notified when libuv's watcher queue changes.
uv_loop_->data = this;
uv_loop_->on_watcher_queue_updated = OnWatcherQueueChanged;
NodeBindings::RunMessageLoop();
}
// static
void NodeBindingsMac::OnWatcherQueueChanged(uv_loop_t* loop) {
NodeBindingsMac* self = static_cast<NodeBindingsMac*>(loop->data);
// We need to break the io polling in the kqueue thread when loop's watcher
// queue changes, otherwise new events cannot be notified.
self->WakeupEmbedThread();
}
void NodeBindingsMac::PollEvents() { void NodeBindingsMac::PollEvents() {
struct timespec spec; struct timespec spec;
int timeout = uv_backend_timeout(uv_loop_); int timeout = uv_backend_timeout(uv_loop_);

View file

@ -15,7 +15,12 @@ class NodeBindingsMac : public NodeBindings {
explicit NodeBindingsMac(bool is_browser); explicit NodeBindingsMac(bool is_browser);
virtual ~NodeBindingsMac(); virtual ~NodeBindingsMac();
virtual void RunMessageLoop() OVERRIDE;
private: private:
// Called when uv's watcher queue changes.
static void OnWatcherQueueChanged(uv_loop_t* loop);
virtual void PollEvents() OVERRIDE; virtual void PollEvents() OVERRIDE;
// Kqueue to poll for uv's backend fd. // Kqueue to poll for uv's backend fd.

2
vendor/node vendored

@ -1 +1 @@
Subproject commit 184a341c2b959a092f64b168e3d55b11d13583bf Subproject commit 7fa644854f91c8dd23d8cec21be1310f0b69d813