]> sjero.net Git - wget/blob - TODO
[svn] TODO: Timestamps are sometimes not copied over on files retrieved by FTP.
[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
31   downloaded.
32
33 * Add option to clobber existing file names (no `.N' suffixes).
34
35 * Introduce a concept of "boolean" options.  For instance, every
36   boolean option `--foo' would have a `--no-foo' equivalent for
37   turning it off.  Get rid of `--foo=no' stuff.  Short options would
38   be handled as `-x' vs. `-nx'.
39
40 * Implement "thermometer" display (not all that hard; use an
41   alternative show_progress() if the output goes to a terminal.)
42
43 * Add option to only list wildcard matches without doing the download.
44
45 * Add case-insensitivity as an option.
46
47 * Handle MIME types correctly.  There should be an option to (not)
48   retrieve files based on MIME types, e.g. `--accept-types=image/*'.
49
50 * Implement "persistent" retrieving.  In "persistent" mode Wget should
51   treat most of the errors as transient.
52
53 * Allow time-stamping by arbitrary date.
54
55 * Fix Unix directory parser to allow for spaces in file names.
56
57 * Allow size limit to files.
58
59 * Recognize HTML comments correctly.  Add more options for handling
60   bogus HTML found all over the 'net.
61
62 * Implement breadth-first retrieval.
63
64 * Download to .in* when mirroring.
65
66 * Add an option to delete or move no-longer-existent files when
67   mirroring.
68
69 * Implement a switch to avoid downloading multiple files (e.g. x and
70   x.gz).
71
72 * Implement uploading (--upload URL?) in FTP and HTTP.
73
74 * Rewrite FTP code to allow for easy addition of new commands.  It
75   should probably be coded as a simple DFA engine.
76
77 * Recognize more FTP servers (VMS).
78
79 * Make HTTP timestamping use If-Modified-Since facility.
80
81 * Implement better spider options.
82
83 * Add more protocols (e.g. gopher and news), implementing them in a
84   modular fashion.
85
86 * Implement a concept of "packages" a la mirror.
87
88 * Implement correct RFC1808 URL parsing.
89
90 * Implement HTTP cookies.
91
92 * Implement more HTTP/1.1 bells and whistles (ETag, Content-MD5 etc.)
93
94 * Support SSL encryption through SSLeay or OpenSSL.