Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 #include "chrome/browser/media_gallery/linux/mtp_recursive_device_object_enumera tor.h" | 5 #include "chrome/browser/media_gallery/linux/mtp_recursive_device_object_enumera tor.h" |
| 6 | 6 |
| 7 #include "base/sequenced_task_runner.h" | 7 #include "base/sequenced_task_runner.h" |
| 8 #include "base/synchronization/waitable_event.h" | 8 #include "base/synchronization/waitable_event.h" |
| 9 #include "chrome/browser/media_gallery/linux/mtp_device_object_enumerator.h" | 9 #include "chrome/browser/media_gallery/linux/mtp_device_object_enumerator.h" |
| 10 #include "chrome/browser/media_gallery/linux/mtp_read_directory_worker.h" | 10 #include "chrome/browser/media_gallery/linux/mtp_read_directory_worker.h" |
| 11 | 11 |
| 12 namespace chrome { | 12 namespace chrome { |
| 13 | 13 |
| 14 MTPRecursiveDeviceObjectEnumerator::MTPRecursiveDeviceObjectEnumerator( | 14 MTPRecursiveDeviceObjectEnumerator::MTPRecursiveDeviceObjectEnumerator( |
| 15 const std::string& handle, | 15 const std::string& handle, |
| 16 base::SequencedTaskRunner* task_runner, | 16 base::SequencedTaskRunner* task_runner, |
| 17 const std::vector<MtpFileEntry>& entries, | 17 const std::vector<MtpFileEntry>& entries, |
| 18 base::WaitableEvent* task_completed_event, | 18 base::WaitableEvent* task_completed_event, |
| 19 base::WaitableEvent* shutdown_event) | 19 base::WaitableEvent* shutdown_event) |
| 20 : device_handle_(handle), | 20 : device_handle_(handle), |
| 21 media_task_runner_(task_runner), | 21 media_task_runner_(task_runner), |
| 22 file_entries_(entries), | |
| 23 file_entry_iter_(file_entries_.begin()), | |
| 24 on_task_completed_event_(task_completed_event), | 22 on_task_completed_event_(task_completed_event), |
| 25 on_shutdown_event_(shutdown_event) { | 23 on_shutdown_event_(shutdown_event) { |
| 26 DCHECK(on_task_completed_event_); | 24 DCHECK(on_task_completed_event_); |
| 27 DCHECK(on_shutdown_event_); | 25 DCHECK(on_shutdown_event_); |
|
Lei Zhang
2013/01/11 23:25:24
Can you also add a DCHECK to make sure |entries| i
kmadhusu
2013/01/11 23:52:45
Done.
| |
| 28 current_enumerator_.reset(new MTPDeviceObjectEnumerator(entries)); | 26 current_enumerator_.reset(new MTPDeviceObjectEnumerator(entries)); |
| 29 } | 27 } |
| 30 | 28 |
| 31 MTPRecursiveDeviceObjectEnumerator::~MTPRecursiveDeviceObjectEnumerator() { | 29 MTPRecursiveDeviceObjectEnumerator::~MTPRecursiveDeviceObjectEnumerator() { |
| 32 } | 30 } |
| 33 | 31 |
| 34 FilePath MTPRecursiveDeviceObjectEnumerator::Next() { | 32 FilePath MTPRecursiveDeviceObjectEnumerator::Next() { |
| 35 if (on_shutdown_event_->IsSignaled()) { | 33 if (on_shutdown_event_->IsSignaled()) { |
| 36 // Process is in shut down mode. | 34 // Process is in shut down mode. |
| 37 return FilePath(); | 35 return FilePath(); |
| 38 } | 36 } |
| 39 | 37 |
| 40 FilePath path = current_enumerator_->Next(); | 38 if (!static_cast<MTPDeviceObjectEnumerator*>( |
| 41 if (!path.empty()) | 39 current_enumerator_.get())->HasMoreEntries()) |
|
Lei Zhang
2013/01/11 23:25:24
If you call Next() after you reach the end, you ar
kmadhusu
2013/01/11 23:52:45
If current_enumerator is set to EmptyFileEnumerato
Lei Zhang
2013/01/12 00:08:35
It should never happen, but it can happen. If it d
| |
| 42 return path; | 40 UpdateEnumeratorToTraverseSubdirectory(); |
| 43 | 41 |
| 44 // We reached the end. | 42 if (IsDirectory()) { |
| 45 if (file_entry_iter_ == file_entries_.end()) | 43 // If the current entry is a directory, add it to |
| 46 return FilePath(); | 44 // |untraversed_directory_entry_ids_| to scan after scanning this directory. |
| 47 | 45 DirectoryEntryId dir_entry_id; |
| 48 // Enumerate subdirectories of the next media file entry. | 46 if (static_cast<MTPDeviceObjectEnumerator*>( |
| 49 MtpFileEntry next_file_entry = *file_entry_iter_; | 47 current_enumerator_.get())->GetEntryId(&dir_entry_id)) |
| 50 ++file_entry_iter_; | 48 untraversed_directory_entry_ids_.push(dir_entry_id); |
| 51 | |
| 52 // Create a MTPReadDirectoryWorker object to enumerate sub directories. | |
| 53 scoped_refptr<MTPReadDirectoryWorker> worker(new MTPReadDirectoryWorker( | |
| 54 device_handle_, next_file_entry.item_id(), media_task_runner_, | |
| 55 on_task_completed_event_, on_shutdown_event_)); | |
| 56 worker->Run(); | |
| 57 if (!worker->get_file_entries().empty()) { | |
| 58 current_enumerator_.reset( | |
| 59 new MTPDeviceObjectEnumerator(worker->get_file_entries())); | |
| 60 } else { | |
| 61 current_enumerator_.reset( | |
| 62 new fileapi::FileSystemFileUtil::EmptyFileEnumerator()); | |
| 63 } | 49 } |
| 64 return current_enumerator_->Next(); | 50 return current_enumerator_->Next(); |
| 65 } | 51 } |
| 66 | 52 |
| 67 int64 MTPRecursiveDeviceObjectEnumerator::Size() { | 53 int64 MTPRecursiveDeviceObjectEnumerator::Size() { |
| 68 return current_enumerator_->Size(); | 54 return current_enumerator_->Size(); |
| 69 } | 55 } |
| 70 | 56 |
| 71 bool MTPRecursiveDeviceObjectEnumerator::IsDirectory() { | 57 bool MTPRecursiveDeviceObjectEnumerator::IsDirectory() { |
| 72 return current_enumerator_->IsDirectory(); | 58 return current_enumerator_->IsDirectory(); |
| 73 } | 59 } |
| 74 | 60 |
| 75 base::Time MTPRecursiveDeviceObjectEnumerator::LastModifiedTime() { | 61 base::Time MTPRecursiveDeviceObjectEnumerator::LastModifiedTime() { |
| 76 return current_enumerator_->LastModifiedTime(); | 62 return current_enumerator_->LastModifiedTime(); |
| 77 } | 63 } |
| 78 | 64 |
| 65 void MTPRecursiveDeviceObjectEnumerator:: | |
| 66 UpdateEnumeratorToTraverseSubdirectory() { | |
| 67 bool has_more_entries = false; | |
| 68 while (!untraversed_directory_entry_ids_.empty()) { | |
| 69 // Create a MTPReadDirectoryWorker object to enumerate sub directories. | |
| 70 DirectoryEntryId dir_entry_id = untraversed_directory_entry_ids_.front(); | |
| 71 untraversed_directory_entry_ids_.pop(); | |
| 72 scoped_refptr<MTPReadDirectoryWorker> worker(new MTPReadDirectoryWorker( | |
| 73 device_handle_, dir_entry_id, media_task_runner_, | |
| 74 on_task_completed_event_, on_shutdown_event_)); | |
| 75 worker->Run(); | |
| 76 if (!worker->get_file_entries().empty()) { | |
| 77 current_enumerator_.reset( | |
| 78 new MTPDeviceObjectEnumerator(worker->get_file_entries())); | |
| 79 has_more_entries = true; | |
| 80 break; | |
|
Lei Zhang
2013/01/11 23:25:24
you can just return here and get rid of |has_more
kmadhusu
2013/01/11 23:52:45
Done.
| |
| 81 } | |
| 82 } | |
| 83 | |
| 84 if (!has_more_entries) { | |
| 85 // Reached the end. Traversed all the sub directories. | |
| 86 current_enumerator_.reset( | |
| 87 new fileapi::FileSystemFileUtil::EmptyFileEnumerator()); | |
| 88 } | |
| 89 } | |
| 90 | |
| 79 } // namespace chrome | 91 } // namespace chrome |
| OLD | NEW |