diff options
Diffstat (limited to 'webkit/glue/webthread_impl.h')
-rw-r--r-- | webkit/glue/webthread_impl.h | 30 |
1 files changed, 26 insertions, 4 deletions
diff --git a/webkit/glue/webthread_impl.h b/webkit/glue/webthread_impl.h index 2112536..a26de79 100644 --- a/webkit/glue/webthread_impl.h +++ b/webkit/glue/webthread_impl.h @@ -4,6 +4,8 @@ #ifndef WEBKIT_GLUE_WEBTHREAD_IMPL_H_ #define WEBKIT_GLUE_WEBTHREAD_IMPL_H_ +#include <map> + #include "base/threading/thread.h" #include "base/memory/scoped_ptr.h" #include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebThread.h" @@ -11,9 +13,23 @@ namespace webkit_glue { -class WebThreadImpl : public WebKit::WebThread { +class WebThreadBase : public WebKit::WebThread { public: - WEBKIT_GLUE_EXPORT WebThreadImpl(const char* name); + virtual void addTaskObserver(TaskObserver* observer); + virtual void removeTaskObserver(TaskObserver* observer); + + protected: + virtual bool IsCurrentThread() const = 0; + + private: + class TaskObserverAdapter; + typedef std::map<TaskObserver*, TaskObserverAdapter*> TaskObserverMap; + TaskObserverMap task_observer_map_; +}; + +class WebThreadImpl : public WebThreadBase { + public: + WEBKIT_GLUE_EXPORT explicit WebThreadImpl(const char* name); WEBKIT_GLUE_EXPORT virtual ~WebThreadImpl(); virtual void postTask(Task* task) OVERRIDE; @@ -22,18 +38,24 @@ class WebThreadImpl : public WebKit::WebThread { MessageLoop* message_loop() const { return thread_->message_loop(); } protected: + virtual bool IsCurrentThread() const; + + private: scoped_ptr<base::Thread> thread_; }; -class WebThreadImplForMessageLoop : public WebKit::WebThread { +class WebThreadImplForMessageLoop : public WebThreadBase { public: - WebThreadImplForMessageLoop(base::MessageLoopProxy* message_loop); + explicit WebThreadImplForMessageLoop(base::MessageLoopProxy* message_loop); virtual ~WebThreadImplForMessageLoop(); virtual void postTask(Task* task) OVERRIDE; virtual void postDelayedTask(Task* task, long long delay_ms) OVERRIDE; protected: + virtual bool IsCurrentThread() const; + + private: scoped_refptr<base::MessageLoopProxy> message_loop_; }; |