From d1792a5ecce579569ac524584fe775d964e18dca Mon Sep 17 00:00:00 2001 From: "satorux@chromium.org" Date: Thu, 9 Aug 2012 19:45:52 +0000 Subject: gdata: Remove use of FindEntryByPathSync() from MoveOnUIThread() The number of calles of FindEntryByPathSync() is reduced from 15 to 13. BUG=137694, 126634, 139446 TEST=Moving a file to another directory and renaming in the same directory work as before from file manager Review URL: https://chromiumcodereview.appspot.com/10854072 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@150871 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/browser/chromeos/gdata/gdata_file_system.cc | 51 ++++++++++++++-------- chrome/browser/chromeos/gdata/gdata_file_system.h | 8 ++++ .../chromeos/gdata/gdata_file_system_interface.h | 1 + 3 files changed, 41 insertions(+), 19 deletions(-) diff --git a/chrome/browser/chromeos/gdata/gdata_file_system.cc b/chrome/browser/chromeos/gdata/gdata_file_system.cc index 3d453db..3ab22e3 100644 --- a/chrome/browser/chromeos/gdata/gdata_file_system.cc +++ b/chrome/browser/chromeos/gdata/gdata_file_system.cc @@ -1081,13 +1081,11 @@ void GDataFileSystem::Rename(const FilePath& file_path, const FilePath::StringType& new_name, const FileMoveCallback& callback) { DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); + DCHECK(!callback.is_null()); // It is a no-op if the file is renamed to the same name. if (file_path.BaseName().value() == new_name) { - if (!callback.is_null()) { - MessageLoop::current()->PostTask( - FROM_HERE, base::Bind(callback, GDATA_FILE_OK, file_path)); - } + callback.Run(GDATA_FILE_OK, file_path); return; } @@ -1145,6 +1143,8 @@ void GDataFileSystem::Move(const FilePath& src_file_path, const FileOperationCallback& callback) { DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::IO)); + DCHECK(!callback.is_null()); + RunTaskOnUIThread(base::Bind(&GDataFileSystem::MoveOnUIThread, ui_weak_ptr_, src_file_path, @@ -1156,29 +1156,42 @@ void GDataFileSystem::MoveOnUIThread(const FilePath& src_file_path, const FilePath& dest_file_path, const FileOperationCallback& callback) { DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); + DCHECK(!callback.is_null()); - 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::MoveOnUIThreadAfterGetEntryInfoPair, + ui_weak_ptr_, + dest_file_path, + callback)); +} - 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; +void GDataFileSystem::MoveOnUIThreadAfterGetEntryInfoPair( + const FilePath& dest_file_path, + const FileOperationCallback& callback, + scoped_ptr result) { + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); + DCHECK(!callback.is_null()); + DCHECK(result.get()); + + if (result->first.error != GDATA_FILE_OK) { + callback.Run(result->first.error); + return; + } else if (result->second.error != GDATA_FILE_OK) { + callback.Run(result->second.error); + return; } - if (error != GDATA_FILE_OK) { - if (!callback.is_null()) { - MessageLoop::current()->PostTask(FROM_HERE, - base::Bind(callback, error)); - } + scoped_ptr dest_parent_proto = result->second.proto.Pass(); + if (!dest_parent_proto->file_info().is_directory()) { + callback.Run(GDATA_FILE_ERROR_NOT_A_DIRECTORY); return; } // If the file/directory is moved to the same directory, just rename it. + const FilePath& src_file_path = result->first.path; + const FilePath& dest_parent_path = result->second.path; if (src_file_path.DirName() == dest_parent_path) { FileMoveCallback final_file_path_update_callback = base::Bind(&GDataFileSystem::OnFilePathUpdated, diff --git a/chrome/browser/chromeos/gdata/gdata_file_system.h b/chrome/browser/chromeos/gdata/gdata_file_system.h index 1545c85..0ba3ef4 100644 --- a/chrome/browser/chromeos/gdata/gdata_file_system.h +++ b/chrome/browser/chromeos/gdata/gdata_file_system.h @@ -358,6 +358,7 @@ class GDataFileSystem : public GDataFileSystemInterface, // "foo (2).txt" // // Can be called from UI thread. |callback| is run on the calling thread. + // |callback| must not be null. void Rename(const FilePath& file_path, const FilePath::StringType& new_name, const FileMoveCallback& callback); @@ -747,6 +748,13 @@ class GDataFileSystem : public GDataFileSystemInterface, const FileOperationCallback& callback, scoped_ptr result); + // Part of MoveOnUIThread(). Called after GetEntryInfoPairByPaths() is + // complete. |callback| must not be null. + void MoveOnUIThreadAfterGetEntryInfoPair( + const FilePath& dest_file_path, + const FileOperationCallback& callback, + scoped_ptr result); + // Part of RemoveOnUIThread(). Called after GetEntryInfoByPath() is // complete. void RemoveOnUIThreadAfterGetEntryInfo( diff --git a/chrome/browser/chromeos/gdata/gdata_file_system_interface.h b/chrome/browser/chromeos/gdata/gdata_file_system_interface.h index 339f96b..16acbbc 100644 --- a/chrome/browser/chromeos/gdata/gdata_file_system_interface.h +++ b/chrome/browser/chromeos/gdata/gdata_file_system_interface.h @@ -220,6 +220,7 @@ class GDataFileSystemInterface { // of the file system. // // Can be called from UI/IO thread. |callback| is run on the calling thread. + // |callback| must not be null. virtual void Move(const FilePath& src_file_path, const FilePath& dest_file_path, const FileOperationCallback& callback) = 0; -- cgit v1.1