summaryrefslogtreecommitdiffstats
path: root/webkit/browser/fileapi/async_file_util_adapter.cc
diff options
context:
space:
mode:
authorkinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-06-10 17:52:43 +0000
committerkinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-06-10 17:52:43 +0000
commit2c02c8d3eb2827b2d2c9b5e300a7cf49f5c2624a (patch)
tree3b74668cbd3f3d7e3f8725a949f92cf85c318e04 /webkit/browser/fileapi/async_file_util_adapter.cc
parent312d44ffbf5671224e50754d690dfdc98aad0fc2 (diff)
downloadchromium_src-2c02c8d3eb2827b2d2c9b5e300a7cf49f5c2624a.zip
chromium_src-2c02c8d3eb2827b2d2c9b5e300a7cf49f5c2624a.tar.gz
chromium_src-2c02c8d3eb2827b2d2c9b5e300a7cf49f5c2624a.tar.bz2
Make FileSystemOperation NOT self-destruct
This architecture was found to bring lots of undesirable complexity in the codebase. This should become much simpler. BUG=176444 TEST=unit_tests:*File*, content_unittests:*File*, browser_tests:*File* NOTRY=true Review URL: https://chromiumcodereview.appspot.com/16413007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@205243 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/browser/fileapi/async_file_util_adapter.cc')
-rw-r--r--webkit/browser/fileapi/async_file_util_adapter.cc95
1 files changed, 55 insertions, 40 deletions
diff --git a/webkit/browser/fileapi/async_file_util_adapter.cc b/webkit/browser/fileapi/async_file_util_adapter.cc
index 8fa1ba7..1664a0b 100644
--- a/webkit/browser/fileapi/async_file_util_adapter.cc
+++ b/webkit/browser/fileapi/async_file_util_adapter.cc
@@ -142,165 +142,180 @@ AsyncFileUtilAdapter::~AsyncFileUtilAdapter() {
}
bool AsyncFileUtilAdapter::CreateOrOpen(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
int file_flags,
const CreateOrOpenCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::FileUtilProxy::RelayCreateOrOpen(
- context->task_runner(),
+ context_ptr->task_runner(),
Bind(&FileSystemFileUtil::CreateOrOpen, Unretained(sync_file_util_.get()),
- context, url, file_flags),
+ context_ptr, url, file_flags),
Bind(&FileSystemFileUtil::Close, Unretained(sync_file_util_.get()),
- context),
+ base::Owned(context_ptr)),
callback);
}
bool AsyncFileUtilAdapter::EnsureFileExists(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const EnsureFileExistsCallback& callback) {
EnsureFileExistsHelper* helper = new EnsureFileExistsHelper;
- return context->task_runner()->PostTaskAndReply(
+ FileSystemOperationContext* context_ptr = context.release();
+ return context_ptr->task_runner()->PostTaskAndReply(
FROM_HERE,
Bind(&EnsureFileExistsHelper::RunWork, Unretained(helper),
- sync_file_util_.get(), context, url),
+ sync_file_util_.get(), base::Owned(context_ptr), url),
Bind(&EnsureFileExistsHelper::Reply, Owned(helper), callback));
}
bool AsyncFileUtilAdapter::CreateDirectory(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
bool exclusive,
bool recursive,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::CreateDirectory,
Unretained(sync_file_util_.get()),
- context, url, exclusive, recursive),
+ base::Owned(context_ptr), url, exclusive, recursive),
callback);
}
bool AsyncFileUtilAdapter::GetFileInfo(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const GetFileInfoCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
GetFileInfoHelper* helper = new GetFileInfoHelper;
- return context->task_runner()->PostTaskAndReply(
+ return context_ptr->task_runner()->PostTaskAndReply(
FROM_HERE,
Bind(&GetFileInfoHelper::GetFileInfo, Unretained(helper),
- sync_file_util_.get(), context, url),
+ sync_file_util_.get(), base::Owned(context_ptr), url),
Bind(&GetFileInfoHelper::ReplyFileInfo, Owned(helper), callback));
}
bool AsyncFileUtilAdapter::ReadDirectory(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const ReadDirectoryCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
ReadDirectoryHelper* helper = new ReadDirectoryHelper;
- return context->task_runner()->PostTaskAndReply(
+ return context_ptr->task_runner()->PostTaskAndReply(
FROM_HERE,
Bind(&ReadDirectoryHelper::RunWork, Unretained(helper),
- sync_file_util_.get(), context, url),
+ sync_file_util_.get(), base::Owned(context_ptr), url),
Bind(&ReadDirectoryHelper::Reply, Owned(helper), callback));
}
bool AsyncFileUtilAdapter::Touch(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const base::Time& last_access_time,
const base::Time& last_modified_time,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::Touch, Unretained(sync_file_util_.get()),
- context, url, last_access_time, last_modified_time),
+ base::Owned(context_ptr), url,
+ last_access_time, last_modified_time),
callback);
}
bool AsyncFileUtilAdapter::Truncate(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
int64 length,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::Truncate, Unretained(sync_file_util_.get()),
- context, url, length),
+ base::Owned(context_ptr), url, length),
callback);
}
bool AsyncFileUtilAdapter::CopyFileLocal(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& src_url,
const FileSystemURL& dest_url,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::CopyOrMoveFile,
Unretained(sync_file_util_.get()),
- context, src_url, dest_url, true /* copy */),
+ base::Owned(context_ptr), src_url, dest_url, true /* copy */),
callback);
}
bool AsyncFileUtilAdapter::MoveFileLocal(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& src_url,
const FileSystemURL& dest_url,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::CopyOrMoveFile,
Unretained(sync_file_util_.get()),
- context, src_url, dest_url, false /* copy */),
+ base::Owned(context_ptr), src_url, dest_url, false /* copy */),
callback);
}
bool AsyncFileUtilAdapter::CopyInForeignFile(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const base::FilePath& src_file_path,
const FileSystemURL& dest_url,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::CopyInForeignFile,
Unretained(sync_file_util_.get()),
- context, src_file_path, dest_url),
+ base::Owned(context_ptr), src_file_path, dest_url),
callback);
}
bool AsyncFileUtilAdapter::DeleteFile(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::DeleteFile,
- Unretained(sync_file_util_.get()), context, url),
+ Unretained(sync_file_util_.get()),
+ base::Owned(context_ptr), url),
callback);
}
bool AsyncFileUtilAdapter::DeleteDirectory(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const StatusCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
return base::PostTaskAndReplyWithResult(
- context->task_runner(), FROM_HERE,
+ context_ptr->task_runner(), FROM_HERE,
Bind(&FileSystemFileUtil::DeleteDirectory,
Unretained(sync_file_util_.get()),
- context, url),
+ base::Owned(context_ptr), url),
callback);
}
bool AsyncFileUtilAdapter::CreateSnapshotFile(
- FileSystemOperationContext* context,
+ scoped_ptr<FileSystemOperationContext> context,
const FileSystemURL& url,
const CreateSnapshotFileCallback& callback) {
+ FileSystemOperationContext* context_ptr = context.release();
GetFileInfoHelper* helper = new GetFileInfoHelper;
- return context->task_runner()->PostTaskAndReply(
+ return context_ptr->task_runner()->PostTaskAndReply(
FROM_HERE,
Bind(&GetFileInfoHelper::CreateSnapshotFile, Unretained(helper),
- sync_file_util_.get(), context, url),
+ sync_file_util_.get(), base::Owned(context_ptr), url),
Bind(&GetFileInfoHelper::ReplySnapshotFile, Owned(helper), callback));
}