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

Side by Side Diff: chrome/browser/chromeos/cros/mount_library.h

Issue 7457001: Adding support for mount point different from removable devices to MountLibrary (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 5 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 (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_CROS_MOUNT_LIBRARY_H_ 5 #ifndef CHROME_BROWSER_CHROMEOS_CROS_MOUNT_LIBRARY_H_
6 #define CHROME_BROWSER_CHROMEOS_CROS_MOUNT_LIBRARY_H_ 6 #define CHROME_BROWSER_CHROMEOS_CROS_MOUNT_LIBRARY_H_
7 #pragma once 7 #pragma once
8 8
9 #include <map>
9 #include <string> 10 #include <string>
10 #include <map>
11 11
12 #include "base/memory/singleton.h" 12 #include "base/memory/singleton.h"
13 #include "base/observer_list.h" 13 #include "base/observer_list.h"
14 #include "base/time.h" 14 #include "base/time.h"
15 #include "third_party/cros/chromeos_mount.h" 15 #include "third_party/cros/chromeos_mount.h"
16 16
17 namespace chromeos { 17 namespace chromeos {
18 18
19 typedef enum MountLibraryEventType { 19 typedef enum MountLibraryEventType {
20 MOUNT_DISK_ADDED, 20 MOUNT_DISK_ADDED,
21 MOUNT_DISK_REMOVED, 21 MOUNT_DISK_REMOVED,
22 MOUNT_DISK_CHANGED, 22 MOUNT_DISK_CHANGED,
23 MOUNT_DISK_MOUNTED, 23 MOUNT_DISK_MOUNTED,
24 MOUNT_DISK_UNMOUNTED, 24 MOUNT_DISK_UNMOUNTED,
25 MOUNT_DEVICE_ADDED, 25 MOUNT_DEVICE_ADDED,
26 MOUNT_DEVICE_REMOVED, 26 MOUNT_DEVICE_REMOVED,
27 MOUNT_DEVICE_SCANNED 27 MOUNT_DEVICE_SCANNED
28 } MountLibraryEventType; 28 } MountLibraryEventType;
29 29
30 // This class handles the interaction with the ChromeOS mount library APIs. 30 // This class handles the interaction with the ChromeOS mount library APIs.
31 // Classes can add themselves as observers. Users can get an instance of this 31 // Classes can add themselves as observers. Users can get an instance of this
32 // library class like this: chromeos::CrosLibrary::Get()->GetMountLibrary() 32 // library class like this: chromeos::CrosLibrary::Get()->GetMountLibrary()
33 class MountLibrary { 33 class MountLibrary {
34 public: 34 public:
35 enum MountEvent {
36 MOUNTING,
37 UNMOUNTING
38 };
35 // Used to house an instance of each found mount device. 39 // Used to house an instance of each found mount device.
36 class Disk { 40 class Disk {
37 public: 41 public:
38 Disk(const std::string& device_path, 42 Disk(const std::string& device_path,
39 const std::string& mount_path, 43 const std::string& mount_path,
40 const std::string& system_path, 44 const std::string& system_path,
41 const std::string& file_path, 45 const std::string& file_path,
42 const std::string& device_label, 46 const std::string& device_label,
43 const std::string& drive_label, 47 const std::string& drive_label,
44 const std::string& parent_path, 48 const std::string& parent_path,
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
90 std::string parent_path_; 94 std::string parent_path_;
91 DeviceType device_type_; 95 DeviceType device_type_;
92 uint64 total_size_; 96 uint64 total_size_;
93 bool is_parent_; 97 bool is_parent_;
94 bool is_read_only_; 98 bool is_read_only_;
95 bool has_media_; 99 bool has_media_;
96 bool on_boot_device_; 100 bool on_boot_device_;
97 }; 101 };
98 typedef std::map<std::string, Disk*> DiskMap; 102 typedef std::map<std::string, Disk*> DiskMap;
99 103
104 // MountPointInfo: {mount_path, mount_type}.
105 struct MountPointInfo {
106 std::string source_path;
107 std::string mount_path;
108 MountType mount_type;
109
110 MountPointInfo(const char* source, const char* mount, const MountType type)
111 : source_path(source ? source : ""),
112 mount_path(mount ? mount : ""),
113 mount_type(type) {
114 }
115 };
116
117 // MountPointMap key is source_path.
118 typedef std::map<std::string, MountPointInfo> MountPointMap;
119
100 typedef void(*UnmountDeviceRecursiveCallbackType)(void*, bool); 120 typedef void(*UnmountDeviceRecursiveCallbackType)(void*, bool);
101 121
102 class Observer { 122 class Observer {
103 public: 123 public:
104 virtual ~Observer() {} 124 virtual ~Observer() {}
105 // Async API events. 125 // Async API events.
106 virtual void DiskChanged(MountLibraryEventType event, 126 virtual void DiskChanged(MountLibraryEventType event,
107 const Disk* disk) = 0; 127 const Disk* disk) = 0;
108 virtual void DeviceChanged(MountLibraryEventType event, 128 virtual void DeviceChanged(MountLibraryEventType event,
109 const std::string& device_path ) = 0; 129 const std::string& device_path ) = 0;
130 virtual void MountCompleted(MountEvent event_type,
131 MountError error_code,
132 const MountPointInfo& mount_info) = 0;
110 }; 133 };
111 134
112 virtual ~MountLibrary() {} 135 virtual ~MountLibrary() {}
113 virtual void AddObserver(Observer* observer) = 0; 136 virtual void AddObserver(Observer* observer) = 0;
114 virtual void RemoveObserver(Observer* observer) = 0; 137 virtual void RemoveObserver(Observer* observer) = 0;
115 virtual const DiskMap& disks() const = 0; 138 virtual const DiskMap& disks() const = 0;
139 virtual const MountPointMap& mount_points() const = 0;
140
141 virtual std::string MountTypeToString(MountType type) const = 0;
142 virtual MountType MountTypeFromString(const std::string& type_str) const = 0;
116 143
117 virtual void RequestMountInfoRefresh() = 0; 144 virtual void RequestMountInfoRefresh() = 0;
118 virtual void MountPath(const char* device_path) = 0; 145 virtual void MountPath(const char* source_path,
119 virtual void UnmountPath(const char* device_path) = 0; 146 MountType type,
147 const MountPathOptions& options) = 0;
148 // |path| may be source od mount path.
149 virtual void UnmountPath(const char* path) = 0;
120 150
121 // Unmounts device_poath and all of its known children. 151 // Unmounts device_poath and all of its known children.
122 virtual void UnmountDeviceRecursive(const char* device_path, 152 virtual void UnmountDeviceRecursive(const char* device_path,
123 UnmountDeviceRecursiveCallbackType callback, void* user_data) = 0; 153 UnmountDeviceRecursiveCallbackType callback, void* user_data) = 0;
124 154
125 // Factory function, creates a new instance and returns ownership. 155 // Factory function, creates a new instance and returns ownership.
126 // For normal usage, access the singleton via CrosLibrary::Get(). 156 // For normal usage, access the singleton via CrosLibrary::Get().
127 static MountLibrary* GetImpl(bool stub); 157 static MountLibrary* GetImpl(bool stub);
128 }; 158 };
129 159
130 } // namespace chromeos 160 } // namespace chromeos
131 161
132 #endif // CHROME_BROWSER_CHROMEOS_CROS_MOUNT_LIBRARY_H_ 162 #endif // CHROME_BROWSER_CHROMEOS_CROS_MOUNT_LIBRARY_H_
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/cros/mock_mount_library.cc ('k') | chrome/browser/chromeos/cros/mount_library.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698