/* */ #ifndef D_DISK_ADAPTOR_H #define D_DISK_ADAPTOR_H #include "BinaryStream.h" #include #include #include "TimeA2.h" namespace aria2 { class FileEntry; class FileAllocationIterator; class DiskAdaptor:public BinaryStream { public: enum FileAllocationMethod { FILE_ALLOC_ADAPTIVE, FILE_ALLOC_FALLOC }; DiskAdaptor(); virtual ~DiskAdaptor(); virtual void openFile() = 0; virtual void closeFile() = 0; virtual void openExistingFile() = 0; virtual void initAndOpenFile() = 0; virtual bool fileExists() = 0; virtual int64_t size() = 0; template void setFileEntries(InputIterator first, InputIterator last) { fileEntries_.assign(first, last); } const std::vector >& getFileEntries() const { return fileEntries_; } virtual SharedHandle fileAllocationIterator() = 0; virtual void enableReadOnly() {} virtual void disableReadOnly() {} virtual bool isReadOnlyEnabled() const { return false; } virtual void enableMmap() {} // Assumed each file length is stored in fileEntries or DiskAdaptor knows it. // If each actual file's length is larger than that, truncate file to that // length. // Call one of openFile/openExistingFile/initAndOpenFile before calling this // function. virtual void cutTrailingGarbage() = 0; // Returns the number of files, the actime and modtime of which are // successfully changed. virtual size_t utime(const Time& actime, const Time& modtime) = 0; void setFileAllocationMethod(FileAllocationMethod method) { fileAllocationMethod_ = method; } int getFileAllocationMethod() const { return fileAllocationMethod_; } private: std::vector > fileEntries_; FileAllocationMethod fileAllocationMethod_; }; typedef SharedHandle DiskAdaptorHandle; } // namespace aria2 #endif // D_DISK_ADAPTOR_H