usage_text.h 80 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061
  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. // clang-format off
  36. #define TEXT_DIR \
  37. _(" -d, --dir=DIR The directory to store the downloaded file.")
  38. #define TEXT_OUT \
  39. _(" -o, --out=FILE The file name of the downloaded file. When \n" \
  40. " the -Z option is used, this option will be \n" \
  41. " ignored.")
  42. #define TEXT_LOG \
  43. _(" -l, --log=LOG The file name of the log file. If '-' is\n" \
  44. " specified, log is written to stdout.")
  45. #define TEXT_DAEMON \
  46. _(" -D, --daemon[=true|false] Run as daemon. The current working directory will\n" \
  47. " be changed to \"/\" and standard input, standard\n" \
  48. " output and standard error will be redirected to\n" \
  49. " \"/dev/null\".")
  50. #define TEXT_SPLIT \
  51. _(" -s, --split=N Download a file using N connections. If more\n" \
  52. " than N URIs are given, first N URIs are used and\n" \
  53. " remaining URLs are used for backup. If less than\n" \
  54. " N URIs are given, those URLs are used more than\n" \
  55. " once so that N connections total are made\n" \
  56. " simultaneously. The number of connections to the\n" \
  57. " same host is restricted by the \n" \
  58. " --max-connection-per-server option. See also the\n" \
  59. " --min-split-size option.")
  60. #define TEXT_RETRY_WAIT \
  61. _(" --retry-wait=SEC Set the seconds to wait between retries. \n" \
  62. " With SEC > 0, aria2 will retry download when the\n" \
  63. " HTTP server returns 503 response.")
  64. #define TEXT_TIMEOUT \
  65. _(" -t, --timeout=SEC Set timeout in seconds.")
  66. #define TEXT_MAX_TRIES \
  67. _(" -m, --max-tries=N Set number of tries. 0 means unlimited.")
  68. #define TEXT_HTTP_PROXY \
  69. _(" --http-proxy=PROXY Use a proxy server for HTTP. To override a\n"\
  70. " previously defined proxy, use \"\".\n" \
  71. " See also the --all-proxy option.\n" \
  72. " This affects all http downloads.")
  73. #define TEXT_HTTPS_PROXY \
  74. _(" --https-proxy=PROXY Use a proxy server for HTTPS. To override a \n" \
  75. " previously defined proxy, use \"\".\n" \
  76. " See also the --all-proxy option.\n" \
  77. " This affects all https downloads.")
  78. #define TEXT_FTP_PROXY \
  79. _(" --ftp-proxy=PROXY Use a proxy server for FTP. To override a \n" \
  80. " previously defined proxy, use \"\".\n" \
  81. " See also the --all-proxy option.\n" \
  82. " This affects all ftp downloads.")
  83. #define TEXT_ALL_PROXY \
  84. _(" --all-proxy=PROXY Use a proxy server for all protocols. To override\n" \
  85. " a previously defined proxy, use \"\".\n" \
  86. " You also can override this setting and specify a\n" \
  87. " proxy server for a particular protocol using the\n" \
  88. " --http-proxy, --https-proxy and --ftp-proxy\n" \
  89. " options.\n" \
  90. " This affects all downloads.")
  91. #define TEXT_HTTP_USER \
  92. _(" --http-user=USER Set HTTP user. This affects all URLs.")
  93. #define TEXT_HTTP_PASSWD \
  94. _(" --http-passwd=PASSWD Set HTTP password. This affects all URLs.")
  95. #define TEXT_PROXY_METHOD \
  96. _(" --proxy-method=METHOD Set the method to use in proxy request.")
  97. #define TEXT_REFERER \
  98. _(" --referer=REFERER Set an http referrrer (Referer). This affects\n" \
  99. " all http/https downloads. If \"*\" is given,\n" \
  100. " the download URI is also used as the referrer.\n" \
  101. " This may be useful when used together with\n" \
  102. " the -P option.")
  103. #define TEXT_FTP_USER \
  104. _(" --ftp-user=USER Set FTP user. This affects all URLs.")
  105. #define TEXT_FTP_PASSWD \
  106. _(" --ftp-passwd=PASSWD Set FTP password. This affects all URLs.")
  107. #define TEXT_FTP_TYPE \
  108. _(" --ftp-type=TYPE Set FTP transfer type.")
  109. #define TEXT_FTP_PASV \
  110. _(" -p, --ftp-pasv[=true|false] Use the passive mode in FTP. If false is given,\n" \
  111. " the active mode will be used.")
  112. #define TEXT_LOWEST_SPEED_LIMIT \
  113. _(" --lowest-speed-limit=SPEED Close connection if download speed is lower than\n" \
  114. " or equal to this value(bytes per sec).\n" \
  115. " 0 means aria2 does not have a lowest speed limit.\n" \
  116. " You can append K or M(1K = 1024, 1M = 1024K).\n" \
  117. " This option does not affect BitTorrent downloads.")
  118. #define TEXT_MAX_OVERALL_DOWNLOAD_LIMIT \
  119. _(" --max-overall-download-limit=SPEED Set max overall download speed in bytes/sec.\n" \
  120. " 0 means unrestricted.\n" \
  121. " You can append K or M(1K = 1024, 1M = 1024K).\n" \
  122. " To limit the download speed per download, use\n" \
  123. " --max-download-limit option.")
  124. #define TEXT_MAX_DOWNLOAD_LIMIT \
  125. _(" --max-download-limit=SPEED Set max download speed per each download in\n" \
  126. " bytes/sec. 0 means unrestricted.\n" \
  127. " You can append K or M(1K = 1024, 1M = 1024K).\n" \
  128. " To limit the overall download speed, use\n" \
  129. " --max-overall-download-limit option.")
  130. #define TEXT_FILE_ALLOCATION \
  131. _(" --file-allocation=METHOD Specify file allocation method.\n" \
  132. " 'none' doesn't pre-allocate file space. 'prealloc'\n" \
  133. " pre-allocates file space before download begins.\n" \
  134. " This may take some time depending on the size of\n" \
  135. " the file.\n" \
  136. " If you are using newer file systems such as ext4\n" \
  137. " (with extents support), btrfs, xfs or NTFS\n" \
  138. " (MinGW build only), 'falloc' is your best\n" \
  139. " choice. It allocates large(few GiB) files\n" \
  140. " almost instantly. Don't use 'falloc' with legacy\n" \
  141. " file systems such as ext3 and FAT32 because it\n" \
  142. " takes almost same time as 'prealloc' and it\n" \
  143. " blocks aria2 entirely until allocation finishes.\n" \
  144. " 'falloc' may not be available if your system\n" \
  145. " doesn't have posix_fallocate() function.\n" \
  146. " 'trunc' uses ftruncate() system call or\n" \
  147. " platform-specific counterpart to truncate a file\n" \
  148. " to a specified length.")
  149. #define TEXT_NO_FILE_ALLOCATION_LIMIT \
  150. _(" --no-file-allocation-limit=SIZE No file allocation is made for files whose\n" \
  151. " size is smaller than SIZE.\n" \
  152. " You can append K or M(1K = 1024, 1M = 1024K).")
  153. #define TEXT_ENABLE_DIRECT_IO \
  154. _(" --enable-direct-io[=true|false] Enable directI/O, which lowers cpu usage while\n" \
  155. " allocating files.\n" \
  156. " Turn off if you encounter any error")
  157. #define TEXT_ALLOW_OVERWRITE \
  158. _(" --allow-overwrite[=true|false] Restart download from scratch if the\n" \
  159. " corresponding control file doesn't exist. See\n" \
  160. " also --auto-file-renaming option.")
  161. #define TEXT_ALLOW_PIECE_LENGTH_CHANGE \
  162. _(" --allow-piece-length-change[=true|false] If false is given, aria2 aborts\n" \
  163. " download when a piece length is different from\n" \
  164. " one in a control file. If true is given, you can\n" \
  165. " proceed but some download progress will be lost.")
  166. #define TEXT_FORCE_SEQUENTIAL \
  167. _(" -Z, --force-sequential[=true|false] Fetch URIs in the command-line sequentially\n" \
  168. " and download each URI in a separate session, like\n" \
  169. " the usual command-line download utilities.")
  170. #define TEXT_AUTO_FILE_RENAMING \
  171. _(" --auto-file-renaming[=true|false] Rename file name if the same file already\n" \
  172. " exists. This option works only in http(s)/ftp\n" \
  173. " download.\n" \
  174. " The new file name has a dot and a number(1..9999)\n" \
  175. " appended.")
  176. #define TEXT_PARAMETERIZED_URI \
  177. _(" -P, --parameterized-uri[=true|false] Enable parameterized URI support.\n" \
  178. " You can specify set of parts:\n" \
  179. " http://{sv1,sv2,sv3}/foo.iso\n" \
  180. " Also you can specify numeric sequences with step\n" \
  181. " counter:\n" \
  182. " http://host/image[000-100:2].img\n" \
  183. " A step counter can be omitted.\n" \
  184. " If all URIs do not point to the same file, such\n" \
  185. " as the second example above, -Z option is\n" \
  186. " required.")
  187. #define TEXT_ENABLE_HTTP_KEEP_ALIVE \
  188. _(" --enable-http-keep-alive[=true|false] Enable HTTP/1.1 persistent connection.")
  189. #define TEXT_ENABLE_HTTP_PIPELINING \
  190. _(" --enable-http-pipelining[=true|false] Enable HTTP/1.1 pipelining.")
  191. #define TEXT_CHECK_INTEGRITY \
  192. _(" -V, --check-integrity[=true|false] Check file integrity by validating piece\n" \
  193. " hashes or a hash of entire file. This option has\n" \
  194. " effect only in BitTorrent, Metalink downloads\n" \
  195. " with checksums or HTTP(S)/FTP downloads with\n" \
  196. " --checksum option. If piece hashes are provided,\n" \
  197. " this option can detect damaged portions of a file\n" \
  198. " and re-download them. If a hash of entire file is\n" \
  199. " provided, hash check is only done when file has\n" \
  200. " been already download. This is determined by file\n" \
  201. " length. If hash check fails, file is\n" \
  202. " re-downloaded from scratch. If both piece hashes\n" \
  203. " and a hash of entire file are provided, only\n" \
  204. " piece hashes are used.")
  205. #define TEXT_BT_HASH_CHECK_SEED \
  206. _(" --bt-hash-check-seed[=true|false] If true is given, after hash check using\n" \
  207. " --check-integrity option and file is complete,\n" \
  208. " continue to seed file. If you want to check file\n" \
  209. " and download it only when it is damaged or\n" \
  210. " incomplete, set this option to false.\n" \
  211. " This option has effect only on BitTorrent\n" \
  212. " download.")
  213. #define TEXT_REALTIME_CHUNK_CHECKSUM \
  214. _(" --realtime-chunk-checksum[=true|false] Validate chunk of data by calculating\n" \
  215. " checksum while downloading a file if chunk\n" \
  216. " checksums are provided.")
  217. #define TEXT_CONTINUE \
  218. _(" -c, --continue[=true|false] Continue downloading a partially downloaded\n" \
  219. " file. Use this option to resume a download\n" \
  220. " started by a web browser or another program\n" \
  221. " which downloads files sequentially from the\n" \
  222. " beginning. Currently this option is only\n" \
  223. " applicable to http(s)/ftp downloads.")
  224. #define TEXT_USER_AGENT \
  225. _(" -U, --user-agent=USER_AGENT Set user agent for http(s) downloads.")
  226. #define TEXT_NO_NETRC \
  227. _(" -n, --no-netrc[=true|false] Disables netrc support.")
  228. #define TEXT_NETRC_PATH \
  229. _(" --netrc-path=FILE Specify the path to the netrc file.")
  230. #define TEXT_INPUT_FILE \
  231. _(" -i, --input-file=FILE Downloads URIs found in FILE. You can specify\n" \
  232. " multiple URIs for a single entity: separate\n" \
  233. " URIs on a single line using the TAB character.\n" \
  234. " Reads input from stdin when '-' is specified.\n" \
  235. " Additionally, options can be specified after each\n" \
  236. " line of URI. This optional line must start with\n" \
  237. " one or more white spaces and have one option per\n" \
  238. " single line. See INPUT FILE section of man page\n" \
  239. " for details. See also --deferred-input option.")
  240. #define TEXT_MAX_CONCURRENT_DOWNLOADS \
  241. _(" -j, --max-concurrent-downloads=N Set maximum number of parallel downloads for\n" \
  242. " every static (HTTP/FTP) URL, torrent and metalink.\n" \
  243. " See also --split option.")
  244. #define TEXT_LOAD_COOKIES \
  245. _(" --load-cookies=FILE Load Cookies from FILE using the Firefox3 format\n" \
  246. " and Mozilla/Firefox(1.x/2.x)/Netscape format.")
  247. #define TEXT_SAVE_COOKIES \
  248. _(" --save-cookies=FILE Save Cookies to FILE in Mozilla/Firefox(1.x/2.x)/\n" \
  249. " Netscape format. If FILE already exists, it is\n" \
  250. " overwritten. Session Cookies are also saved and\n" \
  251. " their expiry values are treated as 0.")
  252. #define TEXT_SHOW_FILES \
  253. _(" -S, --show-files[=true|false] Print file listing of .torrent, .meta4 and\n" \
  254. " .metalink file and exit. More detailed\n" \
  255. " information will be listed in case of torrent\n" \
  256. " file.")
  257. #define TEXT_SELECT_FILE \
  258. _(" --select-file=INDEX... Set file to download by specifying its index.\n" \
  259. " You can find the file index using the\n" \
  260. " --show-files option. Multiple indexes can be\n" \
  261. " specified by using ',', for example: \"3,6\".\n" \
  262. " You can also use '-' to specify a range: \"1-5\".\n" \
  263. " ',' and '-' can be used together.\n" \
  264. " When used with the -M option, index may vary\n" \
  265. " depending on the query(see --metalink-* options).")
  266. #define TEXT_TORRENT_FILE \
  267. _(" -T, --torrent-file=TORRENT_FILE The path to the .torrent file.")
  268. #define TEXT_FOLLOW_TORRENT \
  269. _(" --follow-torrent=true|false|mem If true or mem is specified, when a file\n" \
  270. " whose suffix is .torrent or content type is\n" \
  271. " application/x-bittorrent is downloaded, aria2\n" \
  272. " parses it as a torrent file and downloads files\n" \
  273. " mentioned in it.\n" \
  274. " If mem is specified, a torrent file is not\n" \
  275. " written to the disk, but is just kept in memory.\n" \
  276. " If false is specified, the .torrent file is\n" \
  277. " downloaded to the disk, but is not parsed as a\n" \
  278. " torrent and its contents are not downloaded.")
  279. #define TEXT_LISTEN_PORT \
  280. _(" --listen-port=PORT... Set TCP port number for BitTorrent downloads.\n" \
  281. " Multiple ports can be specified by using ',',\n" \
  282. " for example: \"6881,6885\". You can also use '-'\n" \
  283. " to specify a range: \"6881-6999\". ',' and '-' can\n" \
  284. " be used together.")
  285. #define TEXT_MAX_OVERALL_UPLOAD_LIMIT \
  286. _(" --max-overall-upload-limit=SPEED Set max overall upload speed in bytes/sec.\n" \
  287. " 0 means unrestricted.\n" \
  288. " You can append K or M(1K = 1024, 1M = 1024K).\n" \
  289. " To limit the upload speed per torrent, use\n" \
  290. " --max-upload-limit option.")
  291. #define TEXT_MAX_UPLOAD_LIMIT \
  292. _(" -u, --max-upload-limit=SPEED Set max upload speed per each torrent in\n" \
  293. " bytes/sec. 0 means unrestricted.\n" \
  294. " You can append K or M(1K = 1024, 1M = 1024K).\n" \
  295. " To limit the overall upload speed, use\n" \
  296. " --max-overall-upload-limit option.")
  297. #define TEXT_SEED_TIME \
  298. _(" --seed-time=MINUTES Specify seeding time in minutes. Also see the\n" \
  299. " --seed-ratio option.")
  300. #define TEXT_SEED_RATIO \
  301. _(" --seed-ratio=RATIO Specify share ratio. Seed completed torrents\n" \
  302. " until share ratio reaches RATIO.\n" \
  303. " You are strongly encouraged to specify equals or\n" \
  304. " more than 1.0 here. Specify 0.0 if you intend to\n" \
  305. " do seeding regardless of share ratio.\n" \
  306. " If --seed-time option is specified along with\n" \
  307. " this option, seeding ends when at least one of\n" \
  308. " the conditions is satisfied.")
  309. #define TEXT_PEER_ID_PREFIX \
  310. _(" --peer-id-prefix=PEER_ID_PREFIX Specify the prefix of peer ID. The peer ID in\n" \
  311. " BitTorrent is 20 byte length. If more than 20\n" \
  312. " bytes are specified, only first 20 bytes are\n" \
  313. " used. If less than 20 bytes are specified, random\n" \
  314. " byte data are added to make its length 20 bytes.")
  315. #define TEXT_ENABLE_PEER_EXCHANGE \
  316. _(" --enable-peer-exchange[=true|false] Enable Peer Exchange extension.")
  317. #define TEXT_ENABLE_DHT \
  318. _(" --enable-dht[=true|false] Enable IPv4 DHT functionality. It also enables\n" \
  319. " UDP tracker support. If a private flag is set\n" \
  320. " in a torrent, aria2 doesn't use DHT for that\n" \
  321. " download even if ``true`` is given.")
  322. #define TEXT_DHT_LISTEN_PORT \
  323. _(" --dht-listen-port=PORT... Set UDP listening port used by DHT(IPv4, IPv6)\n" \
  324. " and UDP tracker. Multiple ports can be specified\n" \
  325. " by using ',', for example: \"6881,6885\". You can\n" \
  326. " also use '-' to specify a range: \"6881-6999\".\n" \
  327. " ',' and '-' can be used together.")
  328. #define TEXT_DHT_ENTRY_POINT \
  329. _(" --dht-entry-point=HOST:PORT Set host and port as an entry point to IPv4 DHT\n" \
  330. " network.")
  331. #define TEXT_DHT_FILE_PATH \
  332. _(" --dht-file-path=PATH Change the IPv4 DHT routing table file to PATH.")
  333. #define TEXT_BT_MIN_CRYPTO_LEVEL \
  334. _(" --bt-min-crypto-level=plain|arc4 Set minimum level of encryption method.\n" \
  335. " If several encryption methods are provided by a\n" \
  336. " peer, aria2 chooses the lowest one which satisfies\n" \
  337. " the given level.")
  338. #define TEXT_BT_REQUIRE_CRYPTO \
  339. _(" --bt-require-crypto[=true|false] If true is given, aria2 doesn't accept and\n" \
  340. " establish connection with legacy BitTorrent\n" \
  341. " handshake. Thus aria2 always uses Obfuscation\n" \
  342. " handshake.")
  343. #define TEXT_BT_REQUEST_PEER_SPEED_LIMIT \
  344. _(" --bt-request-peer-speed-limit=SPEED If the whole download speed of every\n" \
  345. " torrent is lower than SPEED, aria2 temporarily\n" \
  346. " increases the number of peers to try for more\n" \
  347. " download speed. Configuring this option with your\n" \
  348. " preferred download speed can increase your\n" \
  349. " download speed in some cases.\n" \
  350. " You can append K or M(1K = 1024, 1M = 1024K).")
  351. #define TEXT_BT_MAX_OPEN_FILES \
  352. _(" --bt-max-open-files=NUM Specify maximum number of files to open in\n" \
  353. " multi-file BitTorrent/Metalink downloads\n" \
  354. " globally.")
  355. #define TEXT_BT_SEED_UNVERIFIED \
  356. _(" --bt-seed-unverified[=true|false] Seed previously downloaded files without\n" \
  357. " verifying piece hashes.")
  358. #define TEXT_BT_MAX_PEERS \
  359. _(" --bt-max-peers=NUM Specify the maximum number of peers per torrent.\n" \
  360. " 0 means unlimited.\n" \
  361. " See also --bt-request-peer-speed-limit option.")
  362. #define TEXT_METALINK_FILE \
  363. _(" -M, --metalink-file=METALINK_FILE The file path to the .meta4 and .metalink\n" \
  364. " file. Reads input from stdin when '-' is\n" \
  365. " specified.")
  366. #define TEXT_METALINK_SERVERS \
  367. _(" -C, --metalink-servers=NUM_SERVERS The number of servers to connect to\n" \
  368. " simultaneously. Some Metalinks regulate the\n" \
  369. " number of servers to connect. aria2 strictly\n" \
  370. " respects them. This means that if Metalink defines\n" \
  371. " the maxconnections attribute lower than\n" \
  372. " NUM_SERVERS, then aria2 uses the value of\n" \
  373. " maxconnections attribute instead of NUM_SERVERS.\n" \
  374. " See also -s and -j options.")
  375. #define TEXT_METALINK_VERSION \
  376. _(" --metalink-version=VERSION The version of the file to download.")
  377. #define TEXT_METALINK_LANGUAGE \
  378. _(" --metalink-language=LANGUAGE The language of the file to download.")
  379. #define TEXT_METALINK_OS \
  380. _(" --metalink-os=OS The operating system of the file to download.")
  381. #define TEXT_METALINK_LOCATION \
  382. _(" --metalink-location=LOCATION[,...] The location of the preferred server.\n" \
  383. " A comma-delimited list of locations is\n" \
  384. " acceptable.")
  385. #define TEXT_METALINK_PREFERRED_PROTOCOL \
  386. _(" --metalink-preferred-protocol=PROTO Specify preferred protocol. Specify 'none'\n" \
  387. " if you don't have any preferred protocol.")
  388. #define TEXT_FOLLOW_METALINK \
  389. _(" --follow-metalink=true|false|mem If true or mem is specified, when a file\n" \
  390. " whose suffix is .meta4 or .metalink, or content\n" \
  391. " type of application/metalink4+xml or\n" \
  392. " application/metalink+xml is downloaded, aria2\n" \
  393. " parses it as a metalink file and downloads files\n" \
  394. " mentioned in it.\n" \
  395. " If mem is specified, a metalink file is not\n" \
  396. " written to the disk, but is just kept in memory.\n" \
  397. " If false is specified, the .metalink file is\n" \
  398. " downloaded to the disk, but is not parsed as a\n" \
  399. " metalink file and its contents are not\n" \
  400. " downloaded.")
  401. #define TEXT_METALINK_ENABLE_UNIQUE_PROTOCOL \
  402. _(" --metalink-enable-unique-protocol[=true|false] If true is given and several\n" \
  403. " protocols are available for a mirror in a metalink\n" \
  404. " file, aria2 uses one of them.\n" \
  405. " Use --metalink-preferred-protocol option to\n" \
  406. " specify the preference of protocol.")
  407. #define TEXT_VERSION \
  408. _(" -v, --version Print the version number and exit.")
  409. #define TEXT_HELP \
  410. _(" -h, --help[=TAG|KEYWORD] Print usage and exit.\n" \
  411. " The help messages are classified with tags. A tag\n" \
  412. " starts with \"#\". For example, type \"--help=#http\"\n" \
  413. " to get the usage for the options tagged with\n" \
  414. " \"#http\". If non-tag word is given, print the usage\n" \
  415. " for the options whose name includes that word.")
  416. #define TEXT_NO_CONF \
  417. _(" --no-conf[=true|false] Disable loading aria2.conf file.")
  418. #define TEXT_CONF_PATH \
  419. _(" --conf-path=PATH Change the configuration file path to PATH.")
  420. #define TEXT_STOP \
  421. _(" --stop=SEC Stop application after SEC seconds has passed.\n" \
  422. " If 0 is given, this feature is disabled.")
  423. #define TEXT_HEADER \
  424. _(" --header=HEADER Append HEADER to HTTP request header. You can use\n" \
  425. " this option repeatedly to specify more than one\n" \
  426. " header:\n" \
  427. " aria2c --header=\"X-A: b78\" --header=\"X-B: 9J1\"\n" \
  428. " http://host/file")
  429. #define TEXT_QUIET \
  430. _(" -q, --quiet[=true|false] Make aria2 quiet(no console output).")
  431. #define TEXT_ASYNC_DNS \
  432. _(" --async-dns[=true|false] Enable asynchronous DNS.")
  433. #define TEXT_FTP_REUSE_CONNECTION \
  434. _(" --ftp-reuse-connection[=true|false] Reuse connection in FTP.")
  435. #define TEXT_SUMMARY_INTERVAL \
  436. _(" --summary-interval=SEC Set interval to output download progress summary.\n" \
  437. " Setting 0 suppresses the output.")
  438. #define TEXT_LOG_LEVEL \
  439. _(" --log-level=LEVEL Set log level to output to file specified using\n" \
  440. " --log option.")
  441. #define TEXT_REMOTE_TIME \
  442. _(" -R, --remote-time[=true|false] Retrieve timestamp of the remote file from the\n" \
  443. " remote HTTP/FTP server and if it is available,\n" \
  444. " apply it to the local file.")
  445. #define TEXT_CONNECT_TIMEOUT \
  446. _(" --connect-timeout=SEC Set the connect timeout in seconds to establish\n" \
  447. " connection to HTTP/FTP/proxy server. After the\n" \
  448. " connection is established, this option makes no\n" \
  449. " effect and --timeout option is used instead.")
  450. #define TEXT_MAX_FILE_NOT_FOUND \
  451. _(" --max-file-not-found=NUM If aria2 receives `file not found' status from the\n" \
  452. " remote HTTP/FTP servers NUM times without getting\n" \
  453. " a single byte, then force the download to fail.\n" \
  454. " Specify 0 to disable this option.\n" \
  455. " This options is effective only when using\n" \
  456. " HTTP/FTP servers. The number of retry attempt is\n" \
  457. " counted toward --max-tries, so it should be\n" \
  458. " configured too.")
  459. #define TEXT_URI_SELECTOR \
  460. _(" --uri-selector=SELECTOR Specify URI selection algorithm.\n" \
  461. " If 'inorder' is given, URI is tried in the order\n" \
  462. " appeared in the URI list.\n" \
  463. " If 'feedback' is given, aria2 uses download speed\n" \
  464. " observed in the previous downloads and choose\n" \
  465. " fastest server in the URI list. This also\n" \
  466. " effectively skips dead mirrors. The observed\n" \
  467. " download speed is a part of performance profile\n" \
  468. " of servers mentioned in --server-stat-of and\n" \
  469. " --server-stat-if options.\n" \
  470. " If 'adaptive' is given, selects one of the best\n" \
  471. " mirrors for the first and reserved connections.\n" \
  472. " For supplementary ones, it returns mirrors which\n" \
  473. " has not been tested yet, and if each of them has\n" \
  474. " already been tested, returns mirrors which has to\n" \
  475. " be tested again. Otherwise, it doesn't select\n" \
  476. " anymore mirrors. Like 'feedback', it uses a\n" \
  477. " performance profile of servers.")
  478. #define TEXT_SERVER_STAT_OF \
  479. _(" --server-stat-of=FILE Specify the filename to which performance profile\n" \
  480. " of the servers is saved. You can load saved data\n" \
  481. " using --server-stat-if option.")
  482. #define TEXT_SERVER_STAT_IF \
  483. _(" --server-stat-if=FILE Specify the filename to load performance profile\n" \
  484. " of the servers. The loaded data will be used in\n" \
  485. " some URI selector such as 'feedback'.\n" \
  486. " See also --uri-selector option")
  487. #define TEXT_SERVER_STAT_TIMEOUT \
  488. _(" --server-stat-timeout=SEC Specifies timeout in seconds to invalidate\n" \
  489. " performance profile of the servers since the last\n" \
  490. " contact to them.")
  491. #define TEXT_AUTO_SAVE_INTERVAL \
  492. _(" --auto-save-interval=SEC Save a control file(*.aria2) every SEC seconds.\n" \
  493. " If 0 is given, a control file is not saved during\n" \
  494. " download. aria2 saves a control file when it stops\n" \
  495. " regardless of the value.")
  496. #define TEXT_CERTIFICATE \
  497. _(" --certificate=FILE Use the client certificate in FILE.\n" \
  498. " The certificate must be in PEM format.\n" \
  499. " You may use --private-key option to specify the\n" \
  500. " private key.")
  501. #define TEXT_PRIVATE_KEY \
  502. _(" --private-key=FILE Use the private key in FILE.\n" \
  503. " The private key must be decrypted and in PEM\n" \
  504. " format. See also --certificate option.")
  505. #define TEXT_CA_CERTIFICATE \
  506. _(" --ca-certificate=FILE Use the certificate authorities in FILE to verify\n" \
  507. " the peers. The certificate file must be in PEM\n" \
  508. " format and can contain multiple CA certificates.\n" \
  509. " Use --check-certificate option to enable\n" \
  510. " verification.")
  511. #define TEXT_CHECK_CERTIFICATE \
  512. _(" --check-certificate[=true|false] Verify the peer using certificates specified\n" \
  513. " in --ca-certificate option.")
  514. #define TEXT_NO_PROXY \
  515. _(" --no-proxy=DOMAINS Specify comma separated hostnames, domains or\n" \
  516. " network address with or without CIDR block where\n" \
  517. " proxy should not be used.")
  518. #define TEXT_USE_HEAD \
  519. _(" --use-head[=true|false] Use HEAD method for the first request to the HTTP\n" \
  520. " server.")
  521. #define TEXT_EVENT_POLL \
  522. _(" --event-poll=POLL Specify the method for polling events.")
  523. #define TEXT_BT_EXTERNAL_IP \
  524. _(" --bt-external-ip=IPADDRESS Specify the external IP address to report to a\n" \
  525. " BitTorrent tracker. Although this function is\n" \
  526. " named 'external', it can accept any kind of IP\n" \
  527. " addresses.")
  528. #define TEXT_HTTP_AUTH_CHALLENGE \
  529. _(" --http-auth-challenge[=true|false] Send HTTP authorization header only when it\n" \
  530. " is requested by the server. If false is set, then\n" \
  531. " authorization header is always sent to the server.\n" \
  532. " There is an exception: if username and password\n" \
  533. " are embedded in URI, authorization header is\n" \
  534. " always sent to the server regardless of this\n" \
  535. " option.")
  536. #define TEXT_INDEX_OUT \
  537. _(" -O, --index-out=INDEX=PATH Set file path for file with index=INDEX. You can\n" \
  538. " find the file index using the --show-files option.\n" \
  539. " PATH is a relative path to the path specified in\n" \
  540. " --dir option. You can use this option multiple\n" \
  541. " times.")
  542. #define TEXT_DRY_RUN \
  543. _(" --dry-run[=true|false] If true is given, aria2 just checks whether the\n" \
  544. " remote file is available and doesn't download\n" \
  545. " data. This option has effect on HTTP/FTP download.\n" \
  546. " BitTorrent downloads are canceled if true is\n" \
  547. " specified.")
  548. #define TEXT_BT_TRACKER_INTERVAL \
  549. _(" --bt-tracker-interval=SEC Set the interval in seconds between tracker\n" \
  550. " requests. This completely overrides interval value\n" \
  551. " and aria2 just uses this value and ignores the\n" \
  552. " min interval and interval value in the response of\n" \
  553. " tracker. If 0 is set, aria2 determines interval\n" \
  554. " based on the response of tracker and the download\n" \
  555. " progress.")
  556. #define TEXT_ON_DOWNLOAD_COMPLETE \
  557. _(" --on-download-complete=COMMAND Set the command to be executed after download\n" \
  558. " completed.\n" \
  559. " See --on-download-start option for the\n" \
  560. " requirement of COMMAND.\n" \
  561. " See also --on-download-stop option.")
  562. #define TEXT_ON_DOWNLOAD_START \
  563. _(" --on-download-start=COMMAND Set the command to be executed after download\n" \
  564. " got started. aria2 passes 3 arguments to COMMAND:\n" \
  565. " GID, the nubmer of files and file path. See Event\n" \
  566. " Hook in man page for more details.")
  567. #define TEXT_ON_DOWNLOAD_PAUSE \
  568. _(" --on-download-pause=COMMAND Set the command to be executed after download\n" \
  569. " was paused.\n"\
  570. " See --on-download-start option for the\n" \
  571. " requirement of COMMAND.")
  572. #define TEXT_ON_DOWNLOAD_ERROR \
  573. _(" --on-download-error=COMMAND Set the command to be executed after download\n" \
  574. " aborted due to error.\n" \
  575. " See --on-download-start option for the\n" \
  576. " requirement of COMMAND.\n" \
  577. " See also --on-download-stop option.")
  578. #define TEXT_ON_DOWNLOAD_STOP \
  579. _(" --on-download-stop=COMMAND Set the command to be executed after download\n" \
  580. " stopped. You can override the command to be\n" \
  581. " executed for particular download result using\n" \
  582. " --on-download-complete and --on-download-error. If\n" \
  583. " they are specified, command specified in this\n" \
  584. " option is not executed.\n" \
  585. " See --on-download-start option for the\n" \
  586. " requirement of COMMAND.")
  587. #define TEXT_BT_STOP_TIMEOUT \
  588. _(" --bt-stop-timeout=SEC Stop BitTorrent download if download speed is 0 in\n" \
  589. " consecutive SEC seconds. If 0 is given, this\n" \
  590. " feature is disabled.")
  591. #define TEXT_BT_PRIORITIZE_PIECE \
  592. _(" --bt-prioritize-piece=head[=SIZE],tail[=SIZE] Try to download first and last\n" \
  593. " pieces of each file first. This is useful for\n" \
  594. " previewing files. The argument can contain 2\n" \
  595. " keywords:head and tail. To include both keywords,\n" \
  596. " they must be separated by comma. These keywords\n" \
  597. " can take one parameter, SIZE. For example, if\n" \
  598. " head=SIZE is specified, pieces in the range of\n" \
  599. " first SIZE bytes of each file get higher priority.\n" \
  600. " tail=SIZE means the range of last SIZE bytes of\n" \
  601. " each file. SIZE can include K or M(1K = 1024, 1M =\n" \
  602. " 1024K). If SIZE is omitted, SIZE=1M is used.")
  603. #define TEXT_INTERFACE \
  604. _(" --interface=INTERFACE Bind sockets to given interface. You can specify\n" \
  605. " interface name, IP address and hostname.")
  606. #define TEXT_MULTIPLE_INTERFACE \
  607. _(" --multiple-interface=INTERFACES Comma separated list of interfaces to bind\n" \
  608. " sockets to. Requests will be splited among the\n" \
  609. " interfaces to achieve link aggregation. You can\n" \
  610. " specify interface name, IP address and hostname.\n" \
  611. " If --interface is used, this option will be\n" \
  612. " ignored.")
  613. #define TEXT_DISABLE_IPV6 \
  614. _(" --disable-ipv6[=true|false] Disable IPv6.")
  615. #define TEXT_BT_SAVE_METADATA \
  616. _(" --bt-save-metadata[=true|false] Save metadata as .torrent file. This option has\n" \
  617. " effect only when BitTorrent Magnet URI is used.\n" \
  618. " The filename is hex encoded info hash with suffix\n" \
  619. " .torrent. The directory to be saved is the same\n" \
  620. " directory where download file is saved. If the\n" \
  621. " same file already exists, metadata is not saved.\n" \
  622. " See also --bt-metadata-only option.")
  623. #define TEXT_HTTP_NO_CACHE \
  624. _(" --http-no-cache[=true|false] Send Cache-Control: no-cache and Pragma: no-cache\n" \
  625. " header to avoid cached content. If false is\n" \
  626. " given, these headers are not sent and you can add\n" \
  627. " Cache-Control header with a directive you like\n" \
  628. " using --header option.")
  629. #define TEXT_BT_METADATA_ONLY \
  630. _(" --bt-metadata-only[=true|false] Download metadata only. The file(s) described\n" \
  631. " in metadata will not be downloaded. This option\n" \
  632. " has effect only when BitTorrent Magnet URI is\n" \
  633. " used. See also --bt-save-metadata option.")
  634. #define TEXT_HUMAN_READABLE \
  635. _(" --human-readable[=true|false] Print sizes and speed in human readable format\n" \
  636. " (e.g., 1.2Ki, 3.4Mi) in the console readout.")
  637. #define TEXT_BT_ENABLE_LPD \
  638. _(" --bt-enable-lpd[=true|false] Enable Local Peer Discovery.")
  639. #define TEXT_BT_LPD_INTERFACE \
  640. _(" --bt-lpd-interface=INTERFACE Use given interface for Local Peer Discovery. If\n" \
  641. " this option is not specified, the default\n" \
  642. " interface is chosen. You can specify interface\n" \
  643. " name and IP address.")
  644. #define TEXT_REUSE_URI \
  645. _(" --reuse-uri[=true|false] Reuse already used URIs if no unused URIs are\n" \
  646. " left.")
  647. #define TEXT_ALL_PROXY_USER \
  648. _(" --all-proxy-user=USER Set user for --all-proxy.")
  649. #define TEXT_ALL_PROXY_PASSWD \
  650. _(" --all-proxy-passwd=PASSWD Set password for --all-proxy.")
  651. #define TEXT_HTTP_PROXY_USER \
  652. _(" --http-proxy-user=USER Set user for --http-proxy.")
  653. #define TEXT_HTTP_PROXY_PASSWD \
  654. _(" --http-proxy-passwd=PASSWD Set password for --http-proxy.")
  655. #define TEXT_HTTPS_PROXY_USER \
  656. _(" --https-proxy-user=USER Set user for --https-proxy.")
  657. #define TEXT_HTTPS_PROXY_PASSWD \
  658. _(" --https-proxy-passwd=PASSWD Set password for --https-proxy.")
  659. #define TEXT_FTP_PROXY_USER \
  660. _(" --ftp-proxy-user=USER Set user for --ftp-proxy.")
  661. #define TEXT_FTP_PROXY_PASSWD \
  662. _(" --ftp-proxy-passwd=PASSWD Set password for --ftp-proxy.")
  663. #define TEXT_REMOVE_CONTROL_FILE \
  664. _(" --remove-control-file[=true|false] Remove control file before download. Using\n" \
  665. " with --allow-overwrite=true, download always\n" \
  666. " starts from scratch. This will be useful for\n" \
  667. " users behind proxy server which disables resume.")
  668. #define TEXT_ALWAYS_RESUME \
  669. _(" --always-resume[=true|false] Always resume download. If true is given, aria2\n" \
  670. " always tries to resume download and if resume is\n" \
  671. " not possible, aborts download. If false is given,\n" \
  672. " when all given URIs do not support resume or\n" \
  673. " aria2 encounters N URIs which does not support\n" \
  674. " resume (N is the value specified using\n" \
  675. " --max-resume-failure-tries option), aria2\n" \
  676. " downloads file from scratch.\n" \
  677. " See --max-resume-failure-tries option.")
  678. #define TEXT_MAX_RESUME_FAILURE_TRIES \
  679. _(" --max-resume-failure-tries=N When used with --always-resume=false, aria2\n" \
  680. " downloads file from scratch when aria2 detects N\n" \
  681. " number of URIs that does not support resume. If N\n" \
  682. " is 0, aria2 downloads file from scratch when all\n" \
  683. " given URIs do not support resume.\n" \
  684. " See --always-resume option.")
  685. #define TEXT_BT_TRACKER_TIMEOUT \
  686. _(" --bt-tracker-timeout=SEC Set timeout in seconds.")
  687. #define TEXT_BT_TRACKER_CONNECT_TIMEOUT \
  688. _(" --bt-tracker-connect-timeout=SEC Set the connect timeout in seconds to\n" \
  689. " establish connection to tracker. After the\n" \
  690. " connection is established, this option makes no\n" \
  691. " effect and --bt-tracker-timeout option is used\n" \
  692. " instead.")
  693. #define TEXT_DHT_MESSAGE_TIMEOUT \
  694. _(" --dht-message-timeout=SEC Set timeout in seconds.")
  695. #define TEXT_HTTP_ACCEPT_GZIP \
  696. _(" --http-accept-gzip[=true|false] Send 'Accept: deflate, gzip' request header\n" \
  697. " and inflate response if remote server responds\n" \
  698. " with 'Content-Encoding: gzip' or\n" \
  699. " 'Content-Encoding: deflate'.")
  700. #define TEXT_SAVE_SESSION \
  701. _(" --save-session=FILE Save error/unfinished downloads to FILE on exit.\n" \
  702. " You can pass this output file to aria2c with -i\n" \
  703. " option on restart. Please note that downloads\n" \
  704. " added by aria2.addTorrent and aria2.addMetalink\n" \
  705. " RPC method and whose metadata could not be saved\n" \
  706. " as a file will not be saved. Downloads removed\n" \
  707. " using aria2.remove and aria2.forceRemove will not\n" \
  708. " be saved.")
  709. #define TEXT_MAX_CONNECTION_PER_SERVER \
  710. _(" -x, --max-connection-per-server=NUM The maximum number of connections to one\n" \
  711. " server for each download.")
  712. #define TEXT_MIN_SPLIT_SIZE \
  713. _(" -k, --min-split-size=SIZE aria2 does not split less than 2*SIZE byte range.\n" \
  714. " For example, let's consider downloading 20MiB\n" \
  715. " file. If SIZE is 10M, aria2 can split file into 2\n" \
  716. " range [0-10MiB) and [10MiB-20MiB) and download it\n" \
  717. " using 2 sources(if --split >= 2, of course).\n" \
  718. " If SIZE is 15M, since 2*15M > 20MiB, aria2 does\n" \
  719. " not split file and download it using 1 source.\n" \
  720. " You can append K or M(1K = 1024, 1M = 1024K).")
  721. #define TEXT_CONDITIONAL_GET \
  722. _(" --conditional-get[=true|false] Download file only when the local file is older\n" \
  723. " than remote file. Currently, this function has\n" \
  724. " many limitations. See man page for details.")
  725. #define TEXT_ON_BT_DOWNLOAD_COMPLETE \
  726. _(" --on-bt-download-complete=COMMAND For BitTorrent, a command specified in\n" \
  727. " --on-download-complete is called after download\n" \
  728. " completed and seeding is over. On the other hand,\n" \
  729. " this option sets the command to be executed after\n" \
  730. " download completed but before seeding.\n" \
  731. " See --on-download-start option for the\n" \
  732. " requirement of COMMAND.")
  733. #define TEXT_ENABLE_ASYNC_DNS6 \
  734. _(" --enable-async-dns6[=true|false] Enable IPv6 name resolution in asynchronous\n" \
  735. " DNS resolver. This option will be ignored when\n" \
  736. " --async-dns=false.")
  737. #define TEXT_ENABLE_DHT6 \
  738. _(" --enable-dht6[=true|false] Enable IPv6 DHT functionality.\n" \
  739. " Use --dht-listen-port option to specify port\n" \
  740. " number to listen on. See also --dht-listen-addr6\n" \
  741. " option.")
  742. #define TEXT_DHT_LISTEN_ADDR6 \
  743. _(" --dht-listen-addr6=ADDR Specify address to bind socket for IPv6 DHT. \n" \
  744. " It should be a global unicast IPv6 address of the\n" \
  745. " host.")
  746. #define TEXT_DHT_ENTRY_POINT6 \
  747. _(" --dht-entry-point6=HOST:PORT Set host and port as an entry point to IPv6 DHT\n" \
  748. " network.")
  749. #define TEXT_DHT_FILE_PATH6 \
  750. _(" --dht-file-path6=PATH Change the IPv6 DHT routing table file to PATH.")
  751. #define TEXT_BT_TRACKER \
  752. _(" --bt-tracker=URI[,...] Comma separated list of additional BitTorrent\n" \
  753. " tracker's announce URI. These URIs are not\n" \
  754. " affected by --bt-exclude-tracker option because\n" \
  755. " they are added after URIs in --bt-exclude-tracker\n" \
  756. " option are removed.")
  757. #define TEXT_BT_EXCLUDE_TRACKER \
  758. _(" --bt-exclude-tracker=URI[,...] Comma separated list of BitTorrent tracker's\n" \
  759. " announce URI to remove. You can use special value\n" \
  760. " '*' which matches all URIs, thus removes all\n" \
  761. " announce URIs. When specifying '*' in shell\n" \
  762. " command-line, don't forget to escape or quote it.\n" \
  763. " See also --bt-tracker option.")
  764. #define TEXT_MAX_DOWNLOAD_RESULT \
  765. _(" --max-download-result=NUM Set maximum number of download result kept in\n" \
  766. " memory. The download results are completed/error/\n" \
  767. " removed downloads. The download results are stored\n" \
  768. " in FIFO queue and it can store at most NUM\n" \
  769. " download results. When queue is full and new\n" \
  770. " download result is created, oldest download result\n" \
  771. " is removed from the front of the queue and new one\n" \
  772. " is pushed to the back. Setting big number in this\n" \
  773. " option may result high memory consumption after\n" \
  774. " thousands of downloads. Specifying 0 means no\n" \
  775. " download result is kept.")
  776. #define TEXT_ASYNC_DNS_SERVER \
  777. _(" --async-dns-server=IPADDRESS[,...] Comma separated list of DNS server address\n" \
  778. " used in asynchronous DNS resolver. Usually\n" \
  779. " asynchronous DNS resolver reads DNS server\n" \
  780. " addresses from /etc/resolv.conf. When this option\n" \
  781. " is used, it uses DNS servers specified in this\n" \
  782. " option instead of ones in /etc/resolv.conf. You\n" \
  783. " can specify both IPv4 and IPv6 address. This\n" \
  784. " option is useful when the system does not have\n" \
  785. " /etc/resolv.conf and user does not have the\n" \
  786. " permission to create it.")
  787. #define TEXT_ENABLE_RPC \
  788. _(" --enable-rpc[=true|false] Enable JSON-RPC/XML-RPC server.\n" \
  789. " It is strongly recommended to set secret\n" \
  790. " authorization token using --rpc-secret option.\n" \
  791. " See also --rpc-listen-port option.")
  792. #define TEXT_RPC_MAX_REQUEST_SIZE \
  793. _(" --rpc-max-request-size=SIZE Set max size of JSON-RPC/XML-RPC request. If aria2\n" \
  794. " detects the request is more than SIZE bytes, it\n" \
  795. " drops connection.")
  796. #define TEXT_RPC_USER \
  797. _(" --rpc-user=USER Set JSON-RPC/XML-RPC user. This option will be\n" \
  798. " deprecated in the future release. Migrate to\n" \
  799. " --rpc-secret option as soon as possible.")
  800. #define TEXT_RPC_PASSWD \
  801. _(" --rpc-passwd=PASSWD Set JSON-RPC/XML-RPC password. This option will\n" \
  802. " be deprecated in the future release. Migrate to\n" \
  803. " --rpc-secret option as soon as possible.")
  804. #define TEXT_RPC_LISTEN_ALL \
  805. _(" --rpc-listen-all[=true|false] Listen incoming JSON-RPC/XML-RPC requests on all\n" \
  806. " network interfaces. If false is given, listen only\n" \
  807. " on local loopback interface.")
  808. #define TEXT_RPC_LISTEN_PORT \
  809. _(" --rpc-listen-port=PORT Specify a port number for JSON-RPC/XML-RPC server\n" \
  810. " to listen to.")
  811. #define TEXT_SHOW_CONSOLE_READOUT \
  812. _(" --show-console-readout[=true|false] Show console readout.")
  813. #define TEXT_METALINK_BASE_URI \
  814. _(" --metalink-base-uri=URI Specify base URI to resolve relative URI in\n" \
  815. " metalink:url and metalink:metaurl element in a\n" \
  816. " metalink file stored in local disk. If URI points\n" \
  817. " to a directory, URI must end with '/'.")
  818. #define TEXT_STREAM_PIECE_SELECTOR \
  819. _(" --stream-piece-selector=SELECTOR Specify piece selection algorithm\n" \
  820. " used in HTTP/FTP download. Piece means fixed\n" \
  821. " length segment which is downloaded in parallel\n" \
  822. " in segmented download. If 'default' is given,\n" \
  823. " aria2 selects piece so that it reduces the\n" \
  824. " number of establishing connection. This is\n" \
  825. " reasonable default behaviour because\n" \
  826. " establishing connection is an expensive\n" \
  827. " operation.\n" \
  828. " If 'inorder' is given, aria2 selects piece which\n" \
  829. " has minimum index. Index=0 means first of the\n" \
  830. " file. This will be useful to view movie while\n" \
  831. " downloading it. --enable-http-pipelining option\n" \
  832. " may be useful to reduce reconnection overhead.\n" \
  833. " Please note that aria2 honors\n" \
  834. " --min-split-size option, so it will be necessary\n" \
  835. " to specify a reasonable value to\n" \
  836. " --min-split-size option.\n" \
  837. " If 'geom' is given, at the beginning aria2\n" \
  838. " selects piece which has minimum index like\n" \
  839. " 'inorder', but it exponentially increasingly\n" \
  840. " keeps space from previously selected piece. This\n" \
  841. " will reduce the number of establishing connection\n" \
  842. " and at the same time it will download the\n" \
  843. " beginning part of the file first. This will be\n" \
  844. " useful to view movie while downloading it.")
  845. #define TEXT_TRUNCATE_CONSOLE_READOUT \
  846. _(" --truncate-console-readout[=true|false] Truncate console readout to fit in\n"\
  847. " a single line.")
  848. #define TEXT_PAUSE \
  849. _(" --pause[=true|false] Pause download after added. This option is\n" \
  850. " effective only when --enable-rpc=true is given.")
  851. #define TEXT_RPC_ALLOW_ORIGIN_ALL \
  852. _(" --rpc-allow-origin-all[=true|false] Add Access-Control-Allow-Origin header\n" \
  853. " field with value '*' to the RPC response.")
  854. #define TEXT_DOWNLOAD_RESULT \
  855. _(" --download-result=OPT This option changes the way \"Download Results\"\n" \
  856. " is formatted. If OPT is 'default', print GID,\n" \
  857. " status, average download speed and path/URI. If\n" \
  858. " multiple files are involved, path/URI of first\n" \
  859. " requested file is printed and remaining ones are\n" \
  860. " omitted.\n" \
  861. " If OPT is 'full', print GID, status, average\n" \
  862. " download speed, percentage of progress and\n" \
  863. " path/URI. The percentage of progress and\n" \
  864. " path/URI are printed for each requested file in\n" \
  865. " each row.")
  866. #define TEXT_HASH_CHECK_ONLY \
  867. _(" --hash-check-only[=true|false] If true is given, after hash check using\n" \
  868. " --check-integrity option, abort download whether\n" \
  869. " or not download is complete.")
  870. #define TEXT_CHECKSUM \
  871. _(" --checksum=TYPE=DIGEST Set checksum. TYPE is hash type. The supported\n" \
  872. " hash type is listed in \"Hash Algorithms\" in\n" \
  873. " \"aria2c -v\". DIGEST is hex digest.\n" \
  874. " For example, setting sha-1 digest looks like\n" \
  875. " this:\n" \
  876. " sha-1=0192ba11326fe2298c8cb4de616f4d4140213838\n" \
  877. " This option applies only to HTTP(S)/FTP\n" \
  878. " downloads.")
  879. #define TEXT_PIECE_LENGTH \
  880. _(" --piece-length=LENGTH Set a piece length for HTTP/FTP downloads. This\n" \
  881. " is the boundary when aria2 splits a file. All\n" \
  882. " splits occur at multiple of this length. This\n" \
  883. " option will be ignored in BitTorrent downloads.\n" \
  884. " It will be also ignored if Metalink file\n" \
  885. " contains piece hashes.")
  886. #define TEXT_STOP_WITH_PROCESS \
  887. _(" --stop-with-process=PID Stop application when process PID is not running.\n" \
  888. " This is useful if aria2 process is forked from a\n" \
  889. " parent process. The parent process can fork aria2\n" \
  890. " with its own pid and when parent process exits\n" \
  891. " for some reason, aria2 can detect it and shutdown\n" \
  892. " itself.")
  893. #define TEXT_DEFERRED_INPUT \
  894. _(" --deferred-input[=true|false] If true is given, aria2 does not read all URIs\n" \
  895. " and options from file specified by -i option at\n" \
  896. " startup, but it reads one by one when it needs\n" \
  897. " later. This may reduce memory usage if input\n" \
  898. " file contains a lot of URIs to download.\n" \
  899. " If false is given, aria2 reads all URIs and\n" \
  900. " options at startup.")
  901. #define TEXT_BT_REMOVE_UNSELECTED_FILE \
  902. _(" --bt-remove-unselected-file[=true|false] Removes the unselected files when\n" \
  903. " download is completed in BitTorrent. To\n" \
  904. " select files, use --select-file option. If\n" \
  905. " it is not used, all files are assumed to be\n" \
  906. " selected. Please use this option with care\n" \
  907. " because it will actually remove files from\n" \
  908. " your disk.")
  909. #define TEXT_ENABLE_MMAP \
  910. _(" --enable-mmap[=true|false] Map files into memory.")
  911. #define TEXT_RPC_CERTIFICATE \
  912. _(" --rpc-certificate=FILE Use the certificate in FILE for RPC server.\n" \
  913. " The certificate must be in PEM format.\n" \
  914. " Use --rpc-private-key option to specify the\n" \
  915. " private key. Use --rpc-secure option to enable\n" \
  916. " encryption.")
  917. #define TEXT_RPC_PRIVATE_KEY \
  918. _(" --rpc-private-key=FILE Use the private key in FILE for RPC server.\n" \
  919. " The private key must be decrypted and in PEM\n" \
  920. " format. Use --rpc-secure option to enable\n" \
  921. " encryption. See also --rpc-certificate option.")
  922. #define TEXT_RPC_SECURE \
  923. _(" --rpc-secure[=true|false] RPC transport will be encrypted by SSL/TLS.\n" \
  924. " The RPC clients must use https scheme to access\n" \
  925. " the server. For WebSocket client, use wss\n" \
  926. " scheme. Use --rpc-certificate and\n" \
  927. " --rpc-private-key options to specify the\n" \
  928. " server certificate and private key.")
  929. #define TEXT_RPC_SAVE_UPLOAD_METADATA \
  930. _(" --rpc-save-upload-metadata[=true|false] Save the uploaded torrent or\n" \
  931. " metalink metadata in the directory specified\n" \
  932. " by --dir option. The filename consists of\n" \
  933. " SHA-1 hash hex string of metadata plus\n" \
  934. " extension. For torrent, the extension is\n" \
  935. " '.torrent'. For metalink, it is '.meta4'.\n" \
  936. " If false is given to this option, the\n" \
  937. " downloads added by aria2.addTorrent or\n" \
  938. " aria2.addMetalink will not be saved by\n" \
  939. " --save-session option.")
  940. #define TEXT_FORCE_SAVE \
  941. _(" --force-save[=true|false] Save download with --save-session option even\n" \
  942. " if the download is completed or removed. This\n" \
  943. " option also saves control file in that\n" \
  944. " situations. This may be useful to save\n" \
  945. " BitTorrent seeding which is recognized as\n" \
  946. " completed state.")
  947. #define TEXT_DISK_CACHE \
  948. _(" --disk-cache=SIZE Enable disk cache. If SIZE is 0, the disk cache\n" \
  949. " is disabled. This feature caches the downloaded\n" \
  950. " data in memory, which grows to at most SIZE\n" \
  951. " bytes. The cache storage is created for aria2\n" \
  952. " instance and shared by all downloads. The one\n" \
  953. " advantage of the disk cache is reduce the disk\n" \
  954. " I/O because the data are written in larger unit\n" \
  955. " and it is reordered by the offset of the file.\n" \
  956. " If hash checking is involved and the data are\n" \
  957. " cached in memory, we don't need to read them\n" \
  958. " from the disk.\n" \
  959. " SIZE can include K or M(1K = 1024, 1M = 1024K).")
  960. #define TEXT_GID \
  961. _(" --gid=GID Set GID manually. aria2 identifies each\n" \
  962. " download by the ID called GID. The GID must be\n" \
  963. " hex string of 16 characters, thus [0-9a-zA-Z]\n" \
  964. " are allowed and leading zeros must not be\n" \
  965. " stripped. The GID all 0 is reserved and must\n" \
  966. " not be used. The GID must be unique, otherwise\n" \
  967. " error is reported and the download is not added.\n" \
  968. " This option is useful when restoring the\n" \
  969. " sessions saved using --save-session option. If\n" \
  970. " this option is not used, new GID is generated\n" \
  971. " by aria2.")
  972. #define TEXT_CONSOLE_LOG_LEVEL \
  973. _(" --console-log-level=LEVEL Set log level to output to console.")
  974. #define TEXT_SAVE_SESSION_INTERVAL \
  975. _(" --save-session-interval=SEC Save error/unfinished downloads to a file\n" \
  976. " specified by --save-session option every SEC\n" \
  977. " seconds. If 0 is given, file will be saved only\n" \
  978. " when aria2 exits.")
  979. #define TEXT_ENABLE_COLOR \
  980. _(" --enable-color[=true|false] Enable color output for a terminal.")
  981. #define TEXT_RPC_SECRET \
  982. _(" --rpc-secret=TOKEN Set RPC secret authorization token.")
  983. #define TEXT_DSCP \
  984. _(" --dscp=DSCP Set DSCP value in outgoing IP packets of\n" \
  985. " BitTorrent traffic for QoS. This parameter sets\n" \
  986. " only DSCP bits in TOS field of IP packets,\n" \
  987. " not the whole field. If you take values\n" \
  988. " from /usr/include/netinet/ip.h divide them by 4\n" \
  989. " (otherwise values would be incorrect, e.g. your\n" \
  990. " CS1 class would turn into CS4). If you take\n" \
  991. " commonly used values from RFC, network vendors'\n" \
  992. " documentation, Wikipedia or any other source,\n" \
  993. " use them as they are.")
  994. #define TEXT_RLIMIT_NOFILE \
  995. _(" --rlimit-nofile=NUM Set the soft limit of open file descriptors.\n" \
  996. " This open will only have effect when:\n" \
  997. " a) The system supports it (posix)\n" \
  998. " b) The limit does not exceed the hard limit.\n" \
  999. " c) The specified limit is larger than the\n" \
  1000. " current soft limit.\n" \
  1001. " This is equivalent to setting nofile via ulimit,\n" \
  1002. " except that it will never decrease the limit.")
  1003. #define TEXT_PAUSE_METADATA \
  1004. _(" --pause-metadata[=true|false]\n" \
  1005. " Pause downloads created as a result of metadata\n" \
  1006. " download. There are 3 types of metadata\n" \
  1007. " downloads in aria2: (1) downloading .torrent\n" \
  1008. " file. (2) downloading torrent metadata using\n" \
  1009. " magnet link. (3) downloading metalink file.\n" \
  1010. " These metadata downloads will generate downloads\n" \
  1011. " using their metadata. This option pauses these\n" \
  1012. " subsequent downloads. This option is effective\n" \
  1013. " only when --enable-rpc=true is given.")
  1014. #define TEXT_BT_DETACH_SEED_ONLY \
  1015. _(" --bt-detach-seed-only[=true|false]\n" \
  1016. " Exclude seed only downloads when counting\n" \
  1017. " concurrent active downloads (See -j option).\n" \
  1018. " This means that if -j3 is given and this option\n" \
  1019. " is turned on and 3 downloads are active and one\n" \
  1020. " of those enters seed mode, then it is excluded\n" \
  1021. " from active download count (thus it becomes 2),\n" \
  1022. " and the next download waiting in queue gets\n" \
  1023. " started. But be aware that seeding item is still\n" \
  1024. " recognized as active download in RPC method.")
  1025. #define TEXT_MIN_TLS_VERSION \
  1026. _(" --min-tls-version=VERSION Specify minimum SSL/TLS version to enable.")
  1027. #define TEXT_BT_FORCE_ENCRYPTION \
  1028. _(" --bt-force-encryption[=true|false]\n" \
  1029. " Requires BitTorrent message payload encryption\n" \
  1030. " with arc4. This is a shorthand of\n" \
  1031. " --bt-require-crypto --bt-min-crypto-level=arc4.\n" \
  1032. " If true is given, deny legacy BitTorrent\n" \
  1033. " handshake and only use Obfuscation handshake and\n" \
  1034. " always encrypt message payload.")
  1035. #define TEXT_SSH_HOST_KEY_MD \
  1036. _(" --ssh-host-key-md=TYPE=DIGEST\n" \
  1037. " Set checksum for SSH host public key. TYPE is\n" \
  1038. " hash type. The supported hash type is sha-1 or\n" \
  1039. " md5. DIGEST is hex digest. For example:\n" \
  1040. " sha-1=b030503d4de4539dc7885e6f0f5e256704edf4c3\n" \
  1041. " This option can be used to validate server's\n" \
  1042. " public key when SFTP is used. If this option is\n" \
  1043. " not set, which is default, no validation takes\n" \
  1044. " place.")
  1045. #define TEXT_SOCKET_RECV_BUFFER_SIZE \
  1046. _(" --socket-recv-buffer-size=SIZE\n" \
  1047. " Set the maximum socket receive buffer in bytes.\n" \
  1048. " Specifing 0 will disable this option. This value\n" \
  1049. " will be set to socket file descriptor using\n" \
  1050. " SO_RCVBUF socket option with setsockopt() call.")
  1051. #define TEXT_BT_ENABLE_HOOK_AFTER_HASH_CHECK \
  1052. _(" --bt-enable-hook-after-hash-check[=true|false] Allow hook command invocation\n" \
  1053. " after hash check (see -V option) in BitTorrent\n" \
  1054. " download. By default, when hash check succeeds,\n" \
  1055. " the command given by --on-bt-download-complete\n" \
  1056. " is executed. To disable this action, give false\n" \
  1057. " to this option.")
  1058. // clang-format on