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

Side by Side Diff: chrome/browser/storage_monitor/removable_device_notifications_mac.h

Issue 12334096: Regularize ownerships and lifecycle for storage monitor platform classes. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Fix mac CF Ref check Created 7 years, 9 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
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 CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_ 5 #ifndef CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_
6 #define CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_ 6 #define CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_
7 7
8 #include <DiskArbitration/DiskArbitration.h> 8 #include <DiskArbitration/DiskArbitration.h>
9 #include <map> 9 #include <map>
10 10
11 #include "base/mac/scoped_cftyperef.h" 11 #include "base/mac/scoped_cftyperef.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "chrome/browser/storage_monitor/disk_info_mac.h" 13 #include "chrome/browser/storage_monitor/disk_info_mac.h"
14 #include "chrome/browser/storage_monitor/storage_monitor.h" 14 #include "chrome/browser/storage_monitor/storage_monitor.h"
15 15
16 namespace chrome { 16 namespace chrome {
17 17
18 class ImageCaptureDeviceManager;
19
18 // This class posts notifications to listeners when a new disk 20 // This class posts notifications to listeners when a new disk
19 // is attached, removed, or changed. 21 // is attached, removed, or changed.
20 class RemovableDeviceNotificationsMac 22 class RemovableDeviceNotificationsMac
21 : public StorageMonitor, 23 : public StorageMonitor,
22 public base::RefCountedThreadSafe<RemovableDeviceNotificationsMac> { 24 public base::RefCountedThreadSafe<RemovableDeviceNotificationsMac> {
23 public: 25 public:
24 enum UpdateType { 26 enum UpdateType {
25 UPDATE_DEVICE_ADDED, 27 UPDATE_DEVICE_ADDED,
26 UPDATE_DEVICE_CHANGED, 28 UPDATE_DEVICE_CHANGED,
27 UPDATE_DEVICE_REMOVED, 29 UPDATE_DEVICE_REMOVED,
28 }; 30 };
29 31
30 // Should only be called by browser start up code. Use GetInstance() instead. 32 // Should only be called by browser start up code. Use GetInstance() instead.
31 RemovableDeviceNotificationsMac(); 33 RemovableDeviceNotificationsMac();
32 34
35 void Init();
vandebo (ex-Chrome) 2013/03/01 22:36:41 Should Init go on StorageMonitor, since we expect
Greg Billock 2013/03/01 23:08:03 I thought about this. I think we do want two-phase
36
33 void UpdateDisk(const DiskInfoMac& info, UpdateType update_type); 37 void UpdateDisk(const DiskInfoMac& info, UpdateType update_type);
34 38
35 virtual bool GetStorageInfoForPath( 39 virtual bool GetStorageInfoForPath(
36 const base::FilePath& path, 40 const base::FilePath& path,
37 StorageInfo* device_info) const OVERRIDE; 41 StorageInfo* device_info) const OVERRIDE;
38 42
39 // Returns the storage size of the device present at |location|. If the 43 // Returns the storage size of the device present at |location|. If the
40 // device information is unavailable, returns zero. |location| must be a 44 // device information is unavailable, returns zero. |location| must be a
41 // top-level mount point. 45 // top-level mount point.
42 virtual uint64 GetStorageSize(const std::string& location) const OVERRIDE; 46 virtual uint64 GetStorageSize(const std::string& location) const OVERRIDE;
(...skipping 11 matching lines...) Expand all
54 bool ShouldPostNotificationForDisk(const DiskInfoMac& info) const; 58 bool ShouldPostNotificationForDisk(const DiskInfoMac& info) const;
55 bool FindDiskWithMountPoint(const base::FilePath& mount_point, 59 bool FindDiskWithMountPoint(const base::FilePath& mount_point,
56 DiskInfoMac* info) const; 60 DiskInfoMac* info) const;
57 61
58 base::mac::ScopedCFTypeRef<DASessionRef> session_; 62 base::mac::ScopedCFTypeRef<DASessionRef> session_;
59 // Maps disk bsd names to disk info objects. This map tracks all mountable 63 // Maps disk bsd names to disk info objects. This map tracks all mountable
60 // devices on the system though only notifications for removable devices are 64 // devices on the system though only notifications for removable devices are
61 // posted. 65 // posted.
62 std::map<std::string, DiskInfoMac> disk_info_map_; 66 std::map<std::string, DiskInfoMac> disk_info_map_;
63 67
68 scoped_ptr<chrome::ImageCaptureDeviceManager> image_capture_device_manager_;
69
64 DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationsMac); 70 DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationsMac);
65 }; 71 };
66 72
67 } // namespace chrome 73 } // namespace chrome
68 74
69 #endif // CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_ 75 #endif // CHROME_BROWSER_STORAGE_MONITOR_REMOVABLE_DEVICE_NOTIFICATIONS_MAC_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698