summaryrefslogtreecommitdiffstats
path: root/webkit/fileapi
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/fileapi')
-rw-r--r--webkit/fileapi/file_system_callback_dispatcher.h4
-rw-r--r--webkit/fileapi/file_system_file_util.cc5
-rw-r--r--webkit/fileapi/file_system_file_util.h4
-rw-r--r--webkit/fileapi/file_system_file_util_proxy.cc5
-rw-r--r--webkit/fileapi/file_system_file_util_proxy.h7
-rw-r--r--webkit/fileapi/file_system_operation.cc11
-rw-r--r--webkit/fileapi/file_system_operation.h9
-rw-r--r--webkit/fileapi/file_system_operation_unittest.cc16
-rw-r--r--webkit/fileapi/local_file_system_file_util.cc5
-rw-r--r--webkit/fileapi/local_file_system_file_util.h4
10 files changed, 49 insertions, 21 deletions
diff --git a/webkit/fileapi/file_system_callback_dispatcher.h b/webkit/fileapi/file_system_callback_dispatcher.h
index e5265bd..2bffe54 100644
--- a/webkit/fileapi/file_system_callback_dispatcher.h
+++ b/webkit/fileapi/file_system_callback_dispatcher.h
@@ -22,7 +22,9 @@ class FileSystemCallbackDispatcher {
virtual void DidSucceed() = 0;
// Callback to report information for a file.
- virtual void DidReadMetadata(const base::PlatformFileInfo& file_info) = 0;
+ virtual void DidReadMetadata(
+ const base::PlatformFileInfo& file_info,
+ const FilePath& platform_path) = 0;
// Callback to report the contents of a directory. If the contents of
// the given directory are reported in one batch, then |entries| will have
diff --git a/webkit/fileapi/file_system_file_util.cc b/webkit/fileapi/file_system_file_util.cc
index 10af22f..1dceed2 100644
--- a/webkit/fileapi/file_system_file_util.cc
+++ b/webkit/fileapi/file_system_file_util.cc
@@ -61,12 +61,13 @@ PlatformFileError FileSystemFileUtil::EnsureFileExists(
PlatformFileError FileSystemFileUtil::GetFileInfo(
FileSystemOperationContext* unused,
const FilePath& file_path,
- base::PlatformFileInfo* file_info) {
+ base::PlatformFileInfo* file_info,
+ FilePath* platform_file_path) {
if (!file_util::PathExists(file_path))
return base::PLATFORM_FILE_ERROR_NOT_FOUND;
if (!file_util::GetFileInfo(file_path, file_info))
return base::PLATFORM_FILE_ERROR_FAILED;
- file_info->path = file_path;
+ *platform_file_path = file_path;
return base::PLATFORM_FILE_OK;
}
diff --git a/webkit/fileapi/file_system_file_util.h b/webkit/fileapi/file_system_file_util.h
index 620ff09..a208ae4 100644
--- a/webkit/fileapi/file_system_file_util.h
+++ b/webkit/fileapi/file_system_file_util.h
@@ -68,7 +68,9 @@ class FileSystemFileUtil {
// callback.
virtual PlatformFileError GetFileInfo(
FileSystemOperationContext* context,
- const FilePath& file_, base::PlatformFileInfo* file_info);
+ const FilePath& file_,
+ base::PlatformFileInfo* file_info,
+ FilePath* platform_path);
virtual PlatformFileError ReadDirectory(
FileSystemOperationContext* context,
diff --git a/webkit/fileapi/file_system_file_util_proxy.cc b/webkit/fileapi/file_system_file_util_proxy.cc
index faf3d4a..0f88ff0 100644
--- a/webkit/fileapi/file_system_file_util_proxy.cc
+++ b/webkit/fileapi/file_system_file_util_proxy.cc
@@ -208,11 +208,11 @@ class RelayGetFileInfo : public MessageLoopRelay {
virtual void RunWork() {
set_error_code(
file_system_file_util()->GetFileInfo(
- context(), file_path_, &file_info_));
+ context(), file_path_, &file_info_, &platform_path_));
}
virtual void RunCallback() {
- callback_->Run(error_code(), file_info_);
+ callback_->Run(error_code(), file_info_, platform_path_);
delete callback_;
}
@@ -220,6 +220,7 @@ class RelayGetFileInfo : public MessageLoopRelay {
fileapi::FileSystemFileUtilProxy::GetFileInfoCallback* callback_;
FilePath file_path_;
base::PlatformFileInfo file_info_;
+ FilePath platform_path_;
};
class RelayReadDirectory : public MessageLoopRelay {
diff --git a/webkit/fileapi/file_system_file_util_proxy.h b/webkit/fileapi/file_system_file_util_proxy.h
index 288d4cf..de4b320 100644
--- a/webkit/fileapi/file_system_file_util_proxy.h
+++ b/webkit/fileapi/file_system_file_util_proxy.h
@@ -25,6 +25,8 @@ class FileSystemOperationContext;
using base::MessageLoopProxy;
using base::PlatformFile;
+using base::PlatformFileError;
+using base::PlatformFileInfo;
// This class provides asynchronous access to common file routines for the
// FileSystem API.
@@ -34,7 +36,10 @@ class FileSystemFileUtilProxy {
typedef base::FileUtilProxy::CreateOrOpenCallback CreateOrOpenCallback;
typedef base::FileUtilProxy::EnsureFileExistsCallback
EnsureFileExistsCallback;
- typedef base::FileUtilProxy::GetFileInfoCallback GetFileInfoCallback;
+ typedef Callback3<PlatformFileError /* error code */,
+ const PlatformFileInfo& /* file_info */,
+ const FilePath& /* platform_path, where possible */
+ >::Type GetFileInfoCallback;
typedef base::FileUtilProxy::ReadDirectoryCallback ReadDirectoryCallback;
// Creates or opens a file with the given flags. It is invalid to pass NULL
diff --git a/webkit/fileapi/file_system_operation.cc b/webkit/fileapi/file_system_operation.cc
index 1555cd7..4ddfd0c 100644
--- a/webkit/fileapi/file_system_operation.cc
+++ b/webkit/fileapi/file_system_operation.cc
@@ -454,7 +454,8 @@ void FileSystemOperation::DidFinishFileOperation(
void FileSystemOperation::DidDirectoryExists(
base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info) {
+ const base::PlatformFileInfo& file_info,
+ const FilePath& unused) {
if (rv == base::PLATFORM_FILE_OK) {
if (file_info.is_directory)
dispatcher_->DidSucceed();
@@ -468,7 +469,8 @@ void FileSystemOperation::DidDirectoryExists(
void FileSystemOperation::DidFileExists(
base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info) {
+ const base::PlatformFileInfo& file_info,
+ const FilePath& unused) {
if (rv == base::PLATFORM_FILE_OK) {
if (file_info.is_directory)
dispatcher_->DidFail(base::PLATFORM_FILE_ERROR_NOT_A_FILE);
@@ -482,9 +484,10 @@ void FileSystemOperation::DidFileExists(
void FileSystemOperation::DidGetMetadata(
base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info) {
+ const base::PlatformFileInfo& file_info,
+ const FilePath& platform_path) {
if (rv == base::PLATFORM_FILE_OK)
- dispatcher_->DidReadMetadata(file_info);
+ dispatcher_->DidReadMetadata(file_info, platform_path);
else
dispatcher_->DidFail(rv);
delete this;
diff --git a/webkit/fileapi/file_system_operation.h b/webkit/fileapi/file_system_operation.h
index 719ac8e..f6d2016 100644
--- a/webkit/fileapi/file_system_operation.h
+++ b/webkit/fileapi/file_system_operation.h
@@ -112,11 +112,14 @@ class FileSystemOperation {
void DidFinishFileOperation(base::PlatformFileError rv);
void DidDirectoryExists(base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info);
+ const base::PlatformFileInfo& file_info,
+ const FilePath& unused);
void DidFileExists(base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info);
+ const base::PlatformFileInfo& file_info,
+ const FilePath& unused);
void DidGetMetadata(base::PlatformFileError rv,
- const base::PlatformFileInfo& file_info);
+ const base::PlatformFileInfo& file_info,
+ const FilePath& platform_path);
void DidReadDirectory(
base::PlatformFileError rv,
const std::vector<base::FileUtilProxy::Entry>& entries);
diff --git a/webkit/fileapi/file_system_operation_unittest.cc b/webkit/fileapi/file_system_operation_unittest.cc
index 5641923..9cd128c 100644
--- a/webkit/fileapi/file_system_operation_unittest.cc
+++ b/webkit/fileapi/file_system_operation_unittest.cc
@@ -43,6 +43,8 @@ class FileSystemOperationTest : public testing::Test {
int status() const { return status_; }
void set_info(const base::PlatformFileInfo& info) { info_ = info; }
const base::PlatformFileInfo& info() const { return info_; }
+ void set_path(const FilePath& path) { path_ = path; }
+ const FilePath& path() const { return path_; }
void set_entries(const std::vector<base::FileUtilProxy::Entry>& entries) {
entries_ = entries;
}
@@ -57,6 +59,7 @@ class FileSystemOperationTest : public testing::Test {
// For post-operation status.
int status_;
base::PlatformFileInfo info_;
+ FilePath path_;
std::vector<base::FileUtilProxy::Entry> entries_;
DISALLOW_COPY_AND_ASSIGN(FileSystemOperationTest);
@@ -74,8 +77,11 @@ class MockDispatcher : public FileSystemCallbackDispatcher {
test_->set_status(kFileOperationSucceeded);
}
- virtual void DidReadMetadata(const base::PlatformFileInfo& info) {
+ virtual void DidReadMetadata(
+ const base::PlatformFileInfo& info,
+ const FilePath& platform_path) {
test_->set_info(info);
+ test_->set_path(platform_path);
test_->set_status(kFileOperationSucceeded);
}
@@ -564,6 +570,7 @@ TEST_F(FileSystemOperationTest, TestExistsAndMetadataSuccess) {
MessageLoop::current()->RunAllPending();
EXPECT_EQ(kFileOperationSucceeded, status());
EXPECT_TRUE(info().is_directory);
+ EXPECT_EQ(dir.path(), path());
FilePath file;
file_util::CreateTemporaryFileInDir(dir.path(), &file);
@@ -575,6 +582,7 @@ TEST_F(FileSystemOperationTest, TestExistsAndMetadataSuccess) {
MessageLoop::current()->RunAllPending();
EXPECT_EQ(kFileOperationSucceeded, status());
EXPECT_FALSE(info().is_directory);
+ EXPECT_EQ(file, path());
}
TEST_F(FileSystemOperationTest, TestTypeMismatchErrors) {
@@ -592,9 +600,9 @@ TEST_F(FileSystemOperationTest, TestTypeMismatchErrors) {
}
TEST_F(FileSystemOperationTest, TestReadDirFailure) {
- // Path doesn't exists
- FilePath nonexisting_dir_path(base_.path().Append(
- FILE_PATH_LITERAL("NonExistingDir")));
+ // Path doesn't exist
+ FilePath nonexisting_dir_path(base_.path().Append(
+ FILE_PATH_LITERAL("NonExistingDir")));
file_util::EnsureEndsWithSeparator(&nonexisting_dir_path);
operation()->ReadDirectory(nonexisting_dir_path);
MessageLoop::current()->RunAllPending();
diff --git a/webkit/fileapi/local_file_system_file_util.cc b/webkit/fileapi/local_file_system_file_util.cc
index 8def3f6..068a052 100644
--- a/webkit/fileapi/local_file_system_file_util.cc
+++ b/webkit/fileapi/local_file_system_file_util.cc
@@ -47,14 +47,15 @@ PlatformFileError LocalFileSystemFileUtil::EnsureFileExists(
PlatformFileError LocalFileSystemFileUtil::GetFileInfo(
FileSystemOperationContext* context,
const FilePath& file_path,
- base::PlatformFileInfo* file_info) {
+ base::PlatformFileInfo* file_info,
+ FilePath* platform_file_path) {
FilePath local_path =
GetLocalPath(context, context->src_origin_url(), context->src_type(),
file_path);
if (local_path.empty())
return base::PLATFORM_FILE_ERROR_INVALID_OPERATION;
return FileSystemFileUtil::GetInstance()->GetFileInfo(
- context, local_path, file_info);
+ context, local_path, file_info, platform_file_path);
}
PlatformFileError LocalFileSystemFileUtil::ReadDirectory(
diff --git a/webkit/fileapi/local_file_system_file_util.h b/webkit/fileapi/local_file_system_file_util.h
index 428b157..3e5855a 100644
--- a/webkit/fileapi/local_file_system_file_util.h
+++ b/webkit/fileapi/local_file_system_file_util.h
@@ -51,7 +51,9 @@ class LocalFileSystemFileUtil : public FileSystemFileUtil {
virtual PlatformFileError GetFileInfo(
FileSystemOperationContext* context,
- const FilePath& file_, base::PlatformFileInfo* file_info);
+ const FilePath& file_,
+ base::PlatformFileInfo* file_info,
+ FilePath* platform_file);
virtual PlatformFileError ReadDirectory(
FileSystemOperationContext* context,