Chromium Code Reviews| Index: chrome/browser/chromeos/gdata/gdata_file_system.cc |
| diff --git a/chrome/browser/chromeos/gdata/gdata_file_system.cc b/chrome/browser/chromeos/gdata/gdata_file_system.cc |
| index c809f8643d1afb3b9623c2f83098e1dde97399d8..4b98c12ed7f2eef9375ba2f346ef20957f056384 100644 |
| --- a/chrome/browser/chromeos/gdata/gdata_file_system.cc |
| +++ b/chrome/browser/chromeos/gdata/gdata_file_system.cc |
| @@ -933,39 +933,58 @@ void GDataFileSystem::CopyOnUIThread(const FilePath& src_file_path, |
| const FileOperationCallback& callback) { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| - GDataFileError error = GDATA_FILE_OK; |
| - FilePath dest_parent_path = dest_file_path.DirName(); |
| + directory_service_->GetEntryInfoPairByPaths( |
| + src_file_path, |
| + dest_file_path.DirName(), |
| + base::Bind(&GDataFileSystem::CopyOnUIThreadAfterGetEntryInfoPair, |
| + ui_weak_ptr_, |
| + src_file_path, |
| + dest_file_path, |
| + callback)); |
| +} |
| - std::string src_file_resource_id; |
| +void GDataFileSystem::CopyOnUIThreadAfterGetEntryInfoPair( |
| + const FilePath& src_file_path, |
| + const FilePath& dest_file_path, |
| + const FileOperationCallback& callback, |
| + scoped_ptr<EntryInfoPairResult> result) { |
| + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| + DCHECK(result.get()); |
| + |
| + GDataFileError error = GDATA_FILE_OK; |
| bool src_file_is_hosted_document = false; |
|
achuithb
2012/08/09 00:29:28
These auto vars seem unnecessary to me. I think it
satorux1
2012/08/09 08:33:03
I'm all for minimized scope, but these cannot be m
achuithb
2012/08/09 11:16:46
Hmm, what am I missing? It looks to me like these
satorux1
2012/08/09 16:51:50
Now I see your point. It seems to me that the awkw
|
| + std::string src_file_resource_id; |
| - GDataEntry* src_entry = directory_service_->FindEntryByPathSync( |
| - src_file_path); |
| - GDataEntry* dest_parent = directory_service_->FindEntryByPathSync( |
| - dest_parent_path); |
| - if (!src_entry || !dest_parent) { |
| - error = GDATA_FILE_ERROR_NOT_FOUND; |
| - } else if (!dest_parent->AsGDataDirectory()) { |
| - error = GDATA_FILE_ERROR_NOT_A_DIRECTORY; |
| - } else if (!src_entry->AsGDataFile()) { |
| - // TODO(benchan): Implement copy for directories. In the interim, |
| - // we handle recursive directory copy in the file manager. |
| - error = GDATA_FILE_ERROR_INVALID_OPERATION; |
| + if (result->first.error != GDATA_FILE_OK) { |
| + error = result->first.error; |
| + } else if (result->second.error != GDATA_FILE_OK) { |
| + error = result->second.error; |
| } else { |
| - src_file_resource_id = src_entry->resource_id(); |
| - src_file_is_hosted_document = |
| - src_entry->AsGDataFile()->is_hosted_document(); |
| + scoped_ptr<GDataEntryProto> src_file_proto = result->first.proto.Pass(); |
|
achuithb
2012/08/09 11:16:46
This seems rather weird to me. We are destroying t
satorux1
2012/08/09 16:51:50
That's a good point. With the new code, this weird
|
| + scoped_ptr<GDataEntryProto> dest_parent_proto = |
| + result->second.proto.Pass(); |
| + |
| + if (!dest_parent_proto->file_info().is_directory()) { |
| + error = GDATA_FILE_ERROR_NOT_A_DIRECTORY; |
| + } else if (src_file_proto->file_info().is_directory()) { |
| + // TODO(benchan): Implement copy for directories. In the interim, |
|
achuithb
2012/08/09 00:29:28
Can we update this TODO with an engineer current o
satorux1
2012/08/09 08:33:03
Done.
|
| + // we handle recursive directory copy in the file manager. |
| + error = GDATA_FILE_ERROR_INVALID_OPERATION; |
| + } else { |
| + src_file_resource_id = src_file_proto->resource_id(); |
| + src_file_is_hosted_document = |
| + src_file_proto->file_specific_info().is_hosted_document(); |
| + } |
| } |
| if (error != GDATA_FILE_OK) { |
| if (!callback.is_null()) |
| - MessageLoop::current()->PostTask(FROM_HERE, base::Bind(callback, error)); |
| - |
| + callback.Run(error); |
| return; |
| } |
| if (src_file_is_hosted_document) { |
| - CopyDocumentToDirectory(dest_parent_path, |
| + CopyDocumentToDirectory(dest_file_path.DirName(), |
| src_file_resource_id, |
| // Drop the document extension, which should not be |
| // in the document title. |