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

Side by Side Diff: chrome/browser/chromeos/camera_presence_notifier.h

Issue 213623005: CameraPresenceNotifier observers removal supported. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 8 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
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 CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_ 5 #ifndef CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_
6 #define CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_ 6 #define CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_
7 7
8 #include "base/memory/singleton.h" 8 #include "base/memory/singleton.h"
9 #include "base/memory/weak_ptr.h" 9 #include "base/memory/weak_ptr.h"
10 #include "base/observer_list.h" 10 #include "base/observer_list.h"
11 #include "base/timer/timer.h" 11 #include "base/timer/timer.h"
12 12
13 namespace chromeos { 13 namespace chromeos {
14 14
15 // Camera presence status dispatcher. 15 // Camera presence status dispatcher.
16 class CameraPresenceNotifier { 16 class CameraPresenceNotifier {
17 public: 17 public:
18 class Observer { 18 class Observer {
19 public: 19 public:
20 virtual void OnCameraPresenceCheckDone(bool is_camera_present) = 0; 20 virtual void OnCameraPresenceCheckDone(bool is_camera_present) = 0;
21 protected: 21 protected:
22 virtual ~Observer() {} 22 virtual ~Observer() {
23 CameraPresenceNotifier::GetInstance()->RemoveObserver(this);
Nikita (slow) 2014/04/03 11:47:29 With virtual destructors all dtors for the type hi
24 }
23 }; 25 };
24 26
25 static CameraPresenceNotifier* GetInstance(); 27 static CameraPresenceNotifier* GetInstance();
26 28
27 void AddObserver(CameraPresenceNotifier::Observer* observer); 29 void AddObserver(CameraPresenceNotifier::Observer* observer);
28 void RemoveObserver(CameraPresenceNotifier::Observer* observer); 30 void RemoveObserver(CameraPresenceNotifier::Observer* observer);
29 31
30 private: 32 private:
31 friend struct DefaultSingletonTraits<CameraPresenceNotifier>; 33 friend struct DefaultSingletonTraits<CameraPresenceNotifier>;
32 CameraPresenceNotifier(); 34 CameraPresenceNotifier();
(...skipping 13 matching lines...) Expand all
46 48
47 ObserverList<Observer> observers_; 49 ObserverList<Observer> observers_;
48 50
49 DISALLOW_COPY_AND_ASSIGN(CameraPresenceNotifier); 51 DISALLOW_COPY_AND_ASSIGN(CameraPresenceNotifier);
50 }; 52 };
51 53
52 } // namespace chromeos 54 } // namespace chromeos
53 55
54 #endif // CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_ 56 #endif // CHROME_BROWSER_CHROMEOS_CAMERA_PRESENCE_NOTIFIER_H_
55 57
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698