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

Unified Diff: chrome/browser/chromeos/drive/file_system/move_operation.cc

Issue 1215503010: OBSOLETE: Move (most of) chrome/browser/chromeos/drive into components/drive. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@drive-componentize-service
Patch Set: Created 5 years, 6 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/chromeos/drive/file_system/move_operation.cc
diff --git a/chrome/browser/chromeos/drive/file_system/move_operation.cc b/chrome/browser/chromeos/drive/file_system/move_operation.cc
deleted file mode 100644
index f48526d29490344fc2174d341e606c6afcea759c..0000000000000000000000000000000000000000
--- a/chrome/browser/chromeos/drive/file_system/move_operation.cc
+++ /dev/null
@@ -1,121 +0,0 @@
-// 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.
-
-#include "chrome/browser/chromeos/drive/file_system/move_operation.h"
-
-#include "base/sequenced_task_runner.h"
-#include "chrome/browser/chromeos/drive/drive.pb.h"
-#include "chrome/browser/chromeos/drive/file_change.h"
-#include "chrome/browser/chromeos/drive/file_system/operation_delegate.h"
-#include "chrome/browser/chromeos/drive/job_scheduler.h"
-#include "chrome/browser/chromeos/drive/resource_metadata.h"
-
-namespace drive {
-namespace file_system {
-namespace {
-
-// Looks up ResourceEntry for source entry and the destination directory.
-FileError UpdateLocalState(internal::ResourceMetadata* metadata,
- const base::FilePath& src_path,
- const base::FilePath& dest_path,
- FileChange* changed_files,
- std::string* local_id) {
- ResourceEntry entry;
- FileError error = metadata->GetResourceEntryByPath(src_path, &entry);
- if (error != FILE_ERROR_OK)
- return error;
- *local_id = entry.local_id();
-
- ResourceEntry parent_entry;
- error = metadata->GetResourceEntryByPath(dest_path.DirName(), &parent_entry);
- if (error != FILE_ERROR_OK)
- return error;
-
- // The parent must be a directory.
- if (!parent_entry.file_info().is_directory())
- return FILE_ERROR_NOT_A_DIRECTORY;
-
- changed_files->Update(src_path, entry, FileChange::CHANGE_TYPE_DELETE);
-
- // Strip the extension for a hosted document if necessary.
- const std::string new_extension =
- base::FilePath(dest_path.Extension()).AsUTF8Unsafe();
- const bool has_hosted_document_extension =
- entry.has_file_specific_info() &&
- entry.file_specific_info().is_hosted_document() &&
- new_extension == entry.file_specific_info().document_extension();
- const std::string new_title =
- has_hosted_document_extension ?
- dest_path.BaseName().RemoveExtension().AsUTF8Unsafe() :
- dest_path.BaseName().AsUTF8Unsafe();
-
- entry.set_title(new_title);
- entry.set_parent_local_id(parent_entry.local_id());
- entry.set_metadata_edit_state(ResourceEntry::DIRTY);
- entry.set_modification_date(base::Time::Now().ToInternalValue());
- error = metadata->RefreshEntry(entry);
- if (error != FILE_ERROR_OK)
- return error;
-
- changed_files->Update(dest_path, entry,
- FileChange::CHANGE_TYPE_ADD_OR_UPDATE);
- return FILE_ERROR_OK;
-}
-
-} // namespace
-
-MoveOperation::MoveOperation(base::SequencedTaskRunner* blocking_task_runner,
- OperationDelegate* delegate,
- internal::ResourceMetadata* metadata)
- : blocking_task_runner_(blocking_task_runner),
- delegate_(delegate),
- metadata_(metadata),
- weak_ptr_factory_(this) {
-}
-
-MoveOperation::~MoveOperation() {
- DCHECK(thread_checker_.CalledOnValidThread());
-}
-
-void MoveOperation::Move(const base::FilePath& src_file_path,
- const base::FilePath& dest_file_path,
- const FileOperationCallback& callback) {
- DCHECK(thread_checker_.CalledOnValidThread());
- DCHECK(!callback.is_null());
-
- FileChange* changed_files = new FileChange;
- std::string* local_id = new std::string;
- base::PostTaskAndReplyWithResult(
- blocking_task_runner_.get(),
- FROM_HERE,
- base::Bind(&UpdateLocalState,
- metadata_,
- src_file_path,
- dest_file_path,
- changed_files,
- local_id),
- base::Bind(&MoveOperation::MoveAfterUpdateLocalState,
- weak_ptr_factory_.GetWeakPtr(),
- callback,
- base::Owned(changed_files),
- base::Owned(local_id)));
-}
-
-void MoveOperation::MoveAfterUpdateLocalState(
- const FileOperationCallback& callback,
- const FileChange* changed_files,
- const std::string* local_id,
- FileError error) {
- DCHECK(thread_checker_.CalledOnValidThread());
- if (error == FILE_ERROR_OK) {
- // Notify the change of directory.
- delegate_->OnFileChangedByOperation(*changed_files);
- delegate_->OnEntryUpdatedByOperation(ClientContext(USER_INITIATED),
- *local_id);
- }
- callback.Run(error);
-}
-
-} // namespace file_system
-} // namespace drive

Powered by Google App Engine
This is Rietveld 408576698