| Index: webkit/browser/fileapi/file_system_file_util.h
|
| diff --git a/webkit/browser/fileapi/file_system_file_util.h b/webkit/browser/fileapi/file_system_file_util.h
|
| index 2a9378702e75d6d29684b4806224a486ad463c4b..5aa3676dddbfe6b3b13670636565c6ea28001b67 100644
|
| --- a/webkit/browser/fileapi/file_system_file_util.h
|
| +++ b/webkit/browser/fileapi/file_system_file_util.h
|
| @@ -1,186 +1,5 @@
|
| -// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| +// Copyright 2014 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.
|
|
|
| -#ifndef WEBKIT_BROWSER_FILEAPI_FILE_SYSTEM_FILE_UTIL_H_
|
| -#define WEBKIT_BROWSER_FILEAPI_FILE_SYSTEM_FILE_UTIL_H_
|
| -
|
| -#include "base/files/file.h"
|
| -#include "base/files/file_path.h"
|
| -#include "base/memory/scoped_ptr.h"
|
| -#include "webkit/browser/fileapi/file_system_operation.h"
|
| -#include "webkit/browser/storage_browser_export.h"
|
| -#include "webkit/common/blob/scoped_file.h"
|
| -
|
| -namespace base {
|
| -class Time;
|
| -}
|
| -
|
| -namespace storage {
|
| -
|
| -class FileSystemOperationContext;
|
| -class FileSystemURL;
|
| -
|
| -// A file utility interface that provides basic file utility methods for
|
| -// FileSystem API.
|
| -//
|
| -// Layering structure of the FileSystemFileUtil was split out.
|
| -// See http://crbug.com/128136 if you need it.
|
| -class STORAGE_EXPORT FileSystemFileUtil {
|
| - public:
|
| - typedef FileSystemOperation::CopyOrMoveOption CopyOrMoveOption;
|
| -
|
| - // It will be implemented by each subclass such as FileSystemFileEnumerator.
|
| - class STORAGE_EXPORT AbstractFileEnumerator {
|
| - public:
|
| - virtual ~AbstractFileEnumerator() {}
|
| -
|
| - // Returns an empty string if there are no more results.
|
| - virtual base::FilePath Next() = 0;
|
| -
|
| - // These methods return metadata for the file most recently returned by
|
| - // Next(). If Next() has never been called, or if Next() most recently
|
| - // returned an empty string, then return the default values of 0,
|
| - // "null time", and false, respectively.
|
| - virtual int64 Size() = 0;
|
| - virtual base::Time LastModifiedTime() = 0;
|
| - virtual bool IsDirectory() = 0;
|
| - };
|
| -
|
| - class STORAGE_EXPORT EmptyFileEnumerator
|
| - : public AbstractFileEnumerator {
|
| - virtual base::FilePath Next() OVERRIDE;
|
| - virtual int64 Size() OVERRIDE;
|
| - virtual base::Time LastModifiedTime() OVERRIDE;
|
| - virtual bool IsDirectory() OVERRIDE;
|
| - };
|
| -
|
| - virtual ~FileSystemFileUtil() {}
|
| -
|
| - // Creates or opens a file with the given flags.
|
| - // See header comments for AsyncFileUtil::CreateOrOpen() for more details.
|
| - // This is used only by Pepper/NaCl File API.
|
| - virtual base::File CreateOrOpen(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - int file_flags) = 0;
|
| -
|
| - // Ensures that the given |url| exist. This creates a empty new file
|
| - // at |url| if the |url| does not exist.
|
| - // See header comments for AsyncFileUtil::EnsureFileExists() for more details.
|
| - virtual base::File::Error EnsureFileExists(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url, bool* created) = 0;
|
| -
|
| - // Creates directory at given url.
|
| - // See header comments for AsyncFileUtil::CreateDirectory() for more details.
|
| - virtual base::File::Error CreateDirectory(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - bool exclusive,
|
| - bool recursive) = 0;
|
| -
|
| - // Retrieves the information about a file.
|
| - // See header comments for AsyncFileUtil::GetFileInfo() for more details.
|
| - virtual base::File::Error GetFileInfo(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - base::File::Info* file_info,
|
| - base::FilePath* platform_path) = 0;
|
| -
|
| - // Returns a pointer to a new instance of AbstractFileEnumerator which is
|
| - // implemented for each FileSystemFileUtil subclass. The instance needs to be
|
| - // freed by the caller, and its lifetime should not extend past when the
|
| - // current call returns to the main FILE message loop.
|
| - //
|
| - // The supplied context must remain valid at least lifetime of the enumerator
|
| - // instance.
|
| - virtual scoped_ptr<AbstractFileEnumerator> CreateFileEnumerator(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& root_url) = 0;
|
| -
|
| - // Maps |file_system_url| given |context| into |local_file_path|
|
| - // which represents physical file location on the host OS.
|
| - // This may not always make sense for all subclasses.
|
| - virtual base::File::Error GetLocalFilePath(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& file_system_url,
|
| - base::FilePath* local_file_path) = 0;
|
| -
|
| - // Updates the file metadata information.
|
| - // See header comments for AsyncFileUtil::Touch() for more details.
|
| - virtual base::File::Error Touch(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - const base::Time& last_access_time,
|
| - const base::Time& last_modified_time) = 0;
|
| -
|
| - // Truncates a file to the given length.
|
| - // See header comments for AsyncFileUtil::Truncate() for more details.
|
| - virtual base::File::Error Truncate(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - int64 length) = 0;
|
| -
|
| - // Copies or moves a single file from |src_url| to |dest_url|.
|
| - // The filesystem type of |src_url| and |dest_url| MUST be same.
|
| - // For |option|, please see file_system_operation.h
|
| - //
|
| - // This returns:
|
| - // - File::FILE_ERROR_NOT_FOUND if |src_url|
|
| - // or the parent directory of |dest_url| does not exist.
|
| - // - File::FILE_ERROR_NOT_A_FILE if |src_url| exists but is not a file.
|
| - // - File::FILE_ERROR_INVALID_OPERATION if |dest_url| exists and
|
| - // is not a file.
|
| - // - File::FILE_ERROR_FAILED if |dest_url| does not exist and
|
| - // its parent path is a file.
|
| - //
|
| - virtual base::File::Error CopyOrMoveFile(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& src_url,
|
| - const FileSystemURL& dest_url,
|
| - CopyOrMoveOption option,
|
| - bool copy) = 0;
|
| -
|
| - // Copies in a single file from a different filesystem.
|
| - // See header comments for AsyncFileUtil::CopyInForeignFile() for
|
| - // more details.
|
| - virtual base::File::Error CopyInForeignFile(
|
| - FileSystemOperationContext* context,
|
| - const base::FilePath& src_file_path,
|
| - const FileSystemURL& dest_url) = 0;
|
| -
|
| - // Deletes a single file.
|
| - // See header comments for AsyncFileUtil::DeleteFile() for more details.
|
| - virtual base::File::Error DeleteFile(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url) = 0;
|
| -
|
| - // Deletes a single empty directory.
|
| - // See header comments for AsyncFileUtil::DeleteDirectory() for more details.
|
| - virtual base::File::Error DeleteDirectory(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url) = 0;
|
| -
|
| - // Creates a local snapshot file for a given |url| and returns the
|
| - // metadata and platform path of the snapshot file via |callback|.
|
| - //
|
| - // See header comments for AsyncFileUtil::CreateSnapshotFile() for
|
| - // more details.
|
| - virtual storage::ScopedFile CreateSnapshotFile(
|
| - FileSystemOperationContext* context,
|
| - const FileSystemURL& url,
|
| - base::File::Error* error,
|
| - base::File::Info* file_info,
|
| - base::FilePath* platform_path) = 0;
|
| -
|
| - protected:
|
| - FileSystemFileUtil() {}
|
| -
|
| - private:
|
| - DISALLOW_COPY_AND_ASSIGN(FileSystemFileUtil);
|
| -};
|
| -
|
| -} // namespace storage
|
| -
|
| -#endif // WEBKIT_BROWSER_FILEAPI_FILE_SYSTEM_FILE_UTIL_H_
|
| +#include "storage/browser/fileapi/file_system_file_util.h"
|
|
|