download_helper.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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_DOWNLOAD_HELPER_H
  36. #define D_DOWNLOAD_HELPER_H
  37. #include "common.h"
  38. #include <string>
  39. #include <vector>
  40. #include <set>
  41. #include "SharedHandle.h"
  42. namespace aria2 {
  43. class RequestGroup;
  44. class Option;
  45. class MetadataInfo;
  46. class DownloadContext;
  47. class UriListParser;
  48. class ValueBase;
  49. #ifdef ENABLE_BITTORRENT
  50. // Create RequestGroup object using torrent file specified by
  51. // metaInfoUri, which is treated as local file path. If non-empty
  52. // torrentData is specified, then it is used as a content of torrent
  53. // file instead. If adjustAnnounceUri is true, announce URIs are
  54. // adjusted using bittorrent::adjustAnnounceUri(). In this function,
  55. // force-sequential is ignored.
  56. void createRequestGroupForBitTorrent
  57. (std::vector<SharedHandle<RequestGroup> >& result,
  58. const SharedHandle<Option>& option,
  59. const std::vector<std::string>& uris,
  60. const std::string& metaInfoUri,
  61. const std::string& torrentData = "",
  62. bool adjustAnnounceUri = true);
  63. // Create RequestGroup object using already decoded torrent metainfo
  64. // structure. If adjustAnnounceUri is true, announce URIs are
  65. // adjusted using bittorrent::adjustAnnounceUri(). In this function,
  66. // force-sequential is ignored.
  67. void createRequestGroupForBitTorrent
  68. (std::vector<SharedHandle<RequestGroup> >& result,
  69. const SharedHandle<Option>& option,
  70. const std::vector<std::string>& uris,
  71. const std::string& metaInfoUri,
  72. const SharedHandle<ValueBase>& torrent,
  73. bool adjustAnnounceUri = true);
  74. #endif // ENABLE_BITTORRENT
  75. #ifdef ENABLE_METALINK
  76. // Create RequestGroup objects using Metalink file specified by
  77. // metalink-file option. If non-empty metalinkData is specified, it is
  78. // used as a content of metalink file instead.
  79. void createRequestGroupForMetalink
  80. (std::vector<SharedHandle<RequestGroup> >& result,
  81. const SharedHandle<Option>& option,
  82. const std::string& metalinkData = "");
  83. #endif // ENABLE_METALINK
  84. // Reads one entry from uriListParser and creates RequestGroups from
  85. // it and store them in result. If the bad entry is found, this
  86. // function just skips it and reads next entry. If at least one
  87. // RequestGroup is created successfully, this function returns true
  88. // and created RequestGroups are stored in result. If no RequestGroup
  89. // is created and uriListParser reads all input, this function returns
  90. // false. The option is used as a option template.
  91. bool createRequestGroupFromUriListParser
  92. (std::vector<SharedHandle<RequestGroup> >& result,
  93. const Option* option,
  94. UriListParser* uriListParser);
  95. // Creates UriListParser using given filename. If filename is "-",
  96. // then UriListParser is configured to read from standard input.
  97. // Otherwise, this function first checks file denoted by filename
  98. // exists. If it does not exist, this function throws exception.
  99. // This function returns SharedHandle<UriListParser> object if it
  100. // succeeds.
  101. SharedHandle<UriListParser> openUriListParser(const std::string& filename);
  102. // Create RequestGroup objects from reading file specified by input-file option.
  103. // If the value of input-file option is "-", stdin is used as a input source.
  104. // Each line is treated as if it is provided in command-line argument.
  105. // The additional out and dir options can be specified after each line of URIs.
  106. // This optional line must start with white space(s).
  107. void createRequestGroupForUriList
  108. (std::vector<SharedHandle<RequestGroup> >& result,
  109. const SharedHandle<Option>& option);
  110. // Create RequestGroup object using provided uris. If ignoreLocalPath
  111. // is true, a path to torrent file abd metalink file are ignored. If
  112. // throwOnError is true, exception will be thrown when Metalink
  113. // Document or .torrent file cannot be parsed or unrecognized URI is
  114. // given. If throwOnError is false, these errors are just logged as
  115. // error.
  116. void createRequestGroupForUri
  117. (std::vector<SharedHandle<RequestGroup> >& result,
  118. const SharedHandle<Option>& option,
  119. const std::vector<std::string>& uris,
  120. bool ignoreForceSequential = false,
  121. bool ignoreLocalPath = false,
  122. bool throwOnError = false);
  123. template<typename InputIterator>
  124. void setMetadataInfo
  125. (InputIterator first, InputIterator last, const SharedHandle<MetadataInfo>& mi)
  126. {
  127. for(; first != last; ++first) {
  128. (*first)->setMetadataInfo(mi);
  129. }
  130. }
  131. SharedHandle<MetadataInfo>
  132. createMetadataInfoFromFirstFileEntry(const SharedHandle<DownloadContext>& dctx);
  133. // Removes option value which is only effective at the first
  134. // construction time.
  135. void removeOneshotOption(const SharedHandle<Option>& option);
  136. } // namespace aria2
  137. #endif // D_DOWNLOAD_HELPER_H