usage_text.h 78 KB

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