Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(170)

Side by Side Diff: content/child/child_message_filter.h

Issue 63843002: Add ChildMessageFilter, a base class for renderer/worker cross-thread MessageFilter (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: cross thread -> child message filter Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CONTENT_CHILD_CROSS_MESSAGE_FILTER_H_
6 #define CONTENT_CHILD_CROSS_MESSAGE_FILTER_H_
7
8 #include "ipc/ipc_channel_proxy.h"
9
10 namespace base {
11 class TaskRunner;
12 }
13
14 namespace content {
15
16 class ThreadSafeSender;
17
18 // A base class for implementing IPC MessageFilter's that run on a different
19 // thread or TaskRunner than the main thread.
20 class ChildMessageFilter
21 : public base::RefCountedThreadSafe<ChildMessageFilter>,
22 public IPC::Sender {
23 public:
24 // IPC::Sender implementation. Can be called on any threads.
25 virtual bool Send(IPC::Message* message) OVERRIDE;
26
27 // If implementors want to run OnMessageReceived on a different task
jam 2013/11/18 05:50:02 nit: implementers
kinuko 2013/11/18 06:35:46 Done.
28 // runner it should override this and return the TaskRunner for the message.
29 // Returning NULL by default, which runs OnMessageReceived() on the
30 // current IPC thread.
31 virtual base::TaskRunner* OverrideTaskRunnerForMessage(
32 const IPC::Message& msg);
jam 2013/11/18 05:50:02 nit: seems that this should be pure virtual as tha
kinuko 2013/11/18 06:35:46 Yup... done.
33
34 // If OverrideTaskRunnerForMessage is overriden and returns non-null
35 // this will be called on the returned TaskRunner.
36 virtual bool OnMessageReceived(const IPC::Message& msg) = 0;
37
38 // This method is called when WorkerTaskRunner::PostTask() returned false
39 // for the target thread. Note that there's still a listtle chance that
jam 2013/11/18 05:50:02 nit: little chance
kinuko 2013/11/18 06:35:46 Done.
40 // PostTask() returns true but OnMessageReceivedOnTargetThread() is
41 // never called. By default this does nothing.
42 virtual void OnStaleMessageReceived(const IPC::Message& msg) {}
43
44 protected:
45 ChildMessageFilter();
46 virtual ~ChildMessageFilter();
47
48 private:
49 class Internal;
50 friend class ChildThread;
51 friend class RenderThreadImpl;
52 friend class WorkerThread;
53
54 friend class base::RefCountedThreadSafe<ChildMessageFilter>;
55
56 IPC::ChannelProxy::MessageFilter* GetFilter();
57
58 // This implements IPC::ChannelProxy::MessageFilter to hide the actual
59 // filter methods from child classes.
60 Internal* internal_;
61
62 scoped_refptr<ThreadSafeSender> thread_safe_sender_;
63
64 DISALLOW_COPY_AND_ASSIGN(ChildMessageFilter);
65 };
66
67 } // namespace content
68
69 #endif // CONTENT_CHILD_CROSS_MESSAGE_FILTER_H_
OLDNEW
« no previous file with comments | « no previous file | content/child/child_message_filter.cc » ('j') | content/child/worker_thread_task_runner.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698