/* */ #ifndef D_DISK_ADAPTOR_H #define D_DISK_ADAPTOR_H #include "BinaryStream.h" #include #include #include #include "TimeA2.h" namespace aria2 { class FileEntry; class FileAllocationIterator; class WrDiskCacheEntry; class OpenedFileCounter; class DiskAdaptor:public BinaryStream { public: enum FileAllocationMethod { FILE_ALLOC_ADAPTIVE, FILE_ALLOC_FALLOC, FILE_ALLOC_TRUNC }; 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 std::unique_ptr fileAllocationIterator() = 0; virtual void enableReadOnly() {} virtual void disableReadOnly() {} virtual bool isReadOnlyEnabled() const { return false; } // Enables mmap feature. Some derived classes may require that files // have been opened before this method call. 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; // Just like readData(), but drop cache after read. virtual ssize_t readDataDropCache(unsigned char* data, size_t len, int64_t offset) = 0; // Writes cached data to the underlying disk. virtual void writeCache(const WrDiskCacheEntry* entry) = 0; void setFileAllocationMethod(FileAllocationMethod method) { fileAllocationMethod_ = method; } int getFileAllocationMethod() const { return fileAllocationMethod_; } // Closes at most |numClose| files if possible. This method is used to // ensure that global number of open file stays under certain limit. // Returns the number of closed files. virtual size_t tryCloseFile(size_t numClose) { return 0; } void setOpenedFileCounter (std::shared_ptr openedFileCounter) { openedFileCounter_ = std::move(openedFileCounter); } const std::shared_ptr& getOpenedFileCounter() const { return openedFileCounter_; } private: std::vector > fileEntries_; FileAllocationMethod fileAllocationMethod_; std::shared_ptr openedFileCounter_; }; } // namespace aria2 #endif // D_DISK_ADAPTOR_H