| Index: include/AdblockPlus/FileSystem.h |
| =================================================================== |
| --- a/include/AdblockPlus/FileSystem.h |
| +++ b/include/AdblockPlus/FileSystem.h |
| @@ -26,9 +26,15 @@ |
| namespace AdblockPlus |
| { |
| + /** |
| + * File system interface. |
| + */ |
| class FileSystem |
| { |
| public: |
| + /** |
| + * Result of a stat operation, i.e.\ information about a file. |
| + */ |
| struct StatResult |
| { |
| StatResult() |
| @@ -39,24 +45,77 @@ |
| lastModified = 0; |
| } |
| + /** |
| + * File exists. |
| + */ |
| bool exists; |
| + |
| + /** |
| + * File is a directory. |
| + */ |
| bool isDirectory; |
| + |
| + /** |
| + * File is a regular file. |
| + */ |
| bool isFile; |
| + |
| + /** |
| + * POSIX time of the last modification. |
| + */ |
| int64_t lastModified; |
| }; |
| virtual ~FileSystem() {} |
| + |
| + /** |
| + * Reads from a file. |
| + * @param path File path. |
| + * @return Input stream with the file's contents. |
| + */ |
| virtual std::tr1::shared_ptr<std::istream> |
| Read(const std::string& path) const = 0; |
| + |
| + /** |
| + * Writes to a file. |
| + * @param path File path. |
| + * @param data Input stream with the data to write. |
| + */ |
| virtual void Write(const std::string& path, |
| std::tr1::shared_ptr<std::istream> data) = 0; |
| + |
| + /** |
| + * Moves a file (i.e.\ renames it). |
| + * @param fromPath Current path to the file. |
| + * @param toPath New path to the file. |
| + */ |
| virtual void Move(const std::string& fromPath, |
| const std::string& toPath) = 0; |
| + |
| + /** |
| + * Removes a file. |
| + * @param path File path. |
| + */ |
| virtual void Remove(const std::string& path) = 0; |
| + |
| + /** |
| + * Retrieves information about a file. |
| + * @param path File path. |
| + * @return File information. |
| + */ |
| virtual StatResult Stat(const std::string& path) const = 0; |
| + |
| + /** |
| + * Returns the absolute path to a file. |
| + * @param path File path (can be relative or absolute). |
| + * @return Absolute file path. |
| + */ |
| virtual std::string Resolve(const std::string& path) const = 0; |
| }; |
| + /** |
| + * Shared smart pointer to a `FileSystem` instance. |
| + */ |
| typedef std::tr1::shared_ptr<FileSystem> FileSystemPtr; |
| } |