]> sjero.net Git - wget/blob - TODO
[svn] TODO: Re-use FTP connection if multiple URLs on one host specified.
[wget] / TODO
1                                  Hey Emacs, this is -*- outline -*- mode
2
3 This is the to-do list for Wget.  There is no timetable of when we plan to
4 implement these features -- this is just a list of things it'd be nice to see in
5 Wget.  Patches to implement any of these items would be gladly accepted.  The
6 items are not listed in any particular order (except that recently-added items
7 may tend towards the top).  Not all of these represent user-visible
8 changes.
9
10 * If multiple FTP URLs are specified that are on the same host, Wget should
11   re-use the connection rather than opening a new one for each file.
12
13 * Try to devise a scheme so that, when password is unknown, Wget asks
14   the user for one.
15
16 * Limit the number of successive redirection to max. 20 or so.
17
18 * If -c used on a file that's already completely downloaded, don't re-download
19   it (unless normal --timestamping processing would cause you to do so).
20
21 * If -c used with -N, check to make sure a file hasn't changed on the server
22   before "continuing" to download it (preventing a bogus hybrid file).
23
24 * Take a look at
25   <http://info.webcrawler.com/mak/projects/robots/norobots-rfc.html>
26   and support the new directives.
27
28 * Generalize --html-extension to something like --mime-extensions and have it
29   look at mime.types/mimecap file for preferred extension.  Non-HTML files with
30   filenames changed this way would be re-downloaded each time despite -N unless
31   .orig files were saved for them.  Since .orig would contain the same data as
32   non-.orig, the latter could be just a link to the former.  Another possibility
33   would be to implement a per-directory database called something like
34   .wget_url_mapping containing URLs and their corresponding filenames.
35
36 * When spanning hosts, there's no way to say that you are only interested in
37   files in a certain directory on _one_ of the hosts (-I and -X apply to all).
38   Perhaps -I and -X should take an optional hostname before the directory?
39
40 * Add an option to not encode special characters like ' ' and '~' when saving
41   local files.  Would be good to have a mode that encodes all special characters
42   (as now), one that encodes none (as above), and one that only encodes a
43   character if it was encoded in the original URL (e.g. %20 but not %7E).
44
45 * --retr-symlinks should cause wget to traverse links to directories too.
46
47 * Make wget return non-zero status in more situations, like incorrect HTTP auth.
48
49 * Make -K compare X.orig to X and move the former on top of the latter if 
50   they're the same, rather than leaving identical .orig files laying around.
51
52 * If CGI output is saved to a file, e.g. cow.cgi?param, -k needs to change the
53   '?' to a "%3F" in links to that file to avoid passing part of the filename as
54   a parameter.
55
56 * Make `-k' convert <base href=...> too.
57
58 * Make `-k' check for files that were downloaded in the past and convert links 
59   to them in newly-downloaded documents.
60
61 * Add option to clobber existing file names (no `.N' suffixes).
62
63 * Introduce a concept of "boolean" options.  For instance, every
64   boolean option `--foo' would have a `--no-foo' equivalent for
65   turning it off.  Get rid of `--foo=no' stuff.  Short options would
66   be handled as `-x' vs. `-nx'.
67
68 * Implement "thermometer" display (not all that hard; use an
69   alternative show_progress() if the output goes to a terminal.)
70
71 * Add option to only list wildcard matches without doing the download.
72
73 * Add case-insensitivity as an option.
74
75 * Handle MIME types correctly.  There should be an option to (not)
76   retrieve files based on MIME types, e.g. `--accept-types=image/*'.
77
78 * Implement "persistent" retrieving.  In "persistent" mode Wget should
79   treat most of the errors as transient.
80
81 * Allow time-stamping by arbitrary date.
82
83 * Fix Unix directory parser to allow for spaces in file names.
84
85 * Allow size limit to files (perhaps with an option to download oversize files 
86   up through the limit or not at all, to get more functionality than [u]limit.
87
88 * Implement breadth-first retrieval.
89
90 * Download to .in* when mirroring.
91
92 * Add an option to delete or move no-longer-existent files when mirroring.
93
94 * Implement a switch to avoid downloading multiple files (e.g. x and x.gz).
95
96 * Implement uploading (--upload URL?) in FTP and HTTP.
97
98 * Rewrite FTP code to allow for easy addition of new commands.  It
99   should probably be coded as a simple DFA engine.
100
101 * Recognize more FTP servers (VMS).
102
103 * Make HTTP timestamping use If-Modified-Since facility.
104
105 * Implement better spider options.
106
107 * Add more protocols (e.g. gopher and news), implementing them in a
108   modular fashion.
109
110 * Implement a concept of "packages" a la mirror.
111
112 * Implement correct RFC1808 URL parsing.
113
114 * Implement HTTP cookies.
115
116 * Implement more HTTP/1.1 bells and whistles (ETag, Content-MD5 etc.)
117
118 * Add a "rollback" option to have --continue throw away a configurable number of
119   bytes at the end of a file before resuming download.  Apparently, some stupid
120   proxies insert a "transfer interrupted" string we need to get rid of.
121
122 * When using --accept and --reject, you can end up with empty directories.  Have
123   Wget any such at the end.