|  | // 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. | 
|  |  | 
|  | #ifndef STORAGE_BLOB_FILE_STREAM_READER_H_ | 
|  | #define STORAGE_BLOB_FILE_STREAM_READER_H_ | 
|  |  | 
|  | #include "base/basictypes.h" | 
|  | #include "base/compiler_specific.h" | 
|  | #include "base/files/file.h" | 
|  | #include "net/base/completion_callback.h" | 
|  | #include "storage/browser/storage_browser_export.h" | 
|  |  | 
|  | namespace base { | 
|  | class FilePath; | 
|  | class TaskRunner; | 
|  | class Time; | 
|  | } | 
|  |  | 
|  | namespace net { | 
|  | class IOBuffer; | 
|  | } | 
|  |  | 
|  | namespace storage { | 
|  | class FileSystemContext; | 
|  | class FileSystemURL; | 
|  | } | 
|  |  | 
|  | namespace storage { | 
|  |  | 
|  | // A generic interface for reading a file-like object. | 
|  | class FileStreamReader { | 
|  | public: | 
|  | // Creates a new FileReader for a local file |file_path|. | 
|  | // |initial_offset| specifies the offset in the file where the first read | 
|  | // should start.  If the given offset is out of the file range any | 
|  | // read operation may error out with net::ERR_REQUEST_RANGE_NOT_SATISFIABLE. | 
|  | // |expected_modification_time| specifies the expected last modification | 
|  | // If the value is non-null, the reader will check the underlying file's | 
|  | // actual modification time to see if the file has been modified, and if | 
|  | // it does any succeeding read operations should fail with | 
|  | // ERR_UPLOAD_FILE_CHANGED error. | 
|  | STORAGE_EXPORT static FileStreamReader* | 
|  | CreateForLocalFile(base::TaskRunner* task_runner, | 
|  | const base::FilePath& file_path, | 
|  | int64 initial_offset, | 
|  | const base::Time& expected_modification_time); | 
|  |  | 
|  | // Creates a new reader for a filesystem URL |url| form |initial_offset|. | 
|  | // |expected_modification_time| specifies the expected last modification if | 
|  | // the value is non-null, the reader will check the underlying file's actual | 
|  | // modification time to see if the file has been modified, and if it does any | 
|  | // succeeding read operations should fail with ERR_UPLOAD_FILE_CHANGED error. | 
|  | STORAGE_EXPORT static FileStreamReader* | 
|  | CreateForFileSystemFile(storage::FileSystemContext* context, | 
|  | const storage::FileSystemURL& url, | 
|  | int64 initial_offset, | 
|  | const base::Time& expected_modification_time); | 
|  |  | 
|  | // Verify if the underlying file has not been modified. | 
|  | STORAGE_EXPORT static bool VerifySnapshotTime( | 
|  | const base::Time& expected_modification_time, | 
|  | const base::File::Info& file_info); | 
|  |  | 
|  | // It is valid to delete the reader at any time.  If the stream is deleted | 
|  | // while it has a pending read, its callback will not be called. | 
|  | virtual ~FileStreamReader() {} | 
|  |  | 
|  | // Reads from the current cursor position asynchronously. | 
|  | // | 
|  | // Up to buf_len bytes will be copied into buf.  (In other words, partial | 
|  | // reads are allowed.)  Returns the number of bytes copied, 0 if at | 
|  | // end-of-file, or an error code if the operation could not be performed. | 
|  | // If the read could not complete synchronously, then ERR_IO_PENDING is | 
|  | // returned, and the callback will be run on the thread where Read() | 
|  | // was called, when the read has completed. | 
|  | // | 
|  | // It is invalid to call Read while there is an in-flight Read operation. | 
|  | // | 
|  | // If the stream is deleted while it has an in-flight Read operation | 
|  | // |callback| will not be called. | 
|  | virtual int Read(net::IOBuffer* buf, int buf_len, | 
|  | const net::CompletionCallback& callback) = 0; | 
|  |  | 
|  | // Returns the length of the file if it could successfully retrieve the | 
|  | // file info *and* its last modification time equals to | 
|  | // expected modification time (rv >= 0 cases). | 
|  | // Otherwise, a negative error code is returned (rv < 0 cases). | 
|  | // If the stream is deleted while it has an in-flight GetLength operation | 
|  | // |callback| will not be called. | 
|  | // Note that the return type is int64 to return a larger file's size (a file | 
|  | // larger than 2G) but an error code should fit in the int range (may be | 
|  | // smaller than int64 range). | 
|  | virtual int64 GetLength(const net::Int64CompletionCallback& callback) = 0; | 
|  | }; | 
|  |  | 
|  | }  // namespace storage | 
|  |  | 
|  | #endif  // STORAGE_BLOB_FILE_STREAM_READER_H_ |