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

Side by Side Diff: remoting/base/plugin_message_loop_proxy.h

Issue 9427023: Add functions to expand PostDelayedTask interface. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Add fix to RunOnPluginThread() in host_plugin.cc Created 8 years, 10 months 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
« no previous file with comments | « content/public/browser/browser_thread.h ('k') | remoting/base/plugin_message_loop_proxy.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_ 5 #ifndef REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_
6 #define REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_ 6 #define REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_
7 7
8 #include "base/callback_forward.h" 8 #include "base/callback_forward.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/message_loop_proxy.h" 10 #include "base/message_loop_proxy.h"
11 #include "base/synchronization/lock.h" 11 #include "base/synchronization/lock.h"
12 #include "base/threading/platform_thread.h" 12 #include "base/threading/platform_thread.h"
13 13
14 namespace remoting { 14 namespace remoting {
15 15
16 // MessageLoopProxy for plugin main threads. 16 // MessageLoopProxy for plugin main threads.
17 class PluginMessageLoopProxy : public base::MessageLoopProxy { 17 class PluginMessageLoopProxy : public base::MessageLoopProxy {
18 public: 18 public:
19 class Delegate { 19 class Delegate {
20 public: 20 public:
21 Delegate() { } 21 Delegate() { }
22 virtual ~Delegate() { } 22 virtual ~Delegate() { }
23 23
24 virtual bool RunOnPluginThread( 24 virtual bool RunOnPluginThread(
25 int delay_ms, void(function)(void*), void* data) = 0; 25 base::TimeDelta delay, void(function)(void*), void* data) = 0;
26 }; 26 };
27 27
28 // Caller keeps ownership of delegate. 28 // Caller keeps ownership of delegate.
29 PluginMessageLoopProxy(Delegate* delegate); 29 PluginMessageLoopProxy(Delegate* delegate);
30 virtual ~PluginMessageLoopProxy(); 30 virtual ~PluginMessageLoopProxy();
31 31
32 void Detach(); 32 void Detach();
33 33
34 // base::MessageLoopProxy implementation. 34 // base::MessageLoopProxy implementation.
35 virtual bool PostDelayedTask( 35 virtual bool PostDelayedTask(
36 const tracked_objects::Location& from_here, 36 const tracked_objects::Location& from_here,
37 const base::Closure& task, 37 const base::Closure& task,
38 int64 delay_ms) OVERRIDE; 38 int64 delay_ms) OVERRIDE;
39 virtual bool PostDelayedTask(
40 const tracked_objects::Location& from_here,
41 const base::Closure& task,
42 base::TimeDelta delay) OVERRIDE;
43 virtual bool PostNonNestableDelayedTask(
44 const tracked_objects::Location& from_here,
45 const base::Closure& task,
46 int64 delay_ms) OVERRIDE;
39 virtual bool PostNonNestableDelayedTask( 47 virtual bool PostNonNestableDelayedTask(
40 const tracked_objects::Location& from_here, 48 const tracked_objects::Location& from_here,
41 const base::Closure& task, 49 const base::Closure& task,
42 int64 delay_ms) OVERRIDE; 50 base::TimeDelta delay) OVERRIDE;
43 51
44 virtual bool RunsTasksOnCurrentThread() const OVERRIDE; 52 virtual bool RunsTasksOnCurrentThread() const OVERRIDE;
45 53
46 private: 54 private:
47 static void TaskSpringboard(void* data); 55 static void TaskSpringboard(void* data);
48 56
49 void RunClosureIf(const base::Closure& task); 57 void RunClosureIf(const base::Closure& task);
50 58
51 base::PlatformThreadId plugin_thread_id_; 59 base::PlatformThreadId plugin_thread_id_;
52 60
53 // |lock_| must be acquired when accessing |delegate_|. 61 // |lock_| must be acquired when accessing |delegate_|.
54 base::Lock lock_; 62 base::Lock lock_;
55 Delegate* delegate_; 63 Delegate* delegate_;
56 64
57 DISALLOW_COPY_AND_ASSIGN(PluginMessageLoopProxy); 65 DISALLOW_COPY_AND_ASSIGN(PluginMessageLoopProxy);
58 }; 66 };
59 67
60 } // namespace remoting 68 } // namespace remoting
61 69
62 #endif // REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_ 70 #endif // REMOTING_BASE_PLUGIN_MESSAGE_LOOP_H_
OLDNEW
« no previous file with comments | « content/public/browser/browser_thread.h ('k') | remoting/base/plugin_message_loop_proxy.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698