2009-12-19 20:53:53 +01:00
|
|
|
#ifndef MANGLE_VFS_H
|
|
|
|
#define MANGLE_VFS_H
|
|
|
|
|
2010-06-03 20:13:27 +02:00
|
|
|
#include "../stream/stream.hpp"
|
2009-12-19 20:53:53 +01:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace Mangle {
|
|
|
|
namespace VFS {
|
|
|
|
|
|
|
|
/// Generic file info structure
|
|
|
|
struct FileInfo
|
|
|
|
{
|
|
|
|
/// Full name, including path
|
|
|
|
std::string name;
|
2011-04-03 13:06:42 +02:00
|
|
|
|
2009-12-19 20:53:53 +01:00
|
|
|
/// Base name, not including path
|
|
|
|
std::string basename;
|
|
|
|
|
|
|
|
/// Is this a directory?
|
|
|
|
bool isDir;
|
|
|
|
|
|
|
|
/// File size
|
|
|
|
size_t size;
|
2011-04-03 13:06:42 +02:00
|
|
|
|
2009-12-19 20:53:53 +01:00
|
|
|
/// Last modification date
|
|
|
|
time_t time;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef std::vector<FileInfo> FileInfoList;
|
|
|
|
|
2009-12-31 15:37:01 +01:00
|
|
|
typedef boost::shared_ptr<FileInfo> FileInfoPtr;
|
|
|
|
typedef boost::shared_ptr<FileInfoList> FileInfoListPtr;
|
|
|
|
|
2009-12-19 20:53:53 +01:00
|
|
|
/** An interface to any file system or other provider of named data
|
|
|
|
streams
|
|
|
|
*/
|
|
|
|
class VFS
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// Feature options. These should be set in the constructor.
|
|
|
|
|
2009-12-26 10:52:10 +01:00
|
|
|
/// If true, the list() function work
|
|
|
|
bool hasList;
|
|
|
|
|
|
|
|
/// If true, the find() function work
|
2009-12-19 20:53:53 +01:00
|
|
|
bool hasFind;
|
|
|
|
|
|
|
|
/// If true, the file system is case sensitive
|
|
|
|
bool isCaseSensitive;
|
|
|
|
|
|
|
|
/// Virtual destructor
|
|
|
|
virtual ~VFS() {}
|
|
|
|
|
2009-12-31 15:37:01 +01:00
|
|
|
/// Open a new data stream. Deleting the object (letting all the
|
|
|
|
/// pointers to it go out of scope) should be enough to close it.
|
|
|
|
virtual Stream::StreamPtr open(const std::string &name) = 0;
|
2009-12-19 20:53:53 +01:00
|
|
|
|
|
|
|
/// Check for the existence of a file
|
|
|
|
virtual bool isFile(const std::string &name) const = 0;
|
|
|
|
|
|
|
|
/// Check for the existence of a directory
|
|
|
|
virtual bool isDir(const std::string &name) const = 0;
|
|
|
|
|
|
|
|
/// Get info about a single file
|
2009-12-31 15:37:01 +01:00
|
|
|
virtual FileInfoPtr stat(const std::string &name) const = 0;
|
2009-12-19 20:53:53 +01:00
|
|
|
|
|
|
|
/// List all entries in a given directory. A blank dir should be
|
|
|
|
/// interpreted as a the root/current directory of the archive. If
|
|
|
|
/// dirs is true, list directories instead of files.
|
2009-12-31 15:37:01 +01:00
|
|
|
virtual FileInfoListPtr list(const std::string& dir = "",
|
|
|
|
bool recurse=true,
|
|
|
|
bool dirs=false) const = 0;
|
2009-12-19 20:53:53 +01:00
|
|
|
|
|
|
|
/// Find files after a given pattern. Wildcards (*) are
|
|
|
|
/// supported. Only valid if 'hasFind' is true. Don't implement your
|
|
|
|
/// own pattern matching here if the backend doesn't support it
|
|
|
|
/// natively; use a filter instead.
|
2009-12-31 15:37:01 +01:00
|
|
|
virtual FileInfoListPtr find(const std::string& pattern,
|
|
|
|
bool recursive=true,
|
|
|
|
bool dirs=false) const = 0;
|
2009-12-19 20:53:53 +01:00
|
|
|
};
|
|
|
|
|
2009-12-31 15:37:01 +01:00
|
|
|
typedef boost::shared_ptr<VFS> VFSPtr;
|
|
|
|
|
2009-12-19 20:53:53 +01:00
|
|
|
}} // namespaces
|
|
|
|
#endif
|