Index: content/child/navigator_connect/navigator_connect_dispatcher.cc |
diff --git a/content/child/navigator_connect/navigator_connect_dispatcher.cc b/content/child/navigator_connect/navigator_connect_dispatcher.cc |
index d2f7119a97d171ed870afd85629d4d207121d4aa..1a30433ac81b7df7f8134e5f5e78092b27962f08 100644 |
--- a/content/child/navigator_connect/navigator_connect_dispatcher.cc |
+++ b/content/child/navigator_connect/navigator_connect_dispatcher.cc |
@@ -4,41 +4,33 @@ |
#include "content/child/navigator_connect/navigator_connect_dispatcher.h" |
-#include "base/message_loop/message_loop_proxy.h" |
#include "content/child/navigator_connect/navigator_connect_provider.h" |
-#include "content/child/thread_safe_sender.h" |
-#include "content/child/worker_thread_task_runner.h" |
#include "content/common/navigator_connect_messages.h" |
namespace content { |
NavigatorConnectDispatcher::NavigatorConnectDispatcher(ThreadSafeSender* sender) |
- : main_thread_loop_proxy_(base::MessageLoopProxy::current()), |
- thread_safe_sender_(sender) { |
+ : WorkerThreadMessageFilter(sender) { |
} |
NavigatorConnectDispatcher::~NavigatorConnectDispatcher() { |
} |
-base::TaskRunner* NavigatorConnectDispatcher::OverrideTaskRunnerForMessage( |
+bool NavigatorConnectDispatcher::ShouldHandleMessage( |
+ const IPC::Message& msg) const { |
+ return IPC_MESSAGE_CLASS(msg) == NavigatorConnectMsgStart; |
+} |
+ |
+void NavigatorConnectDispatcher::OnFilteredMessageReceived( |
const IPC::Message& msg) { |
- if (IPC_MESSAGE_CLASS(msg) != NavigatorConnectMsgStart) |
- 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); |
+ NavigatorConnectProvider::ThreadSpecificInstance( |
+ thread_safe_sender(), main_thread_task_runner())->OnMessageReceived(msg); |
} |
-bool NavigatorConnectDispatcher::OnMessageReceived(const IPC::Message& msg) { |
- if (IPC_MESSAGE_CLASS(msg) != NavigatorConnectMsgStart) |
- return false; |
- NavigatorConnectProvider::ThreadSpecificInstance(thread_safe_sender_.get(), |
- main_thread_loop_proxy_) |
- ->OnMessageReceived(msg); |
- return true; |
+bool NavigatorConnectDispatcher::GetWorkerThreadIdForMessage( |
+ const IPC::Message& msg, |
+ int* ipc_thread_id) { |
+ return PickleIterator(msg).ReadInt(ipc_thread_id); |
} |
} // namespace content |