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