| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ | 5 #ifndef CHROME_BROWSER_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ |
| 6 #define CHROME_BROWSER_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ | 6 #define CHROME_BROWSER_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ |
| 7 | 7 |
| 8 #include <queue> | 8 #include <queue> |
| 9 | 9 |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/files/file.h" |
| 11 #include "base/location.h" | 12 #include "base/location.h" |
| 12 #include "base/memory/scoped_ptr.h" | 13 #include "base/memory/scoped_ptr.h" |
| 13 #include "base/memory/weak_ptr.h" | 14 #include "base/memory/weak_ptr.h" |
| 14 #include "base/platform_file.h" | |
| 15 #include "base/strings/string16.h" | 15 #include "base/strings/string16.h" |
| 16 #include "base/win/scoped_comptr.h" | 16 #include "base/win/scoped_comptr.h" |
| 17 #include "chrome/browser/media_galleries/fileapi/mtp_device_async_delegate.h" | 17 #include "chrome/browser/media_galleries/fileapi/mtp_device_async_delegate.h" |
| 18 #include "webkit/browser/fileapi/async_file_util.h" | 18 #include "webkit/browser/fileapi/async_file_util.h" |
| 19 | 19 |
| 20 namespace base { | 20 namespace base { |
| 21 class FilePath; | 21 class FilePath; |
| 22 class SequencedTaskRunner; | 22 class SequencedTaskRunner; |
| 23 } | 23 } |
| 24 | 24 |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 65 | 65 |
| 66 enum InitializationState { | 66 enum InitializationState { |
| 67 UNINITIALIZED = 0, | 67 UNINITIALIZED = 0, |
| 68 PENDING_INIT, | 68 PENDING_INIT, |
| 69 INITIALIZED | 69 INITIALIZED |
| 70 }; | 70 }; |
| 71 | 71 |
| 72 // Used to represent pending task details. | 72 // Used to represent pending task details. |
| 73 struct PendingTaskInfo { | 73 struct PendingTaskInfo { |
| 74 PendingTaskInfo(const tracked_objects::Location& location, | 74 PendingTaskInfo(const tracked_objects::Location& location, |
| 75 const base::Callback<base::PlatformFileError(void)>& task, | 75 const base::Callback<base::File::Error(void)>& task, |
| 76 const base::Callback<void(base::PlatformFileError)>& reply); | 76 const base::Callback<void(base::File::Error)>& reply); |
| 77 | 77 |
| 78 const tracked_objects::Location location; | 78 const tracked_objects::Location location; |
| 79 const base::Callback<base::PlatformFileError(void)> task; | 79 const base::Callback<base::File::Error(void)> task; |
| 80 const base::Callback<void(base::PlatformFileError)> reply; | 80 const base::Callback<void(base::File::Error)> reply; |
| 81 }; | 81 }; |
| 82 | 82 |
| 83 // Defers the device initializations until the first file operation request. | 83 // Defers the device initializations until the first file operation request. |
| 84 // Do all the initializations in EnsureInitAndRunTask() function. | 84 // Do all the initializations in EnsureInitAndRunTask() function. |
| 85 MTPDeviceDelegateImplWin(const base::string16& registered_device_path, | 85 MTPDeviceDelegateImplWin(const base::string16& registered_device_path, |
| 86 const base::string16& pnp_device_id, | 86 const base::string16& pnp_device_id, |
| 87 const base::string16& storage_object_id); | 87 const base::string16& storage_object_id); |
| 88 | 88 |
| 89 // Destructed via CancelPendingTasksAndDeleteDelegate(). | 89 // Destructed via CancelPendingTasksAndDeleteDelegate(). |
| 90 virtual ~MTPDeviceDelegateImplWin(); | 90 virtual ~MTPDeviceDelegateImplWin(); |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 133 // Called when GetFileInfo() completes. |file_info| specifies the requested | 133 // Called when GetFileInfo() completes. |file_info| specifies the requested |
| 134 // file details. |error| specifies the platform file error code. | 134 // file details. |error| specifies the platform file error code. |
| 135 // | 135 // |
| 136 // If the GetFileInfo() succeeds, |success_callback| is invoked to notify the | 136 // If the GetFileInfo() succeeds, |success_callback| is invoked to notify the |
| 137 // caller about the |file_info| details. | 137 // caller about the |file_info| details. |
| 138 // | 138 // |
| 139 // If the GetFileInfo() fails, |file_info| is not set and |error_callback| is | 139 // If the GetFileInfo() fails, |file_info| is not set and |error_callback| is |
| 140 // invoked to notify the caller about the platform file |error|. | 140 // invoked to notify the caller about the platform file |error|. |
| 141 void OnGetFileInfo(const GetFileInfoSuccessCallback& success_callback, | 141 void OnGetFileInfo(const GetFileInfoSuccessCallback& success_callback, |
| 142 const ErrorCallback& error_callback, | 142 const ErrorCallback& error_callback, |
| 143 base::PlatformFileInfo* file_info, | 143 base::File::Info* file_info, |
| 144 base::PlatformFileError error); | 144 base::File::Error error); |
| 145 | 145 |
| 146 // Called when ReadDirectory() completes. |file_list| contains the directory | 146 // Called when ReadDirectory() completes. |file_list| contains the directory |
| 147 // file entries information. |error| specifies the platform file error code. | 147 // file entries information. |error| specifies the platform file error code. |
| 148 // | 148 // |
| 149 // If the ReadDirectory() succeeds, |success_callback| is invoked to notify | 149 // If the ReadDirectory() succeeds, |success_callback| is invoked to notify |
| 150 // the caller about the directory file entries. | 150 // the caller about the directory file entries. |
| 151 // | 151 // |
| 152 // If the ReadDirectory() fails, |file_list| is not set and |error_callback| | 152 // If the ReadDirectory() fails, |file_list| is not set and |error_callback| |
| 153 // is invoked to notify the caller about the platform file |error|. | 153 // is invoked to notify the caller about the platform file |error|. |
| 154 void OnDidReadDirectory(const ReadDirectorySuccessCallback& success_callback, | 154 void OnDidReadDirectory(const ReadDirectorySuccessCallback& success_callback, |
| 155 const ErrorCallback& error_callback, | 155 const ErrorCallback& error_callback, |
| 156 fileapi::AsyncFileUtil::EntryList* file_list, | 156 fileapi::AsyncFileUtil::EntryList* file_list, |
| 157 base::PlatformFileError error); | 157 base::File::Error error); |
| 158 | 158 |
| 159 // Called when the get file stream request completes. | 159 // Called when the get file stream request completes. |
| 160 // |file_details.request_info| contains the CreateSnapshot request param | 160 // |file_details.request_info| contains the CreateSnapshot request param |
| 161 // details. |error| specifies the platform file error code. | 161 // details. |error| specifies the platform file error code. |
| 162 // | 162 // |
| 163 // If the file stream of the device file is successfully | 163 // If the file stream of the device file is successfully |
| 164 // fetched, |file_details| will contain the required details for the creation | 164 // fetched, |file_details| will contain the required details for the creation |
| 165 // of the snapshot file. | 165 // of the snapshot file. |
| 166 // | 166 // |
| 167 // If the get file stream request fails, |error| is set accordingly. | 167 // If the get file stream request fails, |error| is set accordingly. |
| 168 void OnGetFileStream(scoped_ptr<SnapshotFileDetails> file_details, | 168 void OnGetFileStream(scoped_ptr<SnapshotFileDetails> file_details, |
| 169 base::PlatformFileError error); | 169 base::File::Error error); |
| 170 | 170 |
| 171 // Called when WriteDataChunkIntoSnapshotFile() completes. | 171 // Called when WriteDataChunkIntoSnapshotFile() completes. |
| 172 // |bytes_written| specifies the number of bytes written into the | 172 // |bytes_written| specifies the number of bytes written into the |
| 173 // |snapshot_file_path| during the last write operation. | 173 // |snapshot_file_path| during the last write operation. |
| 174 // | 174 // |
| 175 // If the write operation succeeds, |bytes_written| is set to a non-zero | 175 // If the write operation succeeds, |bytes_written| is set to a non-zero |
| 176 // value. | 176 // value. |
| 177 // | 177 // |
| 178 // If the write operation fails, |bytes_written| is set to zero. | 178 // If the write operation fails, |bytes_written| is set to zero. |
| 179 void OnWroteDataChunkIntoSnapshotFile( | 179 void OnWroteDataChunkIntoSnapshotFile( |
| (...skipping 27 matching lines...) Expand all Loading... |
| 207 // Used to make sure only one task is in progress at any time. | 207 // Used to make sure only one task is in progress at any time. |
| 208 bool task_in_progress_; | 208 bool task_in_progress_; |
| 209 | 209 |
| 210 // For callbacks that may run after destruction. | 210 // For callbacks that may run after destruction. |
| 211 base::WeakPtrFactory<MTPDeviceDelegateImplWin> weak_ptr_factory_; | 211 base::WeakPtrFactory<MTPDeviceDelegateImplWin> weak_ptr_factory_; |
| 212 | 212 |
| 213 DISALLOW_COPY_AND_ASSIGN(MTPDeviceDelegateImplWin); | 213 DISALLOW_COPY_AND_ASSIGN(MTPDeviceDelegateImplWin); |
| 214 }; | 214 }; |
| 215 | 215 |
| 216 #endif // CHROME_BROWSER_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ | 216 #endif // CHROME_BROWSER_MEDIA_GALLERIES_WIN_MTP_DEVICE_DELEGATE_IMPL_WIN_H_ |
| OLD | NEW |