Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: include/AdblockPlus/FileSystem.h

Issue 5728380594946048: Issue 116 - Document the libadblockplus API (Closed)
Patch Set: Remembered that AppInfo is used for more than update checks Created Sept. 2, 2014, 6:23 a.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
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;
}

Powered by Google App Engine
This is Rietveld