OLD | NEW |
| (Empty) |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef CONTENT_RENDERER_MEDIA_SCOPED_LOOP_OBSERVER_H_ | |
6 #define CONTENT_RENDERER_MEDIA_SCOPED_LOOP_OBSERVER_H_ | |
7 | |
8 #include "base/memory/ref_counted.h" | |
9 #include "base/message_loop.h" | |
10 #include "base/message_loop_proxy.h" | |
11 | |
12 namespace base { | |
13 class WaitableEvent; | |
14 } | |
15 | |
16 // A common base class for AudioDevice and AudioInputDevice that manages | |
17 // a message loop pointer and monitors it for destruction. If the object goes | |
18 // out of scope before the message loop, the object will automatically remove | |
19 // itself from the message loop's list of destruction observers. | |
20 // NOTE: The class that inherits from this class must implement the | |
21 // WillDestroyCurrentMessageLoop virtual method from DestructionObserver. | |
22 class ScopedLoopObserver | |
23 : public MessageLoop::DestructionObserver { | |
24 public: | |
25 explicit ScopedLoopObserver( | |
26 const scoped_refptr<base::MessageLoopProxy>& message_loop); | |
27 | |
28 protected: | |
29 virtual ~ScopedLoopObserver(); | |
30 | |
31 // Accessor to the loop that's used by the derived class. | |
32 const scoped_refptr<base::MessageLoopProxy>& message_loop() { return loop_; } | |
33 | |
34 private: | |
35 // Call to add or remove ourselves from the list of destruction observers for | |
36 // the message loop. | |
37 void ObserveLoopDestruction(bool enable, base::WaitableEvent* done); | |
38 | |
39 // A pointer to the message loop's proxy. In case the loop gets destroyed | |
40 // before this object goes out of scope, PostTask etc will fail but not crash. | |
41 scoped_refptr<base::MessageLoopProxy> loop_; | |
42 | |
43 DISALLOW_COPY_AND_ASSIGN(ScopedLoopObserver); | |
44 }; | |
45 | |
46 #endif // CONTENT_RENDERER_MEDIA_SCOPED_LOOP_OBSERVER_H_ | |
OLD | NEW |