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

Side by Side Diff: Source/platform/WebThreadSupportingGC.h

Issue 857193004: [NOT READY FOR REVIEW YET]workers: Some refactoring to allow creating new kind of worker threads Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: . Created 5 years, 11 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 | Annotate | Revision Log
« no previous file with comments | « Source/core/workers/WorkerThread.cpp ('k') | Source/platform/WebThreadSupportingGC.cpp » ('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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 WebThreadSupportingGC_h 5 #ifndef WebThreadSupportingGC_h
6 #define WebThreadSupportingGC_h 6 #define WebThreadSupportingGC_h
7 7
8 #include "platform/heap/glue/MessageLoopInterruptor.h" 8 #include "platform/heap/glue/MessageLoopInterruptor.h"
9 #include "platform/heap/glue/PendingGCRunner.h" 9 #include "platform/heap/glue/PendingGCRunner.h"
10 #include "public/platform/Platform.h" 10 #include "public/platform/Platform.h"
11 #include "public/platform/WebThread.h" 11 #include "public/platform/WebThread.h"
12 #include "wtf/Noncopyable.h" 12 #include "wtf/Noncopyable.h"
13 #include "wtf/OwnPtr.h" 13 #include "wtf/OwnPtr.h"
14 #include "wtf/PassOwnPtr.h" 14 #include "wtf/PassOwnPtr.h"
15 15
16 namespace blink { 16 namespace blink {
17 17
18 // WebThreadSupportingGC wraps a WebThread and adds support for attaching 18 // WebThreadSupportingGC wraps a WebThread and adds support for attaching
19 // to and detaching from the Blink GC infrastructure. The attachGC method 19 // to and detaching from the Blink GC infrastructure. The attachGC method
20 // must be called during initialization on the WebThread and before the 20 // must be called during initialization on the WebThread and before the
21 // thread allocates any objects managed by the Blink GC. The detach GC 21 // thread allocates any objects managed by the Blink GC. The detach GC
22 // method must be called on the WebThread during shutdown when the thread 22 // method must be called on the WebThread during shutdown when the thread
23 // no longer needs to access objects managed by the Blink GC. 23 // no longer needs to access objects managed by the Blink GC.
24 class PLATFORM_EXPORT WebThreadSupportingGC final { 24 class PLATFORM_EXPORT WebThreadSupportingGC {
25 WTF_MAKE_NONCOPYABLE(WebThreadSupportingGC);
26 public: 25 public:
27 static PassOwnPtr<WebThreadSupportingGC> create(const char*); 26 static PassOwnPtr<WebThreadSupportingGC> create(const char*);
28 ~WebThreadSupportingGC(); 27
28 virtual ~WebThreadSupportingGC();
29 29
30 void postTask(WebThread::Task* task) 30 void postTask(WebThread::Task* task)
31 { 31 {
32 m_thread->postTask(task); 32 platformThread().postTask(task);
33 } 33 }
34 34
35 void postDelayedTask(WebThread::Task* task, long long delayMs) 35 void postDelayedTask(WebThread::Task* task, long long delayMs)
36 { 36 {
37 m_thread->postDelayedTask(task, delayMs); 37 platformThread().postDelayedTask(task, delayMs);
38 } 38 }
39 39
40 bool isCurrentThread() const 40 bool isCurrentThread() const
41 { 41 {
42 return m_thread->isCurrentThread(); 42 return platformThread().isCurrentThread();
43 } 43 }
44 44
45 void addTaskObserver(WebThread::TaskObserver* observer) 45 void addTaskObserver(WebThread::TaskObserver* observer)
46 { 46 {
47 m_thread->addTaskObserver(observer); 47 platformThread().addTaskObserver(observer);
48 } 48 }
49 49
50 void removeTaskObserver(WebThread::TaskObserver* observer) 50 void removeTaskObserver(WebThread::TaskObserver* observer)
51 { 51 {
52 m_thread->removeTaskObserver(observer); 52 platformThread().removeTaskObserver(observer);
53 }
54
55 void enterRunLoop()
56 {
57 m_thread->enterRunLoop();
58 }
59
60 void exitRunLoop()
61 {
62 m_thread->exitRunLoop();
63 } 53 }
64 54
65 void attachGC(); 55 void attachGC();
66 void detachGC(); 56 void detachGC();
67 57
68 WebThread& platformThread() const 58 virtual WebThread& platformThread() const = 0;
69 {
70 ASSERT(m_thread);
71 return *m_thread;
72 }
73 59
74 private: 60 private:
75 explicit WebThreadSupportingGC(const char*);
76
77 OwnPtr<PendingGCRunner> m_pendingGCRunner; 61 OwnPtr<PendingGCRunner> m_pendingGCRunner;
78 OwnPtr<MessageLoopInterruptor> m_messageLoopInterruptor; 62 OwnPtr<MessageLoopInterruptor> m_messageLoopInterruptor;
79
80 // FIXME: This has to be last because of crbug.com/401397.
81 // A WorkerThread might get deleted before it had a chance to properly
82 // shut down. By deleting the WebThread first, we can guarantee that
83 // no pending tasks on the thread might want to access any of the other
84 // members during the WorkerThread's destruction.
85 OwnPtr<WebThread> m_thread;
86 }; 63 };
87 64
88 } 65 }
89 66
90 #endif 67 #endif
OLDNEW
« no previous file with comments | « Source/core/workers/WorkerThread.cpp ('k') | Source/platform/WebThreadSupportingGC.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698