| Index: content/renderer/service_worker/embedded_worker_context_message_filter.cc
|
| diff --git a/content/renderer/service_worker/embedded_worker_context_message_filter.cc b/content/renderer/service_worker/embedded_worker_context_message_filter.cc
|
| index cbc141df56a63514548058b1ab89fbf81252f0d5..b90e24de5857eaaa528ad94f1ccaf926d9af37d5 100644
|
| --- a/content/renderer/service_worker/embedded_worker_context_message_filter.cc
|
| +++ b/content/renderer/service_worker/embedded_worker_context_message_filter.cc
|
| @@ -4,45 +4,37 @@
|
|
|
| #include "content/renderer/service_worker/embedded_worker_context_message_filter.h"
|
|
|
| -#include "base/message_loop/message_loop_proxy.h"
|
| #include "content/child/child_thread.h"
|
| -#include "content/child/thread_safe_sender.h"
|
| -#include "content/child/worker_thread_task_runner.h"
|
| #include "content/renderer/service_worker/embedded_worker_context_client.h"
|
| #include "ipc/ipc_message_macros.h"
|
|
|
| namespace content {
|
|
|
| EmbeddedWorkerContextMessageFilter::EmbeddedWorkerContextMessageFilter()
|
| - : main_thread_loop_proxy_(base::MessageLoopProxy::current()),
|
| - thread_safe_sender_(ChildThread::current()->thread_safe_sender()) {}
|
| + : WorkerThreadMessageFilter(ChildThread::current()->thread_safe_sender()) {
|
| +}
|
|
|
| EmbeddedWorkerContextMessageFilter::~EmbeddedWorkerContextMessageFilter() {}
|
|
|
| -base::TaskRunner*
|
| -EmbeddedWorkerContextMessageFilter::OverrideTaskRunnerForMessage(
|
| - const IPC::Message& msg) {
|
| - if (IPC_MESSAGE_CLASS(msg) != EmbeddedWorkerContextMsgStart)
|
| - return NULL;
|
| - int ipc_thread_id = 0;
|
| - const bool success = PickleIterator(msg).ReadInt(&ipc_thread_id);
|
| - DCHECK(success);
|
| - if (!ipc_thread_id)
|
| - return main_thread_loop_proxy_.get();
|
| - return new WorkerThreadTaskRunner(ipc_thread_id);
|
| +bool EmbeddedWorkerContextMessageFilter::ShouldHandleMessage(
|
| + const IPC::Message& msg) const {
|
| + return IPC_MESSAGE_CLASS(msg) == EmbeddedWorkerContextMsgStart;
|
| }
|
|
|
| -bool EmbeddedWorkerContextMessageFilter::OnMessageReceived(
|
| +void EmbeddedWorkerContextMessageFilter::OnFilteredMessageReceived(
|
| const IPC::Message& msg) {
|
| - if (IPC_MESSAGE_CLASS(msg) != EmbeddedWorkerContextMsgStart)
|
| - return false;
|
| EmbeddedWorkerContextClient* client =
|
| EmbeddedWorkerContextClient::ThreadSpecificInstance();
|
| - if (!client) {
|
| + if (!client)
|
| LOG(ERROR) << "Stray message is sent to nonexistent worker";
|
| - return true;
|
| - }
|
| - return client->OnMessageReceived(msg);
|
| + else
|
| + client->OnMessageReceived(msg);
|
| +}
|
| +
|
| +bool EmbeddedWorkerContextMessageFilter::GetWorkerThreadIdForMessage(
|
| + const IPC::Message& msg,
|
| + int* ipc_thread_id) {
|
| + return PickleIterator(msg).ReadInt(ipc_thread_id);
|
| }
|
|
|
| } // namespace content
|
|
|