DiskAdaptor.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /* <!-- copyright */
  2. /*
  3. * aria2 - The high speed download utility
  4. *
  5. * Copyright (C) 2006 Tatsuhiro Tsujikawa
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. *
  21. * In addition, as a special exception, the copyright holders give
  22. * permission to link the code of portions of this program with the
  23. * OpenSSL library under certain conditions as described in each
  24. * individual source file, and distribute linked combinations
  25. * including the two.
  26. * You must obey the GNU General Public License in all respects
  27. * for all of the code used other than OpenSSL. If you modify
  28. * file(s) with this exception, you may extend this exception to your
  29. * version of the file(s), but you are not obligated to do so. If you
  30. * do not wish to do so, delete this exception statement from your
  31. * version. If you delete this exception statement from all source
  32. * files in the program, then also delete it here.
  33. */
  34. /* copyright --> */
  35. #ifndef D_DISK_ADAPTOR_H
  36. #define D_DISK_ADAPTOR_H
  37. #include "BinaryStream.h"
  38. #include <string>
  39. #include <vector>
  40. #include <memory>
  41. #include "TimeA2.h"
  42. namespace aria2 {
  43. class FileEntry;
  44. class FileAllocationIterator;
  45. class WrDiskCacheEntry;
  46. class OpenedFileCounter;
  47. class DiskAdaptor : public BinaryStream {
  48. public:
  49. enum FileAllocationMethod {
  50. FILE_ALLOC_ADAPTIVE,
  51. FILE_ALLOC_FALLOC,
  52. FILE_ALLOC_TRUNC
  53. };
  54. DiskAdaptor();
  55. virtual ~DiskAdaptor();
  56. virtual void openFile() = 0;
  57. virtual void closeFile() = 0;
  58. virtual void openExistingFile() = 0;
  59. virtual void initAndOpenFile() = 0;
  60. virtual bool fileExists() = 0;
  61. virtual int64_t size() = 0;
  62. template <typename InputIterator>
  63. void setFileEntries(InputIterator first, InputIterator last)
  64. {
  65. fileEntries_.assign(first, last);
  66. }
  67. const std::vector<std::shared_ptr<FileEntry>>& getFileEntries() const
  68. {
  69. return fileEntries_;
  70. }
  71. virtual std::unique_ptr<FileAllocationIterator> fileAllocationIterator() = 0;
  72. virtual void enableReadOnly() {}
  73. virtual void disableReadOnly() {}
  74. virtual bool isReadOnlyEnabled() const { return false; }
  75. // Enables mmap feature. Some derived classes may require that files
  76. // have been opened before this method call.
  77. virtual void enableMmap() {}
  78. // Assumed each file length is stored in fileEntries or DiskAdaptor knows it.
  79. // If each actual file's length is larger than that, truncate file to that
  80. // length.
  81. // Call one of openFile/openExistingFile/initAndOpenFile before calling this
  82. // function.
  83. virtual void cutTrailingGarbage() = 0;
  84. // Returns the number of files, the actime and modtime of which are
  85. // successfully changed.
  86. virtual size_t utime(const Time& actime, const Time& modtime) = 0;
  87. // Just like readData(), but drop cache after read.
  88. virtual ssize_t readDataDropCache(unsigned char* data, size_t len,
  89. int64_t offset) = 0;
  90. // Writes cached data to the underlying disk.
  91. virtual void writeCache(const WrDiskCacheEntry* entry) = 0;
  92. void setFileAllocationMethod(FileAllocationMethod method)
  93. {
  94. fileAllocationMethod_ = method;
  95. }
  96. int getFileAllocationMethod() const { return fileAllocationMethod_; }
  97. // Closes at most |numClose| files if possible. This method is used to
  98. // ensure that global number of open file stays under certain limit.
  99. // Returns the number of closed files.
  100. virtual size_t tryCloseFile(size_t numClose) { return 0; }
  101. void
  102. setOpenedFileCounter(std::shared_ptr<OpenedFileCounter> openedFileCounter)
  103. {
  104. openedFileCounter_ = std::move(openedFileCounter);
  105. }
  106. const std::shared_ptr<OpenedFileCounter>& getOpenedFileCounter() const
  107. {
  108. return openedFileCounter_;
  109. }
  110. private:
  111. std::vector<std::shared_ptr<FileEntry>> fileEntries_;
  112. FileAllocationMethod fileAllocationMethod_;
  113. std::shared_ptr<OpenedFileCounter> openedFileCounter_;
  114. };
  115. } // namespace aria2
  116. #endif // D_DISK_ADAPTOR_H