Index: chrome/browser/chromeos/dbus/cros_disks_client.h |
diff --git a/chrome/browser/chromeos/dbus/cros_disks_client.h b/chrome/browser/chromeos/dbus/cros_disks_client.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..732927cbd5be9c7a29ed8b066c4314d02518ea9b |
--- /dev/null |
+++ b/chrome/browser/chromeos/dbus/cros_disks_client.h |
@@ -0,0 +1,230 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_CHROMEOS_DBUS_CROS_DISKS_CLIENT_H_ |
+#define CHROME_BROWSER_CHROMEOS_DBUS_CROS_DISKS_CLIENT_H_ |
+#pragma once |
+ |
+#include <map> |
+#include <string> |
+#include <vector> |
+ |
+#include "base/basictypes.h" |
+ |
+namespace dbus { |
+class Bus; |
+} |
+ |
+namespace chromeos { |
+ |
+enum MountType { |
satorux1
2011/11/08 18:07:22
I know this is just inheriting from the original c
hashimoto
2011/11/09 02:33:25
Done.
|
+ MOUNT_TYPE_INVALID, |
+ MOUNT_TYPE_DEVICE, |
+ MOUNT_TYPE_ARCHIVE, |
+ MOUNT_TYPE_NETWORK_STORAGE |
satorux1
2011/11/08 18:07:22
Let's add a comma. It's a good practice, as it'll
hashimoto
2011/11/09 02:33:25
Done.
|
+}; |
+ |
+enum DeviceType { |
+ FLASH, |
+ HDD, |
+ OPTICAL, |
+ UNDEFINED |
+}; |
+ |
+enum MountError { |
+ MOUNT_ERROR_NONE = 0, |
+ MOUNT_ERROR_UNKNOWN = 1, |
+ MOUNT_ERROR_INTERNAL = 2, |
+ MOUNT_ERROR_UNKNOWN_FILESYSTEM = 101, |
+ MOUNT_ERROR_UNSUPORTED_FILESYSTEM = 102, |
+ MOUNT_ERROR_INVALID_ARCHIVE = 201, |
+ MOUNT_ERROR_LIBRARY_NOT_LOADED = 501, |
+ MOUNT_ERROR_PATH_UNMOUNTED = 901 |
+ // TODO(tbarzic): Add more error codes as they get added to cros-disks and |
+ // consider doing explicit translation from cros-disks error_types. |
+}; |
+ |
+typedef std::vector<std::pair<std::string, std::string> > MountPathOptions; |
satorux1
2011/11/08 18:07:22
Why not map<string>? Maybe the order matters? Woul
hashimoto
2011/11/09 02:33:25
Removed because it is no longer used.
|
+ |
+enum CrosDisksClientEventType { |
+ MOUNT_DISK_ADDED, |
+ MOUNT_DISK_REMOVED, |
+ MOUNT_DISK_CHANGED, |
+ MOUNT_DISK_MOUNTED, |
+ MOUNT_DISK_UNMOUNTED, |
+ MOUNT_DEVICE_ADDED, |
+ MOUNT_DEVICE_REMOVED, |
+ MOUNT_DEVICE_SCANNED, |
+ MOUNT_FORMATTING_STARTED, |
+ MOUNT_FORMATTING_FINISHED |
+}; |
+ |
+enum MountCondition { |
+ MOUNT_CONDITION_NONE, |
+ MOUNT_CONDITION_UNKNOWN_FILESYSTEM, |
+ MOUNT_CONDITION_UNSUPPORTED_FILESYSTEM |
+}; |
+ |
+// This class handles the interaction with cros-disks. |
+// Classes can add themselves as observers. |
+class CrosDisksClient { |
+ public: |
+ enum MountEvent { |
+ MOUNTING, |
+ UNMOUNTING |
+ }; |
+ // Used to house an instance of each found mount device. |
+ class Disk { |
+ public: |
+ Disk(const std::string& device_path, |
+ const std::string& mount_path, |
+ const std::string& system_path, |
+ const std::string& file_path, |
+ const std::string& device_label, |
+ const std::string& drive_label, |
+ const std::string& parent_path, |
+ const std::string& system_path_prefix, |
+ DeviceType device_type, |
+ uint64 total_size, |
+ bool is_parent, |
+ bool is_read_only, |
+ bool has_media, |
+ bool on_boot_device, |
+ bool is_hidden); |
+ ~Disk(); |
+ |
+ // The path of the device, used by devicekit-disks. |
+ const std::string& device_path() const { return device_path_; } |
satorux1
2011/11/08 18:07:22
Please add a blank line between accessors. I think
hashimoto
2011/11/09 02:33:25
Done.
|
+ // The path to the mount point of this device. Will be empty if not mounted. |
+ const std::string& mount_path() const { return mount_path_; } |
+ // The path of the device according to the udev system. |
+ const std::string& system_path() const { return system_path_; } |
+ // The path of the device according to filesystem. |
+ const std::string& file_path() const { return file_path_; } |
+ // Device's label. |
+ const std::string& device_label() const { return device_label_; } |
+ // If disk is a parent, then its label, else parents label. |
+ const std::string& drive_label() const { return drive_label_; } |
+ // Parents device path. If device has no parent, then empty string. |
+ const std::string& parent_path() const { return parent_path_; } |
+ // Path of the system device this device's block is a part of. |
+ const std::string& system_path_prefix() const { |
+ return system_path_prefix_; |
+ } |
+ // Device type. |
+ DeviceType device_type() const { return device_type_; } |
+ // Total size of the device. |
+ uint64 total_size() const { return total_size_; } |
+ // Is the device is a parent device (i.e. sdb rather than sdb1). |
+ bool is_parent() const { return is_parent_; } |
+ // Is the device read only. |
+ bool is_read_only() const { return is_read_only_; } |
+ // Does the device contains media. |
+ bool has_media() const { return has_media_; } |
+ // Is the device on the boot device. |
+ bool on_boot_device() const { return on_boot_device_; } |
+ // Shoud the device be shown in the UI, or automounted. |
+ bool is_hidden() const { return is_hidden_; } |
+ |
+ void set_mount_path(const std::string& mount_path) { |
+ mount_path_ = mount_path; |
+ } |
+ void clear_mount_path() { mount_path_.clear(); } |
+ |
+ private: |
+ std::string device_path_; |
+ std::string mount_path_; |
+ std::string system_path_; |
+ std::string file_path_; |
+ std::string device_label_; |
+ std::string drive_label_; |
+ std::string parent_path_; |
+ std::string system_path_prefix_; |
+ DeviceType device_type_; |
+ uint64 total_size_; |
+ bool is_parent_; |
+ bool is_read_only_; |
+ bool has_media_; |
+ bool on_boot_device_; |
+ bool is_hidden_; |
+ }; |
+ typedef std::map<std::string, Disk*> DiskMap; |
+ typedef std::map<std::string, std::string> PathMap; |
+ |
+ struct MountPointInfo { |
+ std::string source_path; |
+ std::string mount_path; |
+ MountType mount_type; |
+ MountCondition mount_condition; |
+ |
+ MountPointInfo(const std::string& source, const std::string& mount, |
+ const MountType type, MountCondition condition) |
+ : source_path(source), |
+ mount_path(mount), |
+ mount_type(type), |
+ mount_condition(condition) { |
+ } |
+ }; |
+ |
+ // MountPointMap key is mount_path. |
+ typedef std::map<std::string, MountPointInfo> MountPointMap; |
+ |
+ typedef void(*UnmountDeviceRecursiveCallbackType)(void*, bool); |
+ |
+ class Observer { |
+ public: |
+ virtual ~Observer() {} |
+ // Async API events. |
+ virtual void DiskChanged(CrosDisksClientEventType event, |
+ const Disk* disk) = 0; |
+ virtual void DeviceChanged(CrosDisksClientEventType event, |
+ const std::string& device_path) = 0; |
+ virtual void MountCompleted(MountEvent event_type, |
+ MountError error_code, |
+ const MountPointInfo& mount_info) = 0; |
satorux1
2011/11/08 18:07:22
This may be obvious, but please could you add func
hashimoto
2011/11/09 02:33:25
Done.
|
+ }; |
+ |
+ virtual ~CrosDisksClient() {} |
+ virtual void AddObserver(Observer* observer) = 0; |
+ virtual void RemoveObserver(Observer* observer) = 0; |
+ virtual const DiskMap& disks() const = 0; |
+ virtual const MountPointMap& mount_points() const = 0; |
+ |
+ virtual void RequestMountInfoRefresh() = 0; |
satorux1
2011/11/08 18:07:22
Function comment is missing. Please check other fu
hashimoto
2011/11/09 02:33:25
Done.
|
+ virtual void MountPath(const std::string& source_path, |
+ MountType type, |
+ const MountPathOptions& options) = 0; |
+ // |path| is device's mount path. |
+ virtual void UnmountPath(const std::string& path) = 0; |
+ |
+ // Retrieves total and remaining available size on |mount_path|. |
+ virtual void GetSizeStatsOnFileThread(const std::string& mount_path, |
+ size_t* total_size_kb, |
+ size_t* remaining_size_kb) = 0; |
+ |
+ // Formats device given its file path. |
+ // Example: file_path: /dev/sdb1 |
+ virtual void FormatUnmountedDevice(const std::string& file_path) = 0; |
+ |
+ // Formats Device given its mount path. Unmount's the device |
+ // Example: mount_path: /media/VOLUME_LABEL |
+ virtual void FormatMountedDevice(const std::string& mount_path) = 0; |
+ |
+ // Unmounts device_poath and all of its known children. |
+ virtual void UnmountDeviceRecursive(const std::string& device_path, |
+ UnmountDeviceRecursiveCallbackType callback, void* user_data) = 0; |
+ |
+ // Helper functions for parameter conversions. |
+ static std::string MountTypeToString(MountType type); |
+ static MountType MountTypeFromString(const std::string& type_str); |
+ static std::string MountConditionToString(MountCondition type); |
+ |
+ // Factory function, creates a new instance and returns ownership. |
+ // For normal usage, access the singleton via DBusThreadManager::Get(). |
+ static CrosDisksClient* Create(dbus::Bus* bus); |
+}; |
+ |
+} // namespace chromeos |
+ |
+#endif // CHROME_BROWSER_CHROMEOS_DBUS_CROS_DISKS_CLIENT_H_ |