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

Unified Diff: chrome/browser/media_gallery/media_storage_util.h

Issue 10829384: SystemMonitor: Pull device type into the device id (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/media_gallery/media_storage_util.h
diff --git a/chrome/browser/media_gallery/media_storage_util.h b/chrome/browser/media_gallery/media_storage_util.h
new file mode 100644
index 0000000000000000000000000000000000000000..2c47cbb88b7e6c1cfd2e6141d8705fa2e33852b8
--- /dev/null
+++ b/chrome/browser/media_gallery/media_storage_util.h
@@ -0,0 +1,75 @@
+// Copyright (c) 2012 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.
+
+// chrome::MediaStorageUtil provides information about storage devices attached
+// to the computer.
+
+#ifndef CHROME_BROWSER_MEDIA_GALLERY_MEDIA_STORAGE_UTIL_H_
+#define CHROME_BROWSER_MEDIA_GALLERY_MEDIA_STORAGE_UTIL_H_
+
+#include <string>
+
+#include "base/callback_forward.h"
+#include "base/file_path.h"
+#include "base/lazy_instance.h"
+
+namespace chrome {
+
+class MediaStorageUtil {
kmadhusu 2012/08/17 18:53:35 nit: Either move the comments from line 5 to here
vandebo (ex-Chrome) 2012/08/17 22:55:51 Seems unnecessary to me.
+ public:
+ enum Type {
+ // A USB mass storage device with a DCIM directory.
+ USB_MASS_STORAGE_WITH_DCIM,
+ // A USB mass storage device without a DCIM directory.
+ USB_MASS_STORAGE_NO_DCIM,
kmadhusu 2012/08/17 18:53:35 You might want to add TODO's (1) To handle mass st
vandebo (ex-Chrome) 2012/08/17 22:55:51 Where would you like me to add those TODOs?
kmadhusu 2012/08/20 17:13:49 You can add these TODO's in IsMediaDevice function
vandebo (ex-Chrome) 2012/08/20 18:35:14 Actually there's already TODO's in the implementat
+ // Mass storage not connected through USB - a proxy for fixed/removable.
+ OTHER_MASS_STORAGE,
+ // A MTP or PTP device.
+ USB_MTP,
+ };
+
+ // Makes a device id given properties of the device. A prefix dependant on
kmadhusu 2012/08/17 18:53:35 nit: dependent
kmadhusu 2012/08/17 18:53:35 nit: Returns device id ....
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+ // |type| is added so |unique_id| need only be unique within the given type.
+ static std::string MakeDeviceId(Type type, const std::string& unique_id);
+
+ // Extracts the device type from |device_id|.
kmadhusu 2012/08/17 18:53:35 nit: Extracts device |type| and |unique_id| given
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+ static void CrackDeviceId(const std::string& device_id,
+ Type* type, std::string* unique_id);
+
+ // Looks inside |device_id| to determine if it is a media device
+ // (type is USB_MASS_STORAGE_WITH_DCIM or USB_MTP).
kmadhusu 2012/08/17 18:53:35 A device of type USB_MASS_STORAGE_WITH_NO_DCIM can
vandebo (ex-Chrome) 2012/08/17 22:55:51 No, it would be type USB_MASS_STORAGE_WITH_DCIM in
+ static bool IsMediaDevice(const std::string& device_id);
+
+ // Looks inside |device_id| to determine if it is a media device
+ // (type isn't OTHER_MASS_STORAGE).
+ static bool IsRemovableDevice(const std::string& device_id);
kmadhusu 2012/08/17 18:53:35 If IsMediaDevice() returns true of USB_MASS_STORAG
+
+ // Determines if the device is attached to the computer.
+ static void IsDeviceAttached(const std::string& device_id,
+ const base::Callback<void(bool)>& callback);
kmadhusu 2012/08/17 18:53:35 nit: Can we create a typedef for the Query callbac
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+
+ // Given a path |input|, get the device_id, relative path from the root of
kmadhusu 2012/08/17 18:53:35 nit: Can we rename |input| to |path|? Since it is
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+ // the device, and the device name.
+ static void GetDeviceInfoFromPath(
+ const FilePath& input,
+ const base::Callback<void(std::string /*device id*/,
kmadhusu 2012/08/17 18:53:35 nit: /* ABC */ (Space after /*)
vandebo (ex-Chrome) 2012/08/17 22:55:51 Actually there's no clear guidance on this in the
+ FilePath /*path relative to device root*/,
+ string16 /*display name*/)>& callback);
+
+ // Get a FilePath for the given |device_id|. If the device isn't connected
+ // or isn't a mass storage type, the FilePath will be empty.
+ static void FindDevicePathById(
+ const std::string& device_id,
+ const base::Callback<void(FilePath)>& callback);
+
+ private:
+ MediaStorageUtil();
kmadhusu 2012/08/17 18:53:35 nit: Document this function // Do not instantiate
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+
+ static void FindUSBDeviceById(const std::string unique_id,
kmadhusu 2012/08/17 18:53:35 nit: Document this function (To specify that this
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+ const base::Callback<void(FilePath)>& callback);
kmadhusu 2012/08/17 18:53:35 DISALLOW_COPY_AND_ASSIGN(MediaStorageUtil);
vandebo (ex-Chrome) 2012/08/17 22:55:51 Done.
+};
+
+} // namespace chromeos
+
+#endif // CHROME_BROWSER_MEDIA_GALLERY_MEDIA_STORAGE_UTIL_H_

Powered by Google App Engine
This is Rietveld 408576698