]> sjero.net Git - wget/blob - TODO
[svn] -k should convert "hostless absolute" URLs, like <A HREF="/index.html">.
[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.  Not all of them represent
7 user-visible changes.
8
9 * Timestamps are sometimes not copied over on files retrieved by FTP.
10
11 * Wget does not currently handle "fragment identifiers" (the part of a URL 
12   starting with the '#' character) properly.
13
14 * Make -K compare X.orig to X and move the former on top of the latter if 
15   they're the same, rather than leaving identical .orig files laying around.
16
17 * Add an option to save all text/html files with a .html extension so that when
18   grabbing the output of a dynamically-generated remote page, you'll end up with
19   a filename that will cause _your_ webserver to realize the saved static HTML
20   file isn't text/plain (or an illegal CGI script in the case of *.cgi).
21
22 * Allow mirroring of FTP URLs where logging in puts you somewhere else besides 
23   '/'. 
24
25 * Make `-k' convert <base href=...> too.
26
27 * Make `-k' check for files that were downloaded in the past and convert links 
28   to them in newly-downloaded documents.
29
30 * -k should convert convert relative references to absolute if not downloaded.
31
32 * -k should convert "hostless absolute" URLs, like <A HREF="/index.html">.
33
34 * Add option to clobber existing file names (no `.N' suffixes).
35
36 * Introduce a concept of "boolean" options.  For instance, every
37   boolean option `--foo' would have a `--no-foo' equivalent for
38   turning it off.  Get rid of `--foo=no' stuff.  Short options would
39   be handled as `-x' vs. `-nx'.
40
41 * Implement "thermometer" display (not all that hard; use an
42   alternative show_progress() if the output goes to a terminal.)
43
44 * Add option to only list wildcard matches without doing the download.
45
46 * Add case-insensitivity as an option.
47
48 * Handle MIME types correctly.  There should be an option to (not)
49   retrieve files based on MIME types, e.g. `--accept-types=image/*'.
50
51 * Implement "persistent" retrieving.  In "persistent" mode Wget should
52   treat most of the errors as transient.
53
54 * Allow time-stamping by arbitrary date.
55
56 * Fix Unix directory parser to allow for spaces in file names.
57
58 * Allow size limit to files.
59
60 * Recognize HTML comments correctly.  Add more options for handling
61   bogus HTML found all over the 'net.
62
63 * Implement breadth-first retrieval.
64
65 * Download to .in* when mirroring.
66
67 * Add an option to delete or move no-longer-existent files when
68   mirroring.
69
70 * Implement a switch to avoid downloading multiple files (e.g. x and
71   x.gz).
72
73 * Implement uploading (--upload URL?) in FTP and HTTP.
74
75 * Rewrite FTP code to allow for easy addition of new commands.  It
76   should probably be coded as a simple DFA engine.
77
78 * Recognize more FTP servers (VMS).
79
80 * Make HTTP timestamping use If-Modified-Since facility.
81
82 * Implement better spider options.
83
84 * Add more protocols (e.g. gopher and news), implementing them in a
85   modular fashion.
86
87 * Implement a concept of "packages" a la mirror.
88
89 * Implement correct RFC1808 URL parsing.
90
91 * Implement HTTP cookies.
92
93 * Implement more HTTP/1.1 bells and whistles (ETag, Content-MD5 etc.)
94
95 * Support SSL encryption through SSLeay or OpenSSL.