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

Unified Diff: webkit/fileapi/local_file_system_operation.cc

Issue 15994002: Move more browser-specific webkit/fileapi code to webkit/browser/fileapi (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 7 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: webkit/fileapi/local_file_system_operation.cc
diff --git a/webkit/fileapi/local_file_system_operation.cc b/webkit/fileapi/local_file_system_operation.cc
deleted file mode 100644
index 604e87e6c1fe0d6eb063db40e8d2b9086125c21d..0000000000000000000000000000000000000000
--- a/webkit/fileapi/local_file_system_operation.cc
+++ /dev/null
@@ -1,880 +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 "webkit/fileapi/local_file_system_operation.h"
-
-#include "base/bind.h"
-#include "base/single_thread_task_runner.h"
-#include "base/time.h"
-#include "base/utf_string_conversions.h"
-#include "net/base/escape.h"
-#include "net/url_request/url_request_context.h"
-#include "webkit/blob/shareable_file_reference.h"
-#include "webkit/browser/fileapi/cross_operation_delegate.h"
-#include "webkit/browser/fileapi/file_system_file_util.h"
-#include "webkit/browser/fileapi/file_system_mount_point_provider.h"
-#include "webkit/browser/fileapi/sandbox_file_stream_writer.h"
-#include "webkit/fileapi/async_file_util.h"
-#include "webkit/fileapi/file_observers.h"
-#include "webkit/fileapi/file_system_context.h"
-#include "webkit/fileapi/file_system_operation_context.h"
-#include "webkit/fileapi/file_system_task_runners.h"
-#include "webkit/fileapi/file_system_types.h"
-#include "webkit/fileapi/file_system_url.h"
-#include "webkit/fileapi/file_system_util.h"
-#include "webkit/fileapi/file_writer_delegate.h"
-#include "webkit/fileapi/remove_operation_delegate.h"
-#include "webkit/quota/quota_manager.h"
-#include "webkit/quota/quota_types.h"
-
-using webkit_blob::ScopedFile;
-using webkit_blob::ShareableFileReference;
-
-namespace fileapi {
-
-namespace {
-void NopCloseFileCallback() {}
-}
-
-LocalFileSystemOperation::LocalFileSystemOperation(
- FileSystemContext* file_system_context,
- scoped_ptr<FileSystemOperationContext> operation_context)
- : file_system_context_(file_system_context),
- operation_context_(operation_context.Pass()),
- async_file_util_(NULL),
- peer_handle_(base::kNullProcessHandle),
- pending_operation_(kOperationNone),
- weak_factory_(this) {
- DCHECK(operation_context_.get());
- operation_context_->DetachUserDataThread();
-}
-
-LocalFileSystemOperation::~LocalFileSystemOperation() {
- if (!operation_context())
- return;
- if (write_target_url_.is_valid()) {
- operation_context()->update_observers()->Notify(
- &FileUpdateObserver::OnEndUpdate, MakeTuple(write_target_url_));
- }
-}
-
-void LocalFileSystemOperation::CreateFile(const FileSystemURL& url,
- bool exclusive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateFile));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&LocalFileSystemOperation::DoCreateFile,
- base::Unretained(this), url, callback, exclusive),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::CreateDirectory(const FileSystemURL& url,
- bool exclusive,
- bool recursive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateDirectory));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&LocalFileSystemOperation::DoCreateDirectory,
- base::Unretained(this), url, callback, exclusive, recursive),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::Copy(const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopy));
- scoped_ptr<LocalFileSystemOperation> deleter(this);
-
- // Setting up this (dest) operation.
- base::PlatformFileError result = SetUp(dest_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- return;
- }
-
- // Setting up a new operation for source.
- FileSystemOperation* operation =
- file_system_context()->CreateFileSystemOperation(src_url, &result);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- return;
- }
- scoped_ptr<LocalFileSystemOperation> src_operation(
- operation->AsLocalFileSystemOperation());
- DCHECK(src_operation);
- result = src_operation->SetUp(src_url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- return;
- }
-
- DCHECK(!recursive_operation_delegate_);
- recursive_operation_delegate_.reset(
- new CrossOperationDelegate(
- file_system_context(),
- src_operation.Pass(),
- deleter.release(),
- src_url, dest_url,
- CrossOperationDelegate::OPERATION_COPY,
- base::Bind(&LocalFileSystemOperation::DidFinishDelegatedOperation,
- base::Unretained(this), callback)));
- recursive_operation_delegate_->RunRecursively();
-}
-
-void LocalFileSystemOperation::Move(const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationMove));
- scoped_ptr<LocalFileSystemOperation> deleter(this);
-
- // Setting up this (dest) operation.
- base::PlatformFileError result = SetUp(dest_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- return;
- }
-
- // Setting up a new operation for source.
- base::PlatformFileError error = base::PLATFORM_FILE_OK;
- FileSystemOperation* operation =
- file_system_context()->CreateFileSystemOperation(src_url, &error);
- if (error != base::PLATFORM_FILE_OK) {
- DCHECK(!operation);
- callback.Run(error);
- return;
- }
- scoped_ptr<LocalFileSystemOperation> src_operation(
- operation->AsLocalFileSystemOperation());
- DCHECK(src_operation);
- result = src_operation->SetUp(src_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- return;
- }
-
- DCHECK(!recursive_operation_delegate_);
- recursive_operation_delegate_.reset(
- new CrossOperationDelegate(
- file_system_context(),
- src_operation.Pass(),
- deleter.release(),
- src_url, dest_url,
- CrossOperationDelegate::OPERATION_MOVE,
- base::Bind(&LocalFileSystemOperation::DidFinishDelegatedOperation,
- base::Unretained(this), callback)));
- recursive_operation_delegate_->RunRecursively();
-}
-
-void LocalFileSystemOperation::DirectoryExists(const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationDirectoryExists));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- async_file_util_->GetFileInfo(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidDirectoryExists,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::FileExists(const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationFileExists));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- async_file_util_->GetFileInfo(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidFileExists,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::GetMetadata(
- const FileSystemURL& url, const GetMetadataCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationGetMetadata));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result, base::PlatformFileInfo(), base::FilePath());
- delete this;
- return;
- }
-
- async_file_util_->GetFileInfo(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidGetMetadata,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::ReadDirectory(
- const FileSystemURL& url, const ReadDirectoryCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationReadDirectory));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result, std::vector<DirectoryEntry>(), false);
- delete this;
- return;
- }
-
- async_file_util_->ReadDirectory(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidReadDirectory,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::Remove(const FileSystemURL& url,
- bool recursive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- DCHECK(!recursive_operation_delegate_);
- recursive_operation_delegate_.reset(
- new RemoveOperationDelegate(
- file_system_context(),
- this, url,
- base::Bind(&LocalFileSystemOperation::DidFinishDelegatedOperation,
- base::Unretained(this), callback)));
- if (recursive)
- recursive_operation_delegate_->RunRecursively();
- else
- recursive_operation_delegate_->Run();
-}
-
-void LocalFileSystemOperation::Write(
- const net::URLRequestContext* url_request_context,
- const FileSystemURL& url,
- const GURL& blob_url,
- int64 offset,
- const WriteCallback& callback) {
- GetWriteClosure(url_request_context, url, blob_url, offset, callback).Run();
-}
-
-void LocalFileSystemOperation::Truncate(const FileSystemURL& url, int64 length,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationTruncate));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&LocalFileSystemOperation::DoTruncate,
- base::Unretained(this), url, callback, length),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::TouchFile(const FileSystemURL& url,
- const base::Time& last_access_time,
- const base::Time& last_modified_time,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationTouchFile));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- async_file_util_->Touch(
- operation_context(), url,
- last_access_time, last_modified_time,
- base::Bind(&LocalFileSystemOperation::DidTouchFile,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::OpenFile(const FileSystemURL& url,
- int file_flags,
- base::ProcessHandle peer_handle,
- const OpenFileCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationOpenFile));
- scoped_ptr<LocalFileSystemOperation> deleter(this);
-
- peer_handle_ = peer_handle;
-
- if (file_flags & (
- (base::PLATFORM_FILE_ENUMERATE | base::PLATFORM_FILE_TEMPORARY |
- base::PLATFORM_FILE_HIDDEN))) {
- callback.Run(base::PLATFORM_FILE_ERROR_FAILED,
- base::kInvalidPlatformFileValue,
- base::Closure(),
- base::kNullProcessHandle);
- return;
- }
- if (file_flags &
- (base::PLATFORM_FILE_CREATE | base::PLATFORM_FILE_OPEN_ALWAYS |
- base::PLATFORM_FILE_CREATE_ALWAYS | base::PLATFORM_FILE_OPEN_TRUNCATED |
- base::PLATFORM_FILE_WRITE | base::PLATFORM_FILE_EXCLUSIVE_WRITE |
- base::PLATFORM_FILE_DELETE_ON_CLOSE |
- base::PLATFORM_FILE_WRITE_ATTRIBUTES)) {
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result,
- base::kInvalidPlatformFileValue,
- base::Closure(),
- base::kNullProcessHandle);
- return;
- }
- } else {
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result,
- base::kInvalidPlatformFileValue,
- base::Closure(),
- base::kNullProcessHandle);
- return;
- }
- }
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&LocalFileSystemOperation::DoOpenFile,
- base::Unretained(deleter.release()),
- url, callback, file_flags),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED,
- base::kInvalidPlatformFileValue,
- base::Closure(),
- base::kNullProcessHandle));
-}
-
-// We can only get here on a write or truncate that's not yet completed.
-// We don't support cancelling any other operation at this time.
-void LocalFileSystemOperation::Cancel(const StatusCallback& cancel_callback) {
- if (file_writer_delegate_) {
- DCHECK_EQ(kOperationWrite, pending_operation_);
-
- // Writes are done without proxying through FileUtilProxy after the initial
- // opening of the PlatformFile. All state changes are done on this thread,
- // so we're guaranteed to be able to shut down atomically.
- const bool delete_now = file_writer_delegate_->Cancel();
-
- if (!write_callback_.is_null()) {
- // Notify the failure status to the ongoing operation's callback.
- write_callback_.Run(base::PLATFORM_FILE_ERROR_ABORT, 0, false);
- }
- cancel_callback.Run(base::PLATFORM_FILE_OK);
- write_callback_.Reset();
-
- if (delete_now) {
- delete this;
- return;
- }
- } else {
- DCHECK_EQ(kOperationTruncate, pending_operation_);
- // We're cancelling a truncate operation, but we can't actually stop it
- // since it's been proxied to another thread. We need to save the
- // cancel_callback so that when the truncate returns, it can see that it's
- // been cancelled, report it, and report that the cancel has succeeded.
- DCHECK(cancel_callback_.is_null());
- cancel_callback_ = cancel_callback;
- }
-}
-
-LocalFileSystemOperation*
-LocalFileSystemOperation::AsLocalFileSystemOperation() {
- return this;
-}
-
-void LocalFileSystemOperation::SyncGetPlatformPath(const FileSystemURL& url,
- base::FilePath* platform_path) {
- DCHECK(SetPendingOperationType(kOperationGetLocalPath));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- delete this;
- return;
- }
-
- FileSystemFileUtil* file_util = file_system_context()->GetFileUtil(
- url.type());
- DCHECK(file_util);
- file_util->GetLocalFilePath(operation_context(), url, platform_path);
-
- delete this;
-}
-
-void LocalFileSystemOperation::CreateSnapshotFile(
- const FileSystemURL& url,
- const SnapshotFileCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateSnapshotFile));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_READ);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result, base::PlatformFileInfo(), base::FilePath(), NULL);
- delete this;
- return;
- }
-
- async_file_util_->CreateSnapshotFile(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidCreateSnapshotFile,
- base::Owned(this), callback));
-}
-
-LocalFileSystemOperation* LocalFileSystemOperation::CreateNestedOperation() {
- LocalFileSystemOperation* operation = new LocalFileSystemOperation(
- file_system_context(),
- make_scoped_ptr(new FileSystemOperationContext(file_system_context())));
- operation->parent_operation_ = weak_factory_.GetWeakPtr();
- return operation;
-}
-
-void LocalFileSystemOperation::CopyInForeignFile(
- const base::FilePath& src_local_disk_file_path,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopyInForeignFile));
-
- base::PlatformFileError result = SetUp(dest_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&LocalFileSystemOperation::DoCopyInForeignFile,
- base::Unretained(this), src_local_disk_file_path, dest_url,
- callback),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::RemoveFile(
- const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- async_file_util_->DeleteFile(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::RemoveDirectory(
- const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- async_file_util_->DeleteDirectory(
- operation_context(), url,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::CopyFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopy));
- DCHECK(AreSameFileSystem(src_url, dest_url));
-
- base::PlatformFileError result = SetUp(src_url, OPERATION_MODE_READ);
- if (result == base::PLATFORM_FILE_OK)
- result = SetUp(dest_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&LocalFileSystemOperation::DoCopyFileLocal,
- base::Unretained(this), src_url, dest_url, callback),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::MoveFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationMove));
- DCHECK(AreSameFileSystem(src_url, dest_url));
-
- base::PlatformFileError result = SetUp(src_url, OPERATION_MODE_WRITE);
- if (result == base::PLATFORM_FILE_OK)
- result = SetUp(dest_url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- callback.Run(result);
- delete this;
- return;
- }
-
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&LocalFileSystemOperation::DoMoveFileLocal,
- base::Unretained(this), src_url, dest_url, callback),
- base::Bind(callback, base::PLATFORM_FILE_ERROR_FAILED));
-}
-
-void LocalFileSystemOperation::GetUsageAndQuotaThenRunTask(
- const FileSystemURL& url,
- const base::Closure& task,
- const base::Closure& error_callback) {
- quota::QuotaManagerProxy* quota_manager_proxy =
- file_system_context()->quota_manager_proxy();
- if (!quota_manager_proxy ||
- !file_system_context()->GetQuotaUtil(url.type())) {
- // If we don't have the quota manager or the requested filesystem type
- // does not support quota, we should be able to let it go.
- operation_context()->set_allowed_bytes_growth(kint64max);
- task.Run();
- return;
- }
-
- DCHECK(quota_manager_proxy);
- DCHECK(quota_manager_proxy->quota_manager());
- quota_manager_proxy->quota_manager()->GetUsageAndQuota(
- url.origin(),
- FileSystemTypeToQuotaStorageType(url.type()),
- base::Bind(&LocalFileSystemOperation::DidGetUsageAndQuotaAndRunTask,
- weak_factory_.GetWeakPtr(), task, error_callback));
-}
-
-void LocalFileSystemOperation::DidGetUsageAndQuotaAndRunTask(
- const base::Closure& task,
- const base::Closure& error_callback,
- quota::QuotaStatusCode status,
- int64 usage, int64 quota) {
- if (status != quota::kQuotaStatusOk) {
- LOG(WARNING) << "Got unexpected quota error : " << status;
- error_callback.Run();
- return;
- }
-
- operation_context()->set_allowed_bytes_growth(quota - usage);
- task.Run();
-}
-
-base::Closure LocalFileSystemOperation::GetWriteClosure(
- const net::URLRequestContext* url_request_context,
- const FileSystemURL& url,
- const GURL& blob_url,
- int64 offset,
- const WriteCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationWrite));
-
- base::PlatformFileError result = SetUp(url, OPERATION_MODE_WRITE);
- if (result != base::PLATFORM_FILE_OK) {
- return base::Bind(&LocalFileSystemOperation::DidFailWrite,
- base::Owned(this), callback, result);
- }
-
- scoped_ptr<FileStreamWriter> writer(
- file_system_context()->CreateFileStreamWriter(url, offset));
-
- if (!writer) {
- // Write is not supported.
- return base::Bind(&LocalFileSystemOperation::DidFailWrite,
- base::Owned(this), callback,
- base::PLATFORM_FILE_ERROR_SECURITY);
- }
-
- DCHECK(blob_url.is_valid());
- file_writer_delegate_.reset(new FileWriterDelegate(
- base::Bind(&LocalFileSystemOperation::DidWrite,
- weak_factory_.GetWeakPtr(), url),
- writer.Pass()));
-
- write_callback_ = callback;
- scoped_ptr<net::URLRequest> blob_request(url_request_context->CreateRequest(
- blob_url, file_writer_delegate_.get()));
-
- return base::Bind(&FileWriterDelegate::Start,
- base::Unretained(file_writer_delegate_.get()),
- base::Passed(&blob_request));
-}
-
-void LocalFileSystemOperation::DidFailWrite(
- const WriteCallback& callback,
- base::PlatformFileError result) {
- callback.Run(result, 0, false);
-}
-
-void LocalFileSystemOperation::DoCreateFile(
- const FileSystemURL& url,
- const StatusCallback& callback,
- bool exclusive) {
- async_file_util_->EnsureFileExists(
- operation_context(), url,
- base::Bind(
- exclusive ?
- &LocalFileSystemOperation::DidEnsureFileExistsExclusive :
- &LocalFileSystemOperation::DidEnsureFileExistsNonExclusive,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoCreateDirectory(
- const FileSystemURL& url,
- const StatusCallback& callback,
- bool exclusive, bool recursive) {
- async_file_util_->CreateDirectory(
- operation_context(),
- url, exclusive, recursive,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoCopyFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- async_file_util_->CopyFileLocal(
- operation_context(), src_url, dest_url,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoMoveFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- async_file_util_->MoveFileLocal(
- operation_context(), src_url, dest_url,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoCopyInForeignFile(
- const base::FilePath& src_local_disk_file_path,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- async_file_util_->CopyInForeignFile(
- operation_context(),
- src_local_disk_file_path, dest_url,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoTruncate(const FileSystemURL& url,
- const StatusCallback& callback,
- int64 length) {
- async_file_util_->Truncate(
- operation_context(), url, length,
- base::Bind(&LocalFileSystemOperation::DidFinishFileOperation,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DoOpenFile(const FileSystemURL& url,
- const OpenFileCallback& callback,
- int file_flags) {
- async_file_util_->CreateOrOpen(
- operation_context(), url, file_flags,
- base::Bind(&LocalFileSystemOperation::DidOpenFile,
- base::Owned(this), callback));
-}
-
-void LocalFileSystemOperation::DidEnsureFileExistsExclusive(
- const StatusCallback& callback,
- base::PlatformFileError rv, bool created) {
- if (rv == base::PLATFORM_FILE_OK && !created) {
- callback.Run(base::PLATFORM_FILE_ERROR_EXISTS);
- } else {
- DidFinishFileOperation(callback, rv);
- }
-}
-
-void LocalFileSystemOperation::DidEnsureFileExistsNonExclusive(
- const StatusCallback& callback,
- base::PlatformFileError rv, bool /* created */) {
- DidFinishFileOperation(callback, rv);
-}
-
-void LocalFileSystemOperation::DidFinishFileOperation(
- const StatusCallback& callback,
- base::PlatformFileError rv) {
- if (!cancel_callback_.is_null()) {
- DCHECK_EQ(kOperationTruncate, pending_operation_);
-
- callback.Run(base::PLATFORM_FILE_ERROR_ABORT);
- cancel_callback_.Run(base::PLATFORM_FILE_OK);
- cancel_callback_.Reset();
- } else {
- callback.Run(rv);
- }
-}
-
-void LocalFileSystemOperation::DidFinishDelegatedOperation(
- const StatusCallback& callback,
- base::PlatformFileError rv) {
- // The callback might be held by the delegate and Owned() may not work,
- // so just explicitly delete this now.
- callback.Run(rv);
- delete this;
-}
-
-void LocalFileSystemOperation::DidDirectoryExists(
- const StatusCallback& callback,
- base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info,
- const base::FilePath& unused) {
- if (rv == base::PLATFORM_FILE_OK && !file_info.is_directory)
- rv = base::PLATFORM_FILE_ERROR_NOT_A_DIRECTORY;
- callback.Run(rv);
-}
-
-void LocalFileSystemOperation::DidFileExists(
- const StatusCallback& callback,
- base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info,
- const base::FilePath& unused) {
- if (rv == base::PLATFORM_FILE_OK && file_info.is_directory)
- rv = base::PLATFORM_FILE_ERROR_NOT_A_FILE;
- callback.Run(rv);
-}
-
-void LocalFileSystemOperation::DidGetMetadata(
- const GetMetadataCallback& callback,
- base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info,
- const base::FilePath& platform_path) {
- callback.Run(rv, file_info, platform_path);
-}
-
-void LocalFileSystemOperation::DidReadDirectory(
- const ReadDirectoryCallback& callback,
- base::PlatformFileError rv,
- const std::vector<DirectoryEntry>& entries,
- bool has_more) {
- callback.Run(rv, entries, has_more);
-}
-
-void LocalFileSystemOperation::DidWrite(
- const FileSystemURL& url,
- base::PlatformFileError rv,
- int64 bytes,
- FileWriterDelegate::WriteProgressStatus write_status) {
- if (write_callback_.is_null()) {
- // If cancelled, callback is already invoked and set to null in Cancel().
- // We must not call it twice. Just shut down this operation object.
- delete this;
- return;
- }
-
- const bool complete = (
- write_status != FileWriterDelegate::SUCCESS_IO_PENDING);
- if (complete && write_status != FileWriterDelegate::ERROR_WRITE_NOT_STARTED) {
- operation_context()->change_observers()->Notify(
- &FileChangeObserver::OnModifyFile, MakeTuple(url));
- }
-
- write_callback_.Run(rv, bytes, complete);
- if (complete || rv != base::PLATFORM_FILE_OK)
- delete this;
-}
-
-void LocalFileSystemOperation::DidTouchFile(const StatusCallback& callback,
- base::PlatformFileError rv) {
- callback.Run(rv);
-}
-
-void LocalFileSystemOperation::DidOpenFile(
- const OpenFileCallback& callback,
- base::PlatformFileError rv,
- base::PassPlatformFile file,
- bool unused) {
- if (rv == base::PLATFORM_FILE_OK)
- CHECK_NE(base::kNullProcessHandle, peer_handle_);
- callback.Run(rv, file.ReleaseValue(),
- base::Bind(&NopCloseFileCallback),
- peer_handle_);
-}
-
-void LocalFileSystemOperation::DidCreateSnapshotFile(
- const SnapshotFileCallback& callback,
- base::PlatformFileError result,
- const base::PlatformFileInfo& file_info,
- const base::FilePath& platform_path,
- const scoped_refptr<ShareableFileReference>& file_ref) {
- callback.Run(result, file_info, platform_path, file_ref);
-}
-
-base::PlatformFileError LocalFileSystemOperation::SetUp(
- const FileSystemURL& url,
- OperationMode mode) {
- DCHECK(url.is_valid());
-
- async_file_util_ = file_system_context()->GetAsyncFileUtil(url.type());
- if (!async_file_util_)
- return base::PLATFORM_FILE_ERROR_SECURITY;
-
- // If this operation is created for recursive sub-operations (i.e.
- // it has the parent operation) we skip duplicated notifications.
- if (parent_operation_)
- return base::PLATFORM_FILE_OK;
-
- switch (mode) {
- case OPERATION_MODE_READ:
- operation_context()->access_observers()->Notify(
- &FileAccessObserver::OnAccess, MakeTuple(url));
- break;
- case OPERATION_MODE_WRITE:
- operation_context()->update_observers()->Notify(
- &FileUpdateObserver::OnStartUpdate, MakeTuple(url));
- DCHECK(!write_target_url_.is_valid());
- write_target_url_ = url;
- break;
- }
-
- return base::PLATFORM_FILE_OK;
-}
-
-bool LocalFileSystemOperation::SetPendingOperationType(OperationType type) {
- if (pending_operation_ != kOperationNone)
- return false;
- pending_operation_ = type;
- return true;
-}
-
-} // namespace fileapi
« no previous file with comments | « webkit/fileapi/local_file_system_operation.h ('k') | webkit/fileapi/local_file_system_operation_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698