1999-12-02 02:42:23 -05:00
|
|
|
Hey Emacs, this is -*- outline -*- mode
|
|
|
|
|
2003-10-08 11:17:26 -04:00
|
|
|
This is the to-do list for GNU Wget. There is no timetable of when we
|
2001-12-01 13:44:08 -05:00
|
|
|
plan to implement these features -- this is just a list of features
|
|
|
|
we'd like to see in Wget, as well as a list of problems that need
|
2003-10-08 11:17:26 -04:00
|
|
|
fixing. Patches to implement these items are likely to be accepted,
|
|
|
|
especially if they follow the coding convention outlined in PATCHES
|
|
|
|
and if they patch the documentation as well.
|
|
|
|
|
2001-12-01 13:44:08 -05:00
|
|
|
The items are not listed in any particular order (except that
|
|
|
|
recently-added items may tend towards the top). Not all of these
|
|
|
|
represent user-visible changes.
|
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Change the file name generation logic so that redirects can't dictate
|
|
|
|
file names (but redirects should still be followed). By default, file
|
|
|
|
names should be generated only from the URL the user provided. However,
|
|
|
|
with an appropriate flag, Wget will allow the remote server to specify
|
|
|
|
the file name, either through redirection (as is always the case now)
|
|
|
|
or via the increasingly popular header `Content-Disposition: XXX;
|
|
|
|
filename="FILE"'. The file name should be generated and displayed
|
|
|
|
*after* processing the server's response, not before, as it is done now.
|
|
|
|
This will allow trivial implementation of -nc, of O_EXCL when opening
|
|
|
|
the file, --html-extension will stop being a horrible hack, and so on.
|
|
|
|
|
|
|
|
* -O should be respected, with no exceptions. It should work in
|
|
|
|
conjunction with -N and -k. (This is hard to achieve in the current
|
|
|
|
code base.) Ancillary files, such as directory listings and such,
|
|
|
|
should be downloaded either directly to memory, or to /tmp.
|
|
|
|
|
|
|
|
* Implement digest and NTLM authorization for proxies. This is harder
|
|
|
|
than it seems because it requires some rethinking of the HTTP code.
|
|
|
|
|
|
|
|
* Rethink the interaction between recur.c (the recursive download code)
|
|
|
|
and HTTP/FTP code. Ideally, the downloading code should have a way
|
|
|
|
to retrieve a file and, optionally, to specify a list of URLs for
|
|
|
|
continuing the "recursive" download. FTP code will surely benefit
|
|
|
|
from such a restructuring because its current incarnation is way too
|
|
|
|
smart for its own good.
|
|
|
|
|
|
|
|
* Both HTTP and FTP connections should be first-class objects that can
|
|
|
|
be reused after a download is done. Currently information about both
|
|
|
|
is kept implicitly on the stack, and forgotten after each download.
|
|
|
|
|
|
|
|
* Restructure the FTP code to remove massive amounts of code duplication
|
|
|
|
and repetition. Remove all the "intelligence" and make it work as
|
|
|
|
outlined in the previous bullet.
|
|
|
|
|
|
|
|
* Add support for SFTP. Teach Wget about newer features of FTP servers
|
|
|
|
in general.
|
|
|
|
|
|
|
|
* Use FTP features for checking MD5 sums and implementing truly robust
|
|
|
|
downloads.
|
2002-01-15 10:16:19 -05:00
|
|
|
|
2001-12-01 13:44:08 -05:00
|
|
|
* Wget shouldn't delete rejected files that were not downloaded, but
|
|
|
|
just found on disk because of `-nc'. For example, `wget -r -nc
|
|
|
|
-A.gif URL' should allow the user to get all the GIFs without
|
|
|
|
removing any of the existing HTML files.
|
2000-11-14 17:45:43 -05:00
|
|
|
|
2001-11-30 06:15:24 -05:00
|
|
|
* Be careful not to lose username/password information given for the
|
2005-06-22 18:32:33 -04:00
|
|
|
URL on the command line. For example,
|
|
|
|
wget -r http://username:password@server/path/ should send that
|
|
|
|
username and password to all content under /path/ (this is apparently
|
|
|
|
what browsers do).
|
|
|
|
|
|
|
|
* Don't send credentials using "Basic" authorization before the server
|
|
|
|
has a chance to tell us that it supports Digest or NTLM!
|
2001-11-30 06:15:24 -05:00
|
|
|
|
2003-10-08 11:10:55 -04:00
|
|
|
* Add a --range parameter allowing you to explicitly specify a range
|
|
|
|
of bytes to get from a file over HTTP (FTP only supports ranges
|
|
|
|
ending at the end of the file, though forcibly disconnecting from
|
2005-06-22 18:32:33 -04:00
|
|
|
the server at the desired endpoint would work). For example,
|
|
|
|
--range=n-m would specify inclusive range (a la the Range header),
|
|
|
|
and --range=n:m would specify exclusive range (a la Python's
|
|
|
|
slices). -c should work with --range by assuming the range is
|
|
|
|
partially downloaded on disk, and contuing from there (effectively
|
|
|
|
requesting a smaller range).
|
2001-03-05 20:20:58 -05:00
|
|
|
|
2001-02-27 20:29:45 -05:00
|
|
|
* If multiple FTP URLs are specified that are on the same host, Wget should
|
|
|
|
re-use the connection rather than opening a new one for each file.
|
2005-06-22 18:32:33 -04:00
|
|
|
This should be easy provided the above restructuring of FTP code that
|
|
|
|
would include the FTP connection becoming a first-class objects.
|
2001-02-27 20:29:45 -05:00
|
|
|
|
2000-11-21 09:58:46 -05:00
|
|
|
* Try to devise a scheme so that, when password is unknown, Wget asks
|
|
|
|
the user for one.
|
|
|
|
|
2001-01-11 23:51:59 -05:00
|
|
|
* If -c used with -N, check to make sure a file hasn't changed on the server
|
|
|
|
before "continuing" to download it (preventing a bogus hybrid file).
|
|
|
|
|
2003-10-08 11:10:55 -04:00
|
|
|
* Generalize --html-extension to something like --mime-extensions and
|
|
|
|
have it look at mime.types/mimecap file for preferred extension.
|
|
|
|
Non-HTML files with filenames changed this way would be
|
|
|
|
re-downloaded each time despite -N unless .orig files were saved for
|
|
|
|
them. Since .orig would contain the same data as non-.orig, the
|
|
|
|
latter could be just a link to the former. Another possibility
|
2000-10-20 19:20:24 -04:00
|
|
|
would be to implement a per-directory database called something like
|
|
|
|
.wget_url_mapping containing URLs and their corresponding filenames.
|
|
|
|
|
2000-10-20 02:06:03 -04:00
|
|
|
* When spanning hosts, there's no way to say that you are only interested in
|
|
|
|
files in a certain directory on _one_ of the hosts (-I and -X apply to all).
|
|
|
|
Perhaps -I and -X should take an optional hostname before the directory?
|
|
|
|
|
2000-10-09 18:43:11 -04:00
|
|
|
* --retr-symlinks should cause wget to traverse links to directories too.
|
|
|
|
|
2000-09-25 18:09:25 -04:00
|
|
|
* Make wget return non-zero status in more situations, like incorrect HTTP auth.
|
2005-06-22 18:32:33 -04:00
|
|
|
Create and document different exit statuses for different errors.
|
2000-09-25 18:09:25 -04:00
|
|
|
|
2000-04-05 23:36:28 -04:00
|
|
|
* Make -K compare X.orig to X and move the former on top of the latter if
|
|
|
|
they're the same, rather than leaving identical .orig files laying around.
|
|
|
|
|
2000-05-17 22:19:59 -04:00
|
|
|
* Make `-k' check for files that were downloaded in the past and convert links
|
|
|
|
to them in newly-downloaded documents.
|
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Devise a way for options to have effect on a per-URL basis. This is very
|
|
|
|
natural for some options, such as --post-data. It could be implemented
|
|
|
|
simply by having more than one struct options.
|
|
|
|
|
1999-12-02 02:42:23 -05:00
|
|
|
* Add option to clobber existing file names (no `.N' suffixes).
|
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Add option to only list wildcard matches without doing the download. The same
|
|
|
|
could be generalized to support something like apt's --print-uri.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
|
|
|
* Handle MIME types correctly. There should be an option to (not)
|
|
|
|
retrieve files based on MIME types, e.g. `--accept-types=image/*'.
|
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Allow time-stamping by arbitrary date. For example,
|
|
|
|
wget --if-modified-after DATE URL.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Make quota apply to single files, preferrably so that the download of an
|
|
|
|
oversized file is not attempted at all.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* When updating an existing mirror, download to temporary files (such as .in*)
|
|
|
|
and rename the file after the download is done.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2000-10-20 02:06:03 -04:00
|
|
|
* Add an option to delete or move no-longer-existent files when mirroring.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Implement uploading (--upload=FILE URL?) in FTP and HTTP. A beginning of
|
|
|
|
this is available in the form of --post-file, but it should be expanded to
|
|
|
|
be really useful.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
|
|
|
* Make HTTP timestamping use If-Modified-Since facility.
|
|
|
|
|
2005-06-22 18:32:33 -04:00
|
|
|
* Add more protocols (such as news or possibly some of the streaming
|
|
|
|
protocols), implementing them in a modular fashion.
|
1999-12-02 02:42:23 -05:00
|
|
|
|
2001-11-24 22:10:34 -05:00
|
|
|
* Add a "rollback" option to have continued retrieval throw away a
|
|
|
|
configurable number of bytes at the end of a file before resuming
|
|
|
|
download. Apparently, some stupid proxies insert a "transfer
|
|
|
|
interrupted" string we need to get rid of.
|