1 2000-11-01 Hrvoje Niksic <hniksic@arsdigita.com>
3 * html.c (htmlfindurl): Fix recognition of # HTML fragments.
5 2000-11-01 Hrvoje Niksic <hniksic@arsdigita.com>
7 * url.c (construct): Rewritten for clarity. Avoids the
8 unnecessary copying and stack-allocation the old version
11 2000-10-31 Hrvoje Niksic <hniksic@arsdigita.com>
13 * ftp.c (getftp): Ditto.
15 * http.c (gethttp): Rewind the stream when retrying from scratch.
17 2000-10-31 Hrvoje Niksic <hniksic@arsdigita.com>
19 * retr.c (retrieve_url): Use url_concat() to handle relative
20 redirections instead of /ad hoc/ code.
22 * url.c (url_concat): New function encapsulating weird
24 (urllen_http_hack): New function.
25 (construct): When constructing new URLs, recognize that `?' does
26 not form part of the file name in HTTP.
28 2000-10-13 Adrian Aichner <adrian@xemacs.org>
30 * retr.c: Add msec timing support for WINDOWS.
31 * retr.c (reset_timer): GetSystemTime() on WINDOWS.
32 * retr.c (elapsed_time): Calculate delta time to msec on WINDOWS.
34 2000-10-27 Dan Harkless <dan-wget@dilvish.speed.net>
36 * retr.c (retrieve_url): Manually applied T. Bharath
37 <TBharath@responsenetworks.com>'s patch to get wget to grok
38 illegal relative URL redirects. Reformatted and re-commented it.
40 2000-10-23 Dan Harkless <dan-wget@dilvish.speed.net>
42 * connect.c (make_connection and bindport): Manually applied Rob
43 Mayoff <mayoff@dqd.com>'s 1.5.3 patch to add --bind-address,
44 changing coding style to GNU's.
46 * ftp.c (ftp_loop_internal): --delete-after wasn't implemented for
47 files downloaded via FTP. Per a comment, .listing files were not
48 counted towards number of bytes and files downloaded because they're
49 deleted anyway. Well, they aren't under -nr, so count them then.
51 * init.c: Manually applied Rob Mayoff's 1.5.3 patch to add
52 --bind-address, alphabetizing, changing coding style to GNU's,
53 commenting, and renaming cmd_ip_address() to cmd_address() to
54 imply hostnames also okay.
56 * main.c (main): --delete-after didn't delete the root of the
57 tree. Ignore --convert-links if --delete-after was specified.
58 Manually applied Rob Mayoff's 1.5.3 patch to add --bind-address,
59 fixing duplicate use of added-since-1.5.3 case value.
60 (print_help): Clarified that --delete-after deletes local files.
61 Rob forgot to add a line for his new --bind-address option.
63 * options.h (struct options): Manually applied Rob Mayoff's patch
64 to add --bind-address (bind_address structure member).
66 * recur.c (recursive_retrieve): Improved comment; added DEBUGP().
67 Ignore --convert-links if --delete-after was specified.
69 * retr.c (retrieve_from_file): Just added a DEBUGP().
71 2000-10-19 Dan Harkless <dan-wget@dilvish.speed.net>
73 * ftp.c (ftp_loop_internal): downloaded_file() enumerators changed.
74 (getftp): Applied Piotr Sulecki <Piotr.Sulecki@ios.krakow.pl>'s
75 patch to work around FTP servers that incorrectly respond to the
76 "REST" command with the remaining size rather than the total file size.
78 * http.c (gethttp): Improved a comment and added code to tack on
79 ".html" to text/html files without that extension when -E specified.
80 (http_loop): Use new downloaded_file() enumerators and deal with
81 the case of gethttp() called xrealloc() on u->local.
83 * init.c (commands): Added new "htmlextension" command.
84 Also renamed John Daily's cmd_quad() to the more descriptive
85 cmd_lockable_boolean(), alpha-sorted the CMD_DECLARE()s and
86 removed duplicate cmd_boolean() declaration.
88 * main.c (print_help): Added my new -E / --html-extension option.
89 (main): Undocumented --email-address option previously used -E synonym.
90 Stole it away for the much more deserving --html-extension's use.
92 * options.h (struct options): Added html_extension field.
94 * url.c (convert_links): URL X that we saved as X.html locally due
95 to -E needs to be backed up as X.orig, not X.html.orig. Added comments.
96 (downloaded_file): Now remembers if we added .html extension to a file.
98 * url.h (downloaded_file_t): Added extra enumerators to support above.
99 (downloaded_file): Now takes and returns a downloaded_file_t.
101 * wget.h (unnamed "dt" enum): Added ADDED_HTML_EXTENSION enumerator.
103 2000-10-09 Dan Harkless <dan-wget@dilvish.speed.net>
105 * html.c (htmlfindurl): Added unneeded initialization to quiet warning.
107 * main.c (print_help): Clarified what --retr-symlinks does.
109 2000-09-15 John Daily <jdaily@cyberdude.com>
111 * init.c: Add support for "always" and "never" values to allow
112 .wgetrc to override commandline (useful e.g. with .pm files
113 calling `wget --passive-ftp' when your firewall doesn't allow that).
115 * ftp.c (getftp): passive_ftp is first option to support always/never.
117 2000-08-30 Dan Harkless <dan-wget@dilvish.speed.net>
119 * ftp.c (ftp_retrieve_list): Use new INFINITE_RECURSION #define.
121 * html.c: htmlfindurl() now takes final `dash_p_leaf_HTML' parameter.
122 Wrapped some > 80-column lines. When -p is specified and we're at a
123 leaf node, do not traverse <A>, <AREA>, or <LINK> tags other than
124 <LINK REL="stylesheet">.
126 * html.h (htmlfindurl): Now takes final `dash_p_leaf_HTML' parameter.
128 * init.c: Added new -p / --page-requisites / page_requisites option.
130 * main.c (print_help): Clarified that -l inf and -l 0 both allow
131 infinite recursion. Changed the unhelpful --mirrior description
132 to simply give the options it's equivalent to. Added new -p option.
133 (main): Added some comments; handle new -p / --page-requisites.
135 * options.h (struct options): Added new page_requisites field.
137 * recur.c: Changed "URL-s" to "URLs" and "HTML-s" to "HTMLs".
138 Calculate and pass down new `dash_p_leaf_HTML' parameter to
139 get_urls_html(). Use new INFINITE_RECURSION #define.
141 * retr.c: Changed "URL-s" to "URLs". get_urls_html() now takes
142 final `dash_p_leaf_HTML' parameter.
144 * url.c: get_urls_html() and htmlfindurl() now take final
145 `dash_p_leaf_HTML' parameter.
147 * url.h (get_urls_html): Now takes final `dash_p_leaf_HTML' parameter.
149 * wget.h: Added some comments and new INFINITE_RECURSION #define.
151 2000-08-23 Dan Harkless <dan-wget@dilvish.speed.net>
153 * main.c (print_help): -B / --base was not mentioned.
155 2000-08-22 Dan Harkless <dan-wget@dilvish.speed.net>
157 * main.c (print_help): Modified -nc description to mention that it
158 also prevents the creation of multiple versions of the same file
159 with ".<number>" suffixes.
161 2000-07-14 Jan Prikryl <prikryl@cg.tuwien.ac.at>
163 * retr.c (retrieve_url): Consistently strdup opt.referer when
166 2000-06-09 Dan Harkless <dan-wget@dilvish.speed.net>
168 * main.c (print_help): --help output for --waitretry was over 80 cols.
170 2000-06-09 Hrvoje Niksic <hniksic@iskon.hr>
172 * url.c (encode_string): Fix comment.
173 Suggested by Herold Heiko <Heiko.Herold@previnet.it>.
175 2000-06-01 Const Kaplinsky <const@ce.cctpu.edu.ru>
177 * ftp.c (ftp_retrieve_list): Change permissions only on plain
180 2000-06-01 Hrvoje Niksic <hniksic@iskon.hr>
182 * url.c (str_url): Print the port number only if it's different
183 from the default port number for that protocol.
185 2000-05-22 Dan Harkless <dan-wget@dilvish.speed.net>
187 * main.c (print_help): Added --help line for Damir Dzeko
188 <ddzeko@zesoi.fer.hr>'s until-now-undocumented --referer option.
189 Removed comments that --referer and --waitretry were undocumented.
190 Changed "`.wgetrc' command" to "`.wgetrc'-style command" on --help
193 2000-05-18 Hrvoje Niksic <hniksic@iskon.hr>
195 * ftp.c (getftp): Ditto.
197 * http.c (gethttp): Check for return value of fclose/fflush.
199 2000-04-12 Hrvoje Niksic <hniksic@iskon.hr>
201 * host.c (store_hostaddress): Instead of shifting ADDR, start
202 copying from the correct address.
204 2000-04-12 Hrvoje Niksic <hniksic@iskon.hr>
206 * http.c (gethttp): Don't free REQUEST -- it was allocated with
208 Pointed out by Gisle Vanem <gvanem@eunet.no>.
210 2000-04-04 Dan Harkless <dan-wget@dilvish.speed.net>
212 * host.c (store_hostaddress): R. K. Owen's patch introduces a
213 "left shift count >= width of type" warning on 32-bit
214 architectures. Got rid of it by tricking the compiler w/ a variable.
216 * url.c (UNSAFE_CHAR): The macro didn't include all the illegal
217 characters per RFC1738, namely everything above '~'. It also
218 generated a warning on OSes where char =~ unsigned char. Fixed.
220 1998-10-17 Hrvoje Niksic <hniksic@srce.hr>
222 * http.c (http_process_type): Removed needless strdup(), a memory
225 1998-09-25 Hrvoje Niksic <hniksic@srce.hr>
227 * html.c (htmlfindurl): Set PH to the first occurrence of `#'.
229 1998-09-25 Simon Munton <simonm@m4data.co.uk>
231 * init.c (wgetrc_file_name): Don't free HOME under Windows.
233 1998-12-01 "R. K. Owen" <rkowen@Nersc.GOV>
235 * host.c (store_hostaddress): Fix for big endian 64-bit machines.
237 1998-12-01 Hrvoje Niksic <hniksic@srce.hr>
239 * url.c (UNSAFE_CHAR): New macro.
240 (contains_unsafe): Use it.
241 (encode_string): Ditto.
243 1998-12-01 Hrvoje Niksic <hniksic@srce.hr>
245 * main.c (i18n_initialize): Use LC_MESSAGES only if available.
247 2000-03-31 Hrvoje Niksic <hniksic@srce.hr>
249 * Use TOUPPER/TOLOWER.
251 1998-12-22 Alexander V. Lukyanov <lav@yars.free.net>
253 * ftp-opie.c (btoe): Zero-terminate OSTORE.
255 2000-03-21 Hrvoje Niksic <hniksic@iskon.hr>
257 * wget.h (DO_REALLOC_FROM_ALLOCA): Ditto.
259 * sysdep.h (ISALNUM): New macro.
263 2000-03-10 Dan Harkless <dan-wget@dilvish.speed.net>
265 * html.c (idmatch): Implemented checking of my new --follow-tags
266 and --ignore-tags options.
268 * init.c (commands): Added comment reminding people adding new
269 entries doing allocation to add corresponding freeing in cleanup().
270 (commands): Added new followtags and ignoretags commands.
271 (cleanup): Free storage for new followtags and ignoretags.
273 * main.c: Use of "comma-separated list" was random -- normalized
274 it. Did some alphabetization. Added comments pointing out
275 "Options without arguments" and "Options accepting an argument"
276 sections of long_options[]. Added new options --follow-tags and
277 -G / --ignore-tags. Added comment that Damir's --referer is
278 currently undocumented. Added comment that Heiko's --waitretry is
279 partially undocumented (mentioned in --help but not in
280 wget.texi). Moved improperly sorted 24, 129, and 'G' cases.
282 * options.h (struct options): Added new fields follow_tags and
285 * wget.h: Added "#define EQ 0" so we can say "strcmp(a, b) == EQ".
287 2000-03-02 Dan Harkless <dan-wget@dilvish.speed.net>
289 * ftp.c (ftp_loop_internal): Heiko introduced "suggest explicit
290 braces to avoid ambiguous `else'" warnings. Eliminated them.
292 * http.c (gethttp): Dan Berger's query string patch is totally
293 bogus. If you have two different URLs, gen_page.cgi?page1 and
294 get_page.cgi?page2, they'll both be saved as get_page.cgi and the
295 second will overwrite the first. Also, parameters to implicit
296 CGIs, like "http://www.host.com/db/?2000-03-02" cause the URLs to
297 be printed with trailing garbage characters, and could seg fault.
298 Backing out the patch, which Dan B. informed me by email was just
299 a kludge to download StarOffice from Sun made necessary due to
300 wget's unconditional escaping of certain characters (room for an
302 (http_loop): Heiko introduced "suggest explicit braces to avoid
303 ambiguous `else'" warnings. Eliminated them.
305 * main.c: Heiko's --wait / --waitretry backwards compatibility
306 code looks to have been totally untested -- automatic variable
307 'wr' was used without being initialized, and a long int was passed
308 into setval()'s char* val parameter.
310 * recur.c (parse_robots): Applied Edward J. Sabol
311 <sabol@alderaan.gsfc.nasa.gov>'s patch for Guan Yang's reported
312 problem with "User-agent:<space>*<space>" lines in robots.txt.
314 * url.c (parseurl, str_url): Removing Dan Berger's code (see
315 http.c above for explanation).
317 1999-08-25 Heiko Herold <Heiko.Herold@previnet.it>
319 * ftp.c: Respect new option waitretry.
321 2000-01-30 Damir Dzeko <ddzeko@zesoi.fer.hr>
323 * http.c (gethttp): Send custom Referer, if required.
325 1999-09-24 Charles G Waldman <cgw@fnal.gov>
327 * netrc.c (parse_netrc): Allow passwords to contain spaces.
329 * netrc.c (parse_netrc): New function.
331 1999-09-17 Dan Berger <dberger@ix.netcom.com>
333 * http.c (gethttp): Send it.
335 * url.c (parseurl): Detect query string in HTTP URL-s.
338 2000-03-02 HIROSE Masaaki <hirose31@t3.rim.or.jp>
340 * html.c (html_allow): Add <link href=...> and <script src=...>.
342 1999-05-02 andrew deryabin <djsf@softhome.net>
344 * http.c (gethttp): Specify port in `Host' header only if it's
347 1998-11-03 Edward J. Sabol <sabol@alderaan.gsfc.nasa.gov>
349 * recur.c (recursive_retrieve): If a finite maximum depth is
350 specified, and we're are already at that depth, don't download the
351 HTML file for parsing.
353 2000-03-01 Dan Harkless <dan-wget@dilvish.speed.net>
355 * ftp.c (ftp_loop_internal): Call new downloaded_file() function,
356 even though we don't do conversion on HTML files retrieved via
357 FTP, so _current_ usage of downloaded_file() makes this call unneeded.
358 (ftp_retrieve_list): Added a comment saying where we need to
359 stat() a .orig file if FTP'd HTML file conversion is ever implemented.
360 (ftp_retrieve_list): "Local file '%s' is more recent," is sometimes
361 a lie -- reworded as "Server file no newer than local file '%s' --".
363 * http.c (http_loop): Fixed a typo and clarified a comment.
364 (http_loop): When -K and -N are specified together, compare size
365 and timestamp of server file X against local file X.orig (if
366 extant) rather than converted local file X.
367 (http_loop): "Local file '%s' is more recent," is sometimes a lie
368 -- reworded as "Server file no newer than local file '%s' --".
369 (http_loop): Call new downloaded_file() function to prevent
370 wrongful overwriting of .orig file when -N is specified.
372 * url.c (convert_links): When -K specified, only rename X to
373 X.orig if downloaded_file() returns TRUE. Otherwise when we skip
374 file X due to -N, we clobber an X.orig from a previous invocation.
375 (convert_links): Call the failsafe xstrdup(), not the real strdup().
376 (convert_links): Added a note asking anyone who understands how
377 multiple URLs can correspond to a single file to comment it.
378 (downloaded_file): Added this new function.
380 * url.h (downloaded_file): Added prototype for this new function
381 as well as its downloaded_file_t enum type.
383 * wget.h (boolean): Added this new typedef and TRUE and FALSE #defines.
385 2000-02-29 Dan Harkless <dan-wget@dilvish.speed.net>
387 * version.c: Upped version to developer-only "1.5.3+dev".
389 2000-02-18 Dan Harkless <dan-wget@dilvish.speed.net>
391 * init.c (backup_converted): Added this new option.
393 * main.c (-K / --backup-converted): Added this new option.
395 * options.h (backup_converted): Added this new option.
397 * url.c (convert_links): When backup_converted is specified, save
398 file X as X.orig before converting.
400 * url.h (urlpos): Fixed typo -- said "Rekative" instead of "Relative".
402 1998-09-21 Hrvoje Niksic <hniksic@srce.hr>
404 * version.c: Wget 1.5.3 is released.
406 1998-09-21 Hrvoje Niksic <hniksic@srce.hr>
408 * host.c (ftp_getaddress): Don't warn when reverse-lookup of local
409 address doesn't yield FQDN.
411 1998-09-21 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
413 * cmpt.c (strerror): Fix declaration of sys_errlist.
415 1998-09-11 Hrvoje Niksic <hniksic@srce.hr>
417 * main.c (main): Don't use an array subscript as the first
418 argument to STRDUP_ALLOCA.
421 1998-09-11 Szakacsits Szabolcs <szaka@sienet.hu>
423 * html.c (htmlfindurl): Download table background.
425 1998-09-11 Hans Grobler <grobh@conde.ee.sun.ac.za>
427 * init.c (parse_line): Would free *com before allocating it.
428 (parse_line): Would free com instead of *com.
430 1998-09-10 Howard Gayle <howard@fjst.com>
432 * url.c (get_urls_html): Would drop the last character of the
435 1998-09-10 Hrvoje Niksic <hniksic@srce.hr>
437 * http.c (http_loop): Don't print status code if quiet.
439 1998-09-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
441 * log.c: Use <stdarg.h> only when __STDC__.
443 1998-09-10 Adam D. Moss <adam@foxbox.org>
445 * html.c (htmlfindurl): Download <layer src=...>.
447 1998-09-10 Howard Gayle <howard@fjst.com>
449 * ftp.c (ftp_retrieve_list): Don't update the time stamp of a file
452 1998-06-27 Hrvoje Niksic <hniksic@srce.hr>
454 * utils.c: Include <libc.h> on NeXT.
456 1998-06-26 Heinz Salzmann <heinz.salzmann@intermetall.de>
458 * url.c (get_urls_html): Fix calculation of URL position.
460 1998-06-23 Hrvoje Niksic <hniksic@srce.hr>
462 * version.c: Wget 1.5.2 is released.
464 1998-06-23 Dave Love <d.love@dl.ac.uk>
466 * ftp.c, init.c, netrc.c: Include errno.h.
468 * http.c: Include errno.h and time header.
470 * Makefile.in (exext): Define.
471 (install.bin, uninstall.bin): Use it.
473 1998-06-21 Hrvoje Niksic <hniksic@srce.hr>
475 * http.c (http_loop): Don't attempt to compare local and remote
476 sizes if the remote size is unknown.
478 1998-06-16 Hrvoje Niksic <hniksic@srce.hr>
480 * url.c (get_urls_html): Use malloc() instead of alloca in the
483 1998-06-13 Hrvoje Niksic <hniksic@srce.hr>
485 * version.c: Wget 1.5.2-b4 is released.
487 1998-06-13 Hrvoje Niksic <hniksic@srce.hr>
489 * url.c (get_urls_html): Ignore spaces before and after the URI.
491 1998-06-08 Wanderlei Antonio Cavassin <cavassin@conectiva.com.br>
493 * ftp.c (getftp): Translate `done'.
495 1998-06-06 Hrvoje Niksic <hniksic@srce.hr>
497 * version.c: Wget 1.5.2-b3 is released.
499 1998-06-06 Alexander Kourakos <awk@bnt.com>
501 * init.c (cleanup): Close dfp, don't free it.
503 1998-06-06 Hrvoje Niksic <hniksic@srce.hr>
505 * utils.c (make_directory): Twiddle.
507 * config.h.in: Added template for access().
509 1998-06-05 Mathieu Guillaume <mat@cythere.com>
511 * html.c (htmlfindurl): Download <input src=...>
513 1998-06-03 Hrvoje Niksic <hniksic@srce.hr>
515 * utils.c (file_exists_p): Use access() with two arguments.
517 1998-05-27 Martin Kraemer <Martin.Kraemer@mch.sni.de>
519 * netrc.c (parse_netrc): Correct logic.
521 1998-05-27 Hrvoje Niksic <hniksic@srce.hr>
523 * ftp.c (getftp): Added `break'; suggested by Lin Zhe Min
524 <ljm@ljm.wownet.net>.
526 1998-05-24 Hrvoje Niksic <hniksic@srce.hr>
528 * version.c: Wget 1.5.2-b2 is released.
530 1998-05-18 Juan Jose Rodriguez <jcnsoft@jal1.telmex.net.mx>
532 * mswindows.h: Don't translate mkdir to _mkdir under Borland.
534 1998-05-17 Hrvoje Niksic <hniksic@srce.hr>
536 * retr.c (elapsed_time): Return correct value when
537 HAVE_GETTIMEOFDAY is undefined.
539 1998-05-13 Hrvoje Niksic <hniksic@srce.hr>
541 * version.c: Wget 1.5.2-b1 is released.
543 1998-05-08 Hrvoje Niksic <hniksic@srce.hr>
545 * getopt.c (_getopt_internal): Use exec_name instead of argv[0].
546 (_getopt_internal): Don't translate `#if 0'-ed strings.
548 1998-05-06 Douglas E. Wegscheid <wegscd@whirlpool.com>
550 * mswindows.c (ws_handler): Use fork_to_background().
552 1998-05-05 Hrvoje Niksic <hniksic@srce.hr>
554 * version.c: Wget 1.5.1 is released.
556 1998-05-05 Hrvoje Niksic <hniksic@srce.hr>
558 * http.c (parse_http_status_line): Avoid `minor' and `major'
561 1998-05-02 Hrvoje Niksic <hniksic@srce.hr>
563 * utils.c (mkdirhier): Renamed to make_directory.
565 1998-05-01 Hrvoje Niksic <hniksic@srce.hr>
567 * mswindows.c (fork_to_background): Define under Windows.
569 * utils.c (fork_to_background): New function.
571 * html.c (htmlfindurl): Removed rerdundant casts.
573 1998-05-01 Douglas E. Wegscheid <wegscd@whirlpool.com>
575 * mswindows.c (ws_mypath): Cache the path.
577 1998-04-30 Douglas E. Wegscheid <wegscd@whirlpool.com>
579 * ftp.h: Prefix enum ftype members with FT_.
581 * ftp-ls.c, ftp.c, html.h: Adjust accordingly.
583 * mswindows.h: Use stat under Borland, _stat under MSVC.
585 1998-04-28 Hrvoje Niksic <hniksic@srce.hr>
587 * http.c (known_authentication_scheme_p): New function.
588 (gethttp): Handle authorization more correctly.
590 * ftp-basic.h: Removed.
594 * utils.c: Include <unistd.h> before <pwd.h>; needed under SunOS
596 (numdigit): Use `while' loop.
598 * http.c (create_authorization_line): Detect authentication
599 schemes case-insensitively.
601 * http.c (extract_header_attr): Use strdupdelim().
602 (digest_authentication_encode): Move declaration of local
603 variables to smaller scope.
604 (digest_authentication_encode): Reset REALM, OPAQUE and NONCE.
605 (create_authorization_line): Detect authentication schemes
608 * utils.c (touch): Constify.
610 * http.c (gethttp): Report a nicer error when no data is received.
612 * rbuf.h (RBUF_READCHAR): Ditto.
614 * ftp-basic.c (ftp_response): Use sizeof.
616 1998-04-27 Hrvoje Niksic <hniksic@srce.hr>
618 * retr.c (print_percentage): EXPECTED is long, not int.
619 (print_percentage): Use floating-point arithmetic to avoid
620 overflow with large files' sizes multiplied with 100.
622 1998-04-27 Gregor Hoffleit <flight@mathi.uni-heidelberg.de>
624 * config.h.in: Added pid_t stub.
626 * sysdep.h (S_ISREG): Moved here from mswindows.h (NeXT doesn't
629 1998-04-20 Hrvoje Niksic <hniksic@srce.hr>
631 * version.c: Wget 1.5.0 is released.
633 1998-04-18 Hrvoje Niksic <hniksic@srce.hr>
635 * url.c (str_url): Ditto.
637 * ftp-basic.c (ftp_rest): Use new name.
639 * utils.c (long_to_string): Renamed from prnum().
641 1998-04-16 Hrvoje Niksic <hniksic@srce.hr>
643 * version.c: Wget 1.5-b17 is released.
645 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
647 * headers.c (header_get): New argument FLAGS.
649 * http.c (gethttp): If request is malformed, bail out of the
651 (gethttp): Check for empty header *after* the status line checks.
652 (gethttp): Disallow continuations for status line.
654 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
656 * version.c: Wget 1.5-b16 is released.
658 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
660 * init.c (commands): Renamed `always_rest' to `continue'.
662 1998-04-05 Hrvoje Niksic <hniksic@srce.hr>
666 * log.c (logputs): New argument.
670 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
672 * http.c (http_atotm): Update comment.
674 * main.c (i18n_initialize): Set LC_MESSAGES, not LC_ALL.
676 * wget.h: Renamed ENABLED_NLS to HAVE_NLS.
678 * main.c (i18n_initialize): New function.
681 * log.c: Include <unistd.h>.
683 * retr.c (show_progress): Cast alloca to char *.
685 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
687 * version.c: Wget 1.5-b15 is released.
689 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
691 * utils.h: Declare file_non_directory_p().
693 1998-04-03 Hrvoje Niksic <hniksic@srce.hr>
695 * main.c (main): It's `tries', not `numtries' now.
697 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
699 * init.c (getperms): Removed.
701 1998-04-01 Tim Charron <tcharron@interlog.com>
703 * log.c (logvprintf): Don't use ARGS twice.
705 1998-04-01 John <john@futuresguide.com>
707 * mswindows.c: Cleaned up.
709 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
711 * version.c: Wget 1.5-b14 is released.
713 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
715 * ftp-opie.c (STRLEN4): New macro.
718 1998-04-01 Junio Hamano <junio@twinsun.com>
720 * http.c: Document all the Digest functions.
722 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
724 * utils.c (file_non_directory_p): Renamed from isfile().
726 * mswindows.h (S_ISREG): New macro, suggested by Tim Adam.
728 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
730 * utils.c (mkdirhier): Use 0777 instead of opt.dirmode.
732 * init.c (cmd_spec_dotstyle): Use 48 dots per line for binary
734 (cmd_permissions): Removed.
736 * config.h.in: Add template for WORDS_BIGENDIAN.
738 1998-03-31 Junio Hamano <junio@twinsun.com>
740 * http.c (HEXD2asc): New macro.
743 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
745 * version.c: Wget 1.5-b13 is released.
747 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
749 * main.c (main): Don't try to use `com'.
751 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
753 * init.c (cmd_permissions): New function.
755 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
757 * version.c: Wget 1.5-b12 is released.
759 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
761 * init.c (commands): Renamed `numtries' to `tries'.
762 (cmd_spec_debug): Removed.
763 (home_dir): Under Windows, return `C:\' if HOME is undefined.
765 1998-03-29 Hrvoje Niksic <hniksic@srce.hr>
767 * config.h.in: Define _XOPEN_SOURCE.
769 * init.c (check_user_specified_header): New function.
770 (cmd_spec_header): Use it.
771 (cmd_spec_useragent): New function.
773 1998-03-29 Hrvoje Niksic <hniksic@srce.hr>
775 * version.c: Wget 1.5-b11 is released.
777 1998-03-28 Hrvoje Niksic <hniksic@srce.hr>
779 * wget.h: Include <libintl.h> only if NLS is enabled.
781 1998-03-26 Hrvoje Niksic <hniksic@srce.hr>
783 * options.h (struct options): Made `wait' a long.
784 (struct options): Ditto for `timeout'.
786 1998-03-19 Hrvoje Niksic <hniksic@srce.hr>
788 * utils.c (exists): Renamed to file_exists_p.
789 (file_exists_p): Use access() if available.
791 1998-03-17 Hrvoje Niksic <hniksic@srce.hr>
793 * utils.c (memfatal): Set save_log_p to 0 to avoid potential
796 * log.c: do_logging -> save_log_p.
798 * config.h.in: Added template for HAVE_VSNPRINTF.
800 1998-03-16 Hrvoje Niksic <hniksic@srce.hr>
804 * http.c: Protect declaration against non-ANSI compiler.
806 * log.c (logvprintf): Use vsnprintf() if available.
808 * getopt.c (main): Don't translate test stuff.
810 1998-03-16 Hrvoje Niksic <hniksic@srce.hr>
812 * version.c: Wget 1.5-b10 is released.
814 1998-03-11 Hrvoje Niksic <hniksic@srce.hr>
816 * ftp.c (getftp): Don't translate "CWD %s".
818 * wget.h (GCC_FORMAT_ATTR): Renamed from FORMAT_ATTR.
820 1998-03-07 Hrvoje Niksic <hniksic@srce.hr>
822 * ftp-opie.c (btoe): Use memcpy() instead of strncat().
824 * log.c (logputs): New function.
825 (logvprintf): Renamed from vlogmsg; use logputs().
827 * retr.c (show_progress): Print `[100%]' when the retrieval is
830 * init.c (run_wgetrc): Use FILE, not PATH.
831 (wgetrc_file_name): Ditto.
833 1998-03-07 Tim Adam <tma@osa.com.au>
835 * recur.c (parse_robots): Correctly reset `entries' on empty
838 1998-03-07 Hrvoje Niksic <hniksic@srce.hr>
840 * init.c (cmd_spec_debug): Use cmd_boolean().
842 1998-02-23 Hrvoje Niksic <hniksic@srce.hr>
844 * http.c (gethttp): Create proxy-authorization correctly.
846 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
850 * getopt.c: Use ANSI function definitions.
852 * ftp-opie.c: New file.
854 * options.h: Don't redefine EXTERN.
856 * init.c: Sort it correctly.
858 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
860 * version.c: Wget 1.5-b9 is released.
862 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
864 * recur.c (recursive_retrieve): Reset `first_time'.
866 * ftp.c (getftp): Added `default' clause to switches of uerr_t.
868 * rbuf.c (rbuf_peek): Simplified.
869 (rbuf_flush): Use MINVAL.
871 * wget.h (MINVAL): Moved from url.h.
873 * rbuf.h (RBUF_FD): New macro.
875 * url.c (add_url): Add to the head of the list.
877 * ftp.c (ftp_retrieve_list): Set the permissions to downloaded
879 (getftp): Set the default permissions to 0600.
881 1998-02-21 Hrvoje Niksic <hniksic@srce.hr>
883 * url.c (get_urls_html): Ditto.
884 (convert_links): Ditto.
886 * recur.c (parse_robots): Ditto.
888 * html.c (ftp_index): Ditto.
890 * ftp-ls.c (ftp_parse_unix_ls): Open file as binary.
892 * init.c (defaults): Initialize `opt' to zero via memset.
894 * http.c (digest_authentication_encode): goto considered harmful.
896 1998-02-19 Hrvoje Niksic <hniksic@srce.hr>
898 * ftp.c (delelement): Simplify and fix leak.
900 1998-02-18 Hrvoje Niksic <hniksic@srce.hr>
902 * http.c (dump_hash): Use HEXD2ASC instead of home-grown stuff.
904 * url.h (HEXD2ASC): Removed warning.
906 * init.c (comind): Use binary search.
907 (commands): Reorganized.
909 (cmd_boolean): New function.
911 (cmd_number_inf): Ditto.
914 (cmd_directory_vector): Ditto.
917 (cmd_spec_debug): Ditto.
918 (cmd_spec_dirmode): Ditto.
919 (cmd_spec_dirstruct): Ditto.
920 (cmd_spec_dotstyle): Ditto.
921 (cmd_spec_header): Ditto.
922 (cmd_spec_htmlify): Ditto.
923 (cmd_spec_mirror): Ditto.
924 (cmd_spec_outputdocument): Ditto.
925 (cmd_spec_recursive): Ditto.
926 (settime): Merged with cmd_time().
927 (setbytes): Merged with cmd_bytes().
928 (setonoff): Merged with cmd_boolean().
931 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
933 * Makefile.in (distclean): Remove `config.h'.
935 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
937 * version.c: Wget 1.5-b8 is released.
939 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
941 * http.c (digest_authentication_encode): New function.
942 (create_authorization_line): Use it.
943 (dump_hash): New function.
944 (digest_authentication_encode): Use it.
946 * fnmatch.c: Renamed from `mtch.c'.
948 1998-02-15 Karl Eichwalder <ke@suse.de>
950 * main.c (main): Tag "Written by..." string as translatable.
952 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
954 * wget.h (FREE_MAYBE): New macro.
956 * http.c (create_authorization_line): Don't use ANSI C string
957 concatenation feature.
958 (basic_authentication_encode): Use alloca() for temporary
967 * ftp-basic.c: Protect declaration against non-ANSI compiler.
969 * http.c (create_authorization_line): Cast `unsigned char *' to
970 `char *' for sprintf, to shut up the noisy Digital Unix cc.
972 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
974 * version.c: Wget 1.5-b7 is released.
976 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
978 * cmpt.c (strstr): Synched with glibc-2.0.6.
980 * ftp-basic.c (calculate_skey_response): Ditto.
981 (calculate_skey_response): Use alloca().
983 * http.c (create_authorization_line): Work with FSF's version of
986 * md5.c: New file, from GNU libc.
988 1998-02-14 Hrvoje Niksic <hniksic@srce.hr>
990 * url.h (URL_CLEANSE): Name the temporary variable more carefully.
992 1998-02-13 Hrvoje Niksic <hniksic@srce.hr>
994 * http.c (basic_authentication_encode): New function, instead of
997 1998-02-13 Junio Hamano <junio@twinsun.com>
999 * http.c: Add HTTP-DA support.
1000 * ftp-basic.c: Add Opie/S-key support.
1001 * config.h.in, Makefile.in: Add HTTP-DA and Opie/S-key support.
1002 * md5.c, md5.h: New files.
1004 1998-02-13 Hrvoje Niksic <hniksic@srce.hr>
1006 * http.c (http_process_range): Renamed from hprocrange().
1007 (http_process_range): Parse the whole header.
1009 * headers.c: New file.
1010 (header_process): New function.
1011 (header_get): Renamed from fetch_next_header.
1013 * all: Include utils.h only where necessary.
1015 * wget.h: Declare xmalloc(), xrealloc() and xstrdup() here.
1017 * wget.h: Add provisions for dmalloc.
1019 1998-02-12 Hrvoje Niksic <hniksic@srce.hr>
1021 * version.c: Wget 1.5-b6 is released.
1023 1998-02-12 Hrvoje Niksic <hniksic@srce.hr>
1025 * ftp.c (ftp_loop): Determine `filename' more precisely.
1027 * init.c (setval): Don't set `opt.quiet' if output-document is
1030 * log.c (log_init): Print to STDERR instead of STDOUT.
1031 (vlogmsg): Use STDERR by default.
1034 1998-02-11 Simon Josefsson <jas@pdc.kth.se>
1036 * host.c: Use addr_in again.
1038 1998-02-08 Karl Eichwalder <karl@suse.de>
1040 * http.c (gethttp): Fixed typo.
1042 1998-02-08 Hrvoje Niksic <hniksic@srce.hr>
1044 * version.c: Wget 1.5-b5 is released.
1046 1998-02-08 Hrvoje Niksic <hniksic@srce.hr>
1048 * retr.c (show_progress): Use it.
1050 * log.c (logflush): New function.
1052 * wget.h: Utilize __attribute__ if on gcc.
1054 1998-02-07 Hrvoje Niksic <hniksic@srce.hr>
1056 * http.c (base64_encode_line): New argument LENGTH.
1057 (BASIC_AUTHENTICATION_ENCODE): Use it.
1058 (BASIC_AUTHENTICATION_ENCODE): Take length of HEADER into account.
1060 * main.c (main): Fixed fprintf() format mismatch.
1062 1998-02-06 Hrvoje Niksic <hniksic@srce.hr>
1064 * version.c: Wget 1.5-b4 is released.
1066 1998-02-03 Simon Josefsson <jas@pdc.kth.se>
1068 * host.c: use sockaddr_in instead of addr_in.
1070 1998-02-04 Hrvoje Niksic <hniksic@srce.hr>
1072 * init.c (cleanup): Use it.
1074 * recur.c (recursive_cleanup): New function.
1076 * retr.c (retrieve_from_file): Ditto.
1078 * main.c (main): Use it.
1080 * recur.c (recursive_reset): New function.
1082 * retr.c (retrieve_from_file): Ditto.
1084 * main.c (main): Simplify call to recursive_retrieve().
1086 * recur.c (recursive_retrieve): Removed FLAGS argument.
1088 * http.c (gethttp): Changed call to iwrite().
1090 1998-02-03 Hrvoje Niksic <hniksic@srce.hr>
1092 * url.c (get_urls_html): Ditto.
1093 (free_urlpos): Ditto.
1097 * retr.c (retrieve_url): Move declaration of local variables to
1100 * url.c (urlproto): Use it.
1103 (get_urls_html): Ditto.
1105 * utils.h (ARRAY_SIZE): New macro.
1107 * url.c (proto): Moved from url.h.
1109 * url.h (URL_CLEANSE): Reformatted.
1110 (USE_PROXY_P): Renamed from USE_PROXY.
1112 * ftp-basic.c: Adjust to the new interface of iwrite().
1114 * ftp-basic.c (ftp_port): Use alloca().
1116 1998-02-03 Hrvoje Niksic <hniksic@srce.hr>
1118 * version.c: Wget 1.5-b3 is released.
1120 * host.c (ftp_getaddress): Don't print to stderr directly.
1122 * init.c (setbytes): Support `g' for gigabytes.
1123 (cmdtype): New specification CTIME.
1124 (setval): Use it with settime().
1125 (commands): Use it for WAIT and TIMEOUT.
1127 1998-02-02 Hrvoje Niksic <hniksic@srce.hr>
1129 * http.c (BASIC_AUTHENTICATION_ENCODE): New macro.
1132 * utils.c (unique_name_1): Moved from url.c.
1133 (unique_name): Ditto.
1135 * url.c (url_filename): Ditto.
1137 * log.c (redirect_output): Changed call to unique_name().
1139 * url.c (unique_name_1): Renamed from unique_name().
1140 (unique_name): Changed interface.
1142 * init.c (enum cmdid): Moved from init.h.
1144 (struct cmd): Ditto.
1146 * main.c (main): Use it.
1147 (main): Moved `--backups' to not have a short option.
1149 * options.h (struct options): New member BACKGROUND.
1151 * main.c (print_help): Rearranged.
1152 (main): New long options for -n* short options: --no-directories,
1153 --no-host-directories, --non-verbose, --no-host-lookup and
1154 --dont-remove-listing.
1156 1998-02-01 Hrvoje Niksic <hniksic@srce.hr>
1158 * main.c (main): Use log_close().
1160 * log.c: New variable LOGFP.
1162 (redirect_output): Don't open /dev/null; set LOGFP to stdin
1164 (log_close): New function.
1166 * options.h (struct options): Removed LFILE.
1168 * log.c (log_enable): Removed.
1170 * main.c (main): Use it.
1172 * log.c (log_init): New function.
1174 * url.c (get_urls_html): Removed needless assignment to BASE.
1176 * host.c (add_hlist): Don't set CMP needlessly.
1178 * utils.c (match_backwards): Ditto.
1179 (in_acclist): Ditto.
1181 * url.c (findurl): Ditto.
1183 * netrc.c (parse_netrc): Ditto.
1185 * log.c (log_dump): Ditto.
1187 * html.c (html_quote_string): Ditto.
1189 * ftp-basic.c (ftp_request): Made static.
1191 * connect.c: Made global variables static.
1193 * url.c (construct): Ditto.
1195 * init.c (init_path): Avoid assignment inside `if'-condition.
1197 * ftp.c: Don't include in.h or winsock.h.
1199 * ftp.c (ftp_loop): Use SZ.
1201 * connect.c (bindport): Cast &addrlen to int *.
1204 * init.c (initialize): Don't use SYSTEM_WGETRC unconditionally.
1206 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1208 * ftp.c (getftp): Initialize opt.ftp_pass here.
1209 (ftp_retrieve_dirs): Use alloca().
1211 * init.c (defaults): Don't initialize opt.ftp_pass.
1213 * sysdep.h (S_ISLNK): Declare for OS/2; ditto for lstat.
1214 From Ivan F. Martinez <ivanfm@ecodigit.com.br>.
1216 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1218 * recur.c (parse_robots): Check for comments more correctly.
1220 * host.c (ftp_getaddress): Use STRDUP_ALLOCA.
1221 (ftp_getaddress): Add diagnostics when reverse-lookup yields only
1224 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1226 * version.c: Wget 1.5-b2 is released.
1228 * netrc.c (NETRC_FILE_NAME): Moved from netrc.h.
1230 * utils.c (proclist): Pass FNM_PATHNAME to fnmatch().
1232 * ftp-basic.c (ftp_pasv): Avoid unnecessary casting to unsigned
1235 * log.c: Don't attempt to hide arguments from ansi2knr.
1237 * cmpt.c: Synched strptime() and mktime() with glibc-2.0.6.
1239 * ansi2knr.c: Use a later version, from fileutils-3.16l alpha.
1241 * ftp.c (getftp): Ditto.
1243 * http.c (gethttp): Use it.
1245 * retr.c (get_contents): New argument EXPECTED; pass it to
1247 (show_progress): New argument EXPECTED; use it to display
1250 * init.c (setval): Ditto.
1252 * http.c (gethttp): Ditto.
1255 * ftp.c (getftp): Ditto.
1256 (ftp_loop_internal): Ditto.
1258 * ftp-ls.c (ftp_parse_unix_ls): Use abort() instead of assert(0).
1260 * sysdep.h (CLOSE): Simplify; use DEBUGP.
1262 * netrc.c (search_netrc): Use alloca().
1264 * init.c (defaults): Initialize no_flush.
1266 * log.c (vlogmsg): Don't flush if no_flush.
1268 * options.h (struct options): New variable no_flush.
1270 * main.c (main): Don't play games with buffering.
1272 * log.c (vlogmsg): Flush the output after every message.
1274 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1276 * init.c (parse_line): Ditto.
1278 * url.c (get_urls_html): Ditto.
1280 * main.c (main): Don't cast to unsigned char.
1282 * init.c (run_wgetrc): Don't cast to unsigned char.
1283 (parse_line): Accept char instead of unsigned char.
1285 * html.c (htmlfindurl): Use char instead of unsigned char.
1289 * sysdep.h: Add wrappers to ctype macros to make them
1292 1998-01-30 Hrvoje Niksic <hniksic@srce.hr>
1294 * html.c (htmlfindurl): Download <img lowsrc=...>
1296 * main.c (main): Ignore SIGPIPE.
1298 * connect.c (select_fd): New argument WRITEP.
1299 (iwrite): Call select_fd().
1301 1997-02-27 Fila Kolodny <fila@ibi.com>
1303 * ftp.c (ftp_retrieve_list): If retrieving symlink and the proper
1304 one already exists, just skip it.
1306 1998-01-30 Hrvoje Niksic <hniksic@srce.hr>
1308 * http.c (gethttp): Cosmetic changes.
1310 * http.c (check_end): Allow `+D...' instead of `GMT'.
1311 From Fabrizio Pollastri <pollastri@cstv.to.cnr.it>.
1313 * url.c (process_ftp_type): New function.
1316 * connect.c (iwrite): Allow writing in a few chunks.
1317 (bindport): Made SRV static, so addr can point to it.
1318 (select_fd): Removed HPUX kludge.
1320 * host.c (free_hlist): Incorporated into clean_hosts().
1322 1998-01-29 Hrvoje Niksic <hniksic@srce.hr>
1324 * host.c (hlist): Made static.
1325 (search_address): Cosmetic change.
1327 1998-01-29 Hrvoje Niksic <hniksic@srce.hr>
1329 * version.c: Wget v1.5-b1 is released.
1331 * http.c (hgetlen): Use sizeof() to get the header length.
1334 (hgetlocation): Ditto.
1335 (hgetmodified): Ditto.
1336 (haccepts_none): Ditto.
1338 * main.c (main): Updated `--version' and `--help' output, as per
1339 Francois Pinard's suggestions.
1341 * main.c: Include locale.h; call setlocale(), bindtextdomain() and
1344 * config.h.in: Define stubs for I18N3.
1346 * wget.h: Include libintl.h.
1348 1998-01-28 Hrvoje Niksic <hniksic@srce.hr>
1350 * url.c (mkstruct): Check for opt.cut_dirs.
1351 (mkstruct): alloca()-te more, xmalloc() less.
1353 * utils.c (load_file): Check for ferror().
1355 * url.c (get_urls_file): Close only the files we opened.
1356 (get_urls_html): Ditto.
1357 (count_slashes): New function.
1361 * http.c (gethttp): Respect username and password provided by
1363 (base64_encode_line): Write into an existing buffer instead of
1364 malloc-ing a new one.
1365 (struct http_stat): Moved from http.h
1367 * retr.c (retrieve_url): Free SUF.
1369 * all: Removed lots of unnecessary .h dependencies.
1371 * html.c (global_state): Made static.
1373 * utils.h (ALLOCA_ARRAY): New macro.
1375 * main.c (main): New option `--cut-dirs'.
1377 * url.c (construct): Use alloca() for T.
1379 * utils.c (mkdirhier): Use STRDUP_ALLOCA.
1381 * host.c (_host_t): Moved from host.h.
1382 (struct host): Renamed from _host_t.
1383 (store_hostaddress): Use STRDUP_ALLOCA for INET_S.
1386 * host.h: Don't include url.h.
1388 * ftp.c (LIST_FILENAME): Moved from ftp.h.
1390 * init.c (DEFAULT_FTP_ACCT): Moved from ftp.h.
1392 * main.c (main): Enable log if the output goes to a TTY.
1394 * connect.h: Removed unused constant `BACKLOG'.
1396 * config.h.in: Check for isatty().
1398 * Makefile.in (LINK): Use CFLAGS when linking.
1400 1998-01-27 Hrvoje Niksic <hniksic@srce.hr>
1402 * mswindows.c (ws_hangup): Use redirect_output().
1404 * main.c (redirect_output_signal): New function; use
1407 * log.c (redirect_output): New function, based on hangup(), which
1410 * log.c (vlogmsg): New function.
1412 * wget.h (DEBUGP): Use debug_logmsg().
1414 * main.c (hangup): Use it.
1416 * log.c (log_dump): New function.
1418 * utils.h (DO_REALLOC): Use `long' for various sizes.
1420 * http.c (hskip_lws): Use `while', for clarity.
1421 (HTTP_DYNAMIC_LINE_BUFFER): New constant.
1422 (fetch_next_header): Use it instead of DYNAMIC_LINE_BUFFER.
1424 * ftp-basic.c (FTP_DYNAMIC_LINE_BUFFER): New constant.
1425 (ftp_response): Use it instead of DYNAMIC_LINE_BUFFER.
1427 * utils.c (DYNAMIC_LINE_BUFFER): Moved from utils.c.
1428 (LEGIBLE_SEPARATOR): Ditto.
1429 (FILE_BUFFER_SIZE): Ditto.
1431 * retr.c (BUFFER_SIZE): Moved from retr.h.
1434 (logmsg): Moved from utils.c.
1435 (debug_logmsg): New function.
1437 * mswindows.h: Include it here.
1441 * utils.c: Don't include <windows.h>.
1443 1998-01-25 Hrvoje Niksic <hniksic@srce.hr>
1445 * host.c (ftp_getaddress): Ditto.
1447 * main.c (main): Use it.
1449 * utils.h (STRDUP_ALLOCA): New macro.
1451 * init.c: Prepend `wget: ' to error messages printed on stderr.
1453 * utils.c (mkdirhier): Renamed from mymkdir.
1454 (touch): Renamed from my_touch.
1455 (pwd_cuserid): Renamed from my_cuserid().
1457 1998-01-24 Andy Eskilsson <andy.eskilsson@telelogic.se>
1459 * utils.c (accdir): Process wildcards.
1460 (proclist): New function.
1461 (accdir): Use it to avoid code repetition.
1463 1998-01-24 Hrvoje Niksic <hniksic@srce.hr>
1465 * recur.c (parse_robots): Respect opt.useragent; use alloca().
1467 * http.c (gethttp): Construct useragent accordingly.
1469 * version.c: Changed version string to numbers-only.
1471 * main.c (print_help): List all the options.
1473 * mswindows.c (windows_main_junk): Initialize argv0 here.
1475 1998-01-24 Karl Heuer <kwzh@gnu.org>
1477 * netrc.c (search_netrc): Initialize `l' only after processing
1480 * main.c (main): Don't trap SIGHUP if it's being ignored.
1482 1998-01-24 Hrvoje Niksic <hniksic@srce.hr>
1484 * all: Use logmsg().
1486 * utils.c (time_str): Moved from retr.c.
1487 (logmsg): New function.
1488 (logmsg_noflush): Ditto.
1490 * rbuf.c: New file, moved buf_* functions here.
1492 * ftp.c (ftp_expected_bytes): Moved from ftp-basic.c.
1494 * ftp-basic.c (ftp_rest): Use prnum().
1496 * ftp-basic.c: Ditto.
1498 * ftp.c: Use the new reading functions and macros.
1500 * retr.c (buf_initialize): New function.
1501 (buf_initialized_p): Ditto.
1502 (buf_uninitialize): Ditto.
1505 * http.c (fetch_next_header): Use the BUF_READCHAR macro for
1507 (gethttp): Use alloca() where appropriate.
1509 * retr.c (buf_readchar): Use it.
1510 (buf_peek): Use rstreams.
1512 * retr.h (BUF_READCHAR): New macro.
1514 * init.c (home_dir): Rewritten for clarity.
1517 * mswindows.c (ws_backgnd): Made static.
1518 (read_registry): Ditto.
1519 (ws_cleanup): Ditto.
1520 (ws_handler): Ditto.
1522 1998-01-23 Hrvoje Niksic <hniksic@srce.hr>
1524 * alloca.c: New file.
1526 * Makefile.in (ALLOCA): Define.
1528 * mswindows.c (ws_help): Constify.
1529 (ws_help): Use alloca.
1531 * mswindows.c: Reformat.
1533 * all: Added _(...) annotations for I18N snarfing and translation.
1535 * host.c (ftp_getaddress): Nuke SYSINFO.
1536 (ftp_getaddress): Don't use getdomainname().
1537 (ftp_getaddress): Use uname(), where available.
1539 * http.c (gethttp): Protect a stray fprintf().
1541 * init.c (settime): New function.
1542 (setval): Treat WAIT specially, allowing suffixes like `m' for
1545 1998-01-21 Hrvoje Niksic <hniksic@srce.hr>
1547 * url.c (get_urls_html): Use alloca() for TEMP.
1549 1998-01-21 Jordan Mendelson <jordy@wserv.com>
1551 * url.c (rotate_backups): New function.
1553 * http.c (gethttp): Ditto.
1555 * ftp.c (getftp): Rotate backups.
1557 1997-12-18 Hrvoje Niksic <hniksic@srce.hr>
1559 * all: Renamed nmalloc(), nrealloc() and nstrdup() to xmalloc(),
1560 xrealloc() and xstrdup(). Use the new functions.
1562 * url.c (decode_string): Made static.
1565 (parse_uname): Ditto.
1568 (construct_relative): Ditto.
1570 * retr.c (show_progress): Made static.
1572 * recur.c (robots_url): Made static.
1573 (retrieve_robots): Ditto.
1574 (parse_robots): Ditto.
1575 (robots_match): Ditto.
1579 * main.c (printhelp): Made static.
1582 * init.c (comind): Made static.
1585 (run_wgetrc): Ditto.
1593 * http.c (fetch_next_header): Made static.
1594 (hparsestatline): Ditto.
1599 (hgetlocation): Ditto.
1600 (hgetmodified): Ditto.
1601 (haccepts_none): Ditto.
1603 (base64_encode_line): Ditto.
1604 (mktime_from_utc): Ditto.
1605 (http_atotm): Ditto.
1607 * html.c (idmatch): Made static.
1609 * host.c (search_host): Made static.
1610 (search_address): Ditto.
1611 (free_hlist): Ditto.
1613 * ftp.c (getftp): Made static.
1614 (ftp_loop_internal): Ditto.
1615 (ftp_get_listing): Ditto.
1616 (ftp_retrieve_list): Ditto.
1617 (ftp_retrieve_dirs): Ditto.
1618 (ftp_retrieve_glob): Ditto.
1619 (freefileinfo): Ditto.
1620 (delelement): Ditto.
1622 * ftp-ls.c (symperms): Made static.
1623 (ftp_parse_unix_ls): Ditto.
1625 * connect.c (select_fd): Made static.
1627 * utils.c (xmalloc): Renamed from nmalloc.
1628 (xrealloc): Renamed from nrealloc.
1629 (xstrdup): Renamed from nstrdup.
1631 * getopt.c (exchange): Use alloca.
1633 * mswindows.c (mycuserid): Use strncpy.
1635 * New files mswindows.c, mswindows.h, sysdep.h. winjunk.c,
1636 systhings.h, windecl.h and winjunk.h removed.
1638 * mswindows.c (sleep): New function.
1640 * utils.c: Include <windows.h> under Windows.
1642 1997-06-12 Darko Budor <dbudor@zesoi.fer.hr>
1644 * url.h (URL_UNSAFE): Change default under Windows.
1646 * retr.c (retrieve_from_file): Respect opt.delete_after.
1648 * main.c (main): Call ws_help on Windows.
1650 * winjunk.c (windows_main_junk): New function.
1652 * main.c (main): Junk-process argv[0].
1654 * http.c (mktime_from_utc): Return -1 if mktime failed.
1656 * http.c (http_loop): Ditto.
1658 * ftp.c (ftp_loop_internal): Change title on Windows when using a
1661 * winjunk.c (getdomainname): Lots of functions.
1663 1997-06-12 Hrvoje Niksic <hniksic@srce.hr>
1665 * cmpt.c (strptime_internal): Handle years more correctly for
1668 1997-06-09 Mike Thomas <mthomas@reality.ctron.com>
1670 * http.c (gethttp): Allocate enough space for
1671 `Proxy-Authorization' header.
1673 1997-05-10 Hrvoje Niksic <hniksic@srce.hr>
1675 * version.c: Wget/1.4.5 is released.
1677 1997-05-10 Hrvoje Niksic <hniksic@srce.hr>
1679 * retr.c (get_contents): Check return value of fwrite more
1682 1997-03-30 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1684 * cmpt.c (strptime_internal) [case 'Y']: Always subtract 1900 from
1685 year, regardless of century.
1687 1997-03-30 Hrvoje Niksic <hniksic@srce.hr>
1689 * utils.c (isfile): Use `lstat' instead of `stat'.
1691 1997-03-29 Hrvoje Niksic <hniksic@srce.hr>
1693 * utils.c (numdigit): Use explicit test.
1695 1997-03-21 Hrvoje Niksic <hniksic@srce.hr>
1697 * http.c (http_loop): Always use `url_filename' to get u->local.
1699 1997-03-20 Hrvoje Niksic <hniksic@srce.hr>
1701 * url.c: Recognize https.
1703 1997-03-13 Hrvoje Niksic <hniksic@srce.hr>
1705 * recur.c (recursive_retrieve): Lowercase just the host name.
1707 1997-03-09 Hrvoje Niksic <hniksic@srce.hr>
1709 * url.c (get_urls_file): Use the correct test.
1710 (get_urls_html): Ditto.
1712 1997-03-07 Hrvoje Niksic <hniksic@srce.hr>
1714 * connect.c: Reverted addrlen to int.
1716 * init.c (parse_line): Check for -1 instead of NONE.
1718 * version.c: Changed version to 1.4.5.
1720 1997-02-17 Hrvoje Niksic <hniksic@srce.hr>
1722 * init.c: New option netrc.
1723 (initialize): Don't parse .netrc.
1725 * cmpt.c (recursive): Return rp.
1726 (strptime_internal): Match the long strings first, the abbreviated
1729 1997-02-16 Hrvoje Niksic <hniksic@srce.hr>
1731 * http.c (check_end): New function.
1732 (http_atotm): Use it.
1734 1997-02-13 gilles Cedoc <gilles@cedocar.fr>
1736 * http.c (gethttp): Use them.
1738 * init.c: New options proxy_user and proxy_passwd.
1740 1997-02-14 Hrvoje Niksic <hniksic@srce.hr>
1742 * ftp.c (ftp_retrieve_list): Create links even if not relative.
1744 1997-02-10 Hrvoje Niksic <hniksic@srce.hr>
1746 * recur.c (recursive_retrieve): Lowercase the host name, if the
1747 URL is not "optimized".
1749 * host.c (realhost): Return l->hostname, even if it matches with
1752 1997-02-10 Marin Purgar <pmc@asgard.hr>
1754 * connect.c: Make addrlen size_t instead of int.
1757 1997-02-09 Gregor Hoffleit <flight@mathi.uni-heidelberg.DE>
1759 * systhings.h: Define S_ISLNK on NeXT too.
1761 1997-02-09 Hrvoje Niksic <hniksic@srce.hr>
1763 * version.c: Released 1.4.3.
1765 * url.c: Futher update to list of protostrings.
1766 (skip_proto): Skip `//' correctly for FTP and HTTP.
1768 * url.c (get_urls_html): Handle bogus `http:' things a little
1771 * main.c (main): Removed `follow-ftp' from `f'.
1772 (main): Dumped the `prefix-files' and `file-prefix' options and
1773 features; old and bogus.
1774 (main): Exit on failed setval() in `-e'.
1776 * http.c (fetch_next_header): Use it to detect header continuation
1779 * retr.c (buf_peek): New function.
1781 1997-02-08 Hrvoje Niksic <hniksic@srce.hr>
1783 * wget.h: Include time.h and stuff.
1785 1997-02-08 Roger Beeman <beeman@cisco.com>
1787 * ftp.c: Include <time.h>
1789 1997-02-07 Hrvoje Niksic <hniksic@srce.hr>
1791 * url.c (findurl): Would read over buffer limits.
1793 1997-02-06 Hrvoje Niksic <hniksic@srce.hr>
1795 * ftp-ls.c (ftp_parse_unix_ls): Allow spaces in file names.
1797 1997-02-05 Hrvoje Niksic <hniksic@srce.hr>
1799 * http.c (http_atotm): Initialize tm.is_dst.
1801 1997-02-02 Hrvoje Niksic <hniksic@srce.hr>
1803 * http.c (gethttp): Don't print the number of retrieved headers.
1805 * main.c (main): New option `--no-clobber', alias for `-nc'.
1807 * url.c: Recognize `https://'.
1809 1997-02-01 Hrvoje Niksic <hniksic@srce.hr>
1811 * host.c (herrmsg): Don't use h_errno.
1813 1997-01-30 Hrvoje Niksic <hniksic@srce.hr>
1815 * host.c (accept_domain): Use it.
1817 * main.c (main): New option `--exclude-domains'.
1819 * retr.c (retrieve_url): Use it.
1820 (retrieve_url): Bail out when an URL is redirecting to itself.
1822 * url.c (url_equal): New function.
1824 1997-01-29 Hrvoje Niksic <hniksic@srce.hr>
1826 * connect.c: Include arpa/inet.h instead of arpa/nameser.h.
1828 * http.c (mk_utc_time): New function.
1829 (http_atotm): Use it; handle time zones correctly.
1831 1997-01-28 Hrvoje Niksic <hniksic@srce.hr>
1835 * ftp-basic.c: Use it instead of WRITE.
1837 * connect.c (iwrite): New function.
1839 1997-01-27 Hrvoje Niksic <hniksic@srce.hr>
1841 * cmpt.c (mktime): New function.
1843 * netrc.c: Include <sys/types.h>.
1845 * main.c (main): Wouldn't recognize --spider.
1847 * retr.c (rate): Use `B', `KB' and `MB'.
1848 (reset_timer,elapsed_time): Moved from utils.c.
1850 * ftp.c (ftp_retrieve_list): Ditto.
1852 * http.c (http_loop): Don't touch the file if opt.dfp.
1854 1997-01-24 Hrvoje Niksic <hniksic@srce.hr>
1858 * ftp.c (ftp_retrieve_glob): New argument semantics.
1859 (ftp_retrieve_dirs): Use it.
1862 * html.c (htmlfindurl): Recognize `'' as the quote char.
1864 1997-01-23 Hrvoje Niksic <hniksic@srce.hr>
1866 * ftp.c (ftp_loop_internal): Use it.
1868 * utils.c (remove_link): New function.
1870 1997-01-22 Hrvoje Niksic <hniksic@srce.hr>
1872 * retr.c (retrieve_url): Require STRICT redirection URL.
1874 * url.c (parseurl): New argument STRICT.
1876 * http.c (hparsestatline): Be a little-bit less strict about
1879 1997-01-21 Hrvoje Niksic <hniksic@srce.hr>
1881 * http.c (gethttp): Use it.
1883 * main.c (main): Don't use '<digit>' as options.
1885 * init.c: New option ignore_length.
1887 * http.c (gethttp): Ditto.
1888 (http_loop): Check for redirection without Location:.
1889 (gethttp): Don't print Length unless RETROKF.
1891 * ftp.c (getftp): Use it.
1893 * url.c (mkalldirs): New function.
1895 * utils.c (mymkdir): Don't check for existing non-directory.
1897 * url.c (mkstruct): Don't create the directory.
1899 1997-01-20 Hrvoje Niksic <hniksic@srce.hr>
1901 * init.c (setval): Removed NO_RECURSION checks.
1903 1997-01-19 Hrvoje Niksic <hniksic@srce.hr>
1905 * version.c: "Released" 1.4.3-pre2.
1907 * recur.c (recursive_retrieve): Bypass host checking only if URL
1908 is ftp AND parent URL is not ftp.
1910 * ftp-basic.c (ftp_request): Print out Turtle Power.
1912 * ftp.c (ftp_loop): Call ftp_retrieve_glob with 0 if there's no
1914 (ftp_retrieve_glob): Call ftp_loop_internal even on empty list, if
1917 * http.c (gethttp): Be a little bit smarter about status codes.
1919 * recur.c (recursive_retrieve): Always reset opt.recursive when
1922 1997-01-18 Hrvoje Niksic <hniksic@srce.hr>
1924 * retr.c (retrieve_url): New variable location_changed; use it for
1925 tests instead of mynewloc.
1926 (retrieve_url): Allow heuristic adding of html.
1928 * url.c (url_filename): Don't use the `%' in Windows file names.
1930 * http.c (http_loop): Always time-stamp the local file.
1932 * http.c (http_loop): Ditto.
1934 * ftp.c (ftp_retrieve_list): Use it.
1936 * utils.c (my_touch): New function.
1938 * ftp.c (ftp_retrieve_list): Use #ifdef HAVE_STRUCT_UTIMBUF
1939 instead of #ifndef NeXT.
1941 * utils.c (strptime): New version, by Ulrich Drepper.
1943 1997-01-17 Hrvoje Niksic <hniksic@srce.hr>
1945 * http.c (haccepts_none): Renamed from `haccepts_bytes'.
1946 (gethttp): If haccepts_none(), disable ACCEPTRANGES.
1947 (http_loop): Would remove ACCEPTRANGES.
1949 * ftp.c (getftp): Call ftp_list with NULL.
1951 1997-01-15 Hrvoje Niksic <hniksic@srce.hr>
1953 * html.c (ftp_index): Don't print minutes and seconds if we don't
1954 know them; beautify the output.
1956 * ftp.c (getftp): Don't close the socket on FTPNSFOD.
1958 1997-01-14 Hrvoje Niksic <hniksic@srce.hr>
1960 * utils.c (strptime): New function.
1961 (strptime): Don't use get_alt_number.
1962 (strptime): Don't use locale.
1963 (match_string): Made it a function.
1965 1997-01-12 Hrvoje Niksic <hniksic@srce.hr>
1967 * http.c (http_atotm): New function.
1968 (http_loop): Use it.
1970 * atotm.c: Removed from the distribution.
1972 * http.c (base64_encode_line): Rewrite.
1974 1997-01-09 Hrvoje Niksic <hniksic@srce.hr>
1976 * ftp.c (getftp): Use ftp_expected_bytes; print size.
1978 * ftp-basic.c (ftp_response): Use ftp_last_respline.
1979 (ftp_expected_bytes): New function.
1981 * ftp.c (getftp): Print the unauthoritative file length.
1983 * ftp-ls.c: Renamed from ftp-unix.c.
1984 (ftp_parse_ls): Moved from ftp.c.
1985 (ftp_parse_unix_ls): Recognize seconds in time spec.
1986 (ftp_parse_unix_ls): Recognize year-less dates of the previous
1989 1997-01-08 Hrvoje Niksic <hniksic@srce.hr>
1991 * ftp-basic.c: Don't declare errno if #defined.
1993 * host.c (ftp_getaddress): Check for sysinfo legally.
1995 1997-01-08 Darko Budor <dbudor@diana.zems.fer.hr>
1997 * connect.c (iread): Use READ.
1999 1996-12-23 Hrvoje Niksic <hniksic@srce.hr>
2001 * url.c: Recognize finger, rlogin, tn3270, mid and cid as valid
2004 1996-12-22 Hrvoje Niksic <hniksic@srce.hr>
2006 * host.c (ftp_getaddress): Allow `.' in hostname.
2008 1996-12-26 Darko Budor <dbudor@zems.fer.hr>
2010 * wget.h: READ and WRITE macros for use instead of read and write
2011 on sockets, grep READ *.c, grep WRITE *.c
2013 * wsstartup.c: new file - startup for winsock
2015 * wsstartup.h: new file
2017 * win32decl.h: new file - fixup for <errno.h> and winsock trouble
2019 * configure.bat: Configure utility for MSVC
2021 * src/Makefile.ms,config.h.ms: new files for use with MSVC 4.x
2023 1996-12-22 Hrvoje Niksic <hniksic@srce.hr>
2025 * version.c: Released 1.4.3-pre.
2027 * utils.c (prnum): Accept long.
2028 (legible): Use prnum().
2030 * connect.c (make_connection): Accept port as short.
2033 * http.c (gethttp): Use search_netrc.
2035 1996-12-21 Hrvoje Niksic <hniksic@srce.hr>
2037 * ftp.c (getftp): Use search_netrc.
2039 * netrc.c (free_netrc): New function.
2041 * init.c (home_dir): New function.
2043 * url.c (convert_links): Allow REL2ABS changes.
2045 1996-12-21 Gordon Matzigkeit <gord@gnu.ai.mit.edu>
2047 * netrc.c: New file.
2048 (parse_netrc, maybe_add_to_list): New functions.
2050 1996-12-17 Hrvoje Niksic <hniksic@srce.hr>
2052 * retr.c (retrieve_url): Reset opt.recursion before calling
2053 ftp_loop if it is reached through newloc.
2055 * init.c (run_wgetrc): Print the wgetrc path too, when reporting
2056 error; don't use "Syntax error", since we don't know if it is
2057 really a syntax error.
2059 1996-12-16 Hrvoje Niksic <hniksic@srce.hr>
2061 * utils.c (acceptable): Extract the filename part of the path.
2063 * recur.c (recursive_retrieve): Call acceptable() with the right
2064 argument; would bug out on wildcards.
2066 * init.c (parse_line): Likewise.
2068 * html.c (htmlfindurl): Cast to char * when calling stuff.
2070 1996-12-15 Hrvoje Niksic <hniksic@srce.hr>
2072 * ftp.c (getftp): Use ftp_pasv.
2074 * ftp-basic.c (ftp_request): Accept NULL value.
2075 (ftp_pasv): New function.
2077 * options.h (struct options): Add passive FTP option.
2079 1996-12-15 Hrvoje Niksic <hniksic@srce.hr>
2081 * url.c (parseurl): Debug output.
2083 * utils.c (path_simplify): New one, adapted from bash's
2084 canonicalize_pathname().
2086 1996-12-14 Hrvoje Niksic <hniksic@srce.hr>
2088 * ftp.c (getftp): Don't discard the buffer.
2090 * retr.c (get_contents): New parameter nobuf.
2092 1996-12-13 Shawn McHorse <riffraff@txdirect.net>
2094 * html.c (htmlfindurl): Recognize <meta contents="d; URL=...".
2096 * init.c (setval): Strip the trailing slashes on CVECDIR.
2098 1996-12-13 Hrvoje Niksic <hniksic@srce.hr>
2100 * init.c: Make excludes and includes under CVECDIR instead of
2103 1996-12-13 Shawn McHorse <riffraff@txdirect.net>
2105 * url.c (get_urls_html): Skip "http:".
2107 1996-12-13 Hrvoje Niksic <hniksic@srce.hr>
2109 * utils.c (strcasecmp): From glibc.
2110 (strncasecmp): Also.
2113 * url.c: Added javascript: to the list of URLs prefixes.
2115 1996-12-12 Shawn McHorse <riffraff@txdirect.net>
2117 * recur.c (retrieve_robots): Print the warning message only if
2120 1996-12-12 Gregor Hoffleit <flight@mathi.uni-heidelberg.DE>
2122 * ftp.c (ftp_retrieve_list): Use NeXT old utime interface.
2124 1996-12-12 Hrvoje Niksic <hniksic@srce.hr>
2126 * systhings.h: New file.
2128 * ../configure.in: Check for utime.h
2130 * ftp.c: Check whether we have unistd.h.
2132 1996-11-27 Hrvoje Niksic <hniksic@srce.hr>
2134 * recur.c (recursive_retrieve): Send the canonical URL as referer.
2135 (recursive_retrieve): Call get_urls_html with the canonical URL.
2137 1996-12-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2139 * (configure.in, config.h.in, src/Makefile.in, src/*.[ch]): Add
2140 ansi2knr support for compilers which don't support ANSI style
2141 function prototypes and signatures.
2143 * (aclocal.m4, src/ansi2knr.c, src/ansi2knr.1): New files.
2145 1996-11-26 Hrvoje Niksic <hniksic@srce.hr>
2147 * url.c: Use it; Recognize paths ending with "." and ".." as
2149 (url_filename): Append .n whenever file exists and could be a
2152 * url.h (ISDDOT): New macro.
2154 * init.c (parse_line): Use unsigned char.
2156 * url.c (get_urls_html): Cast to unsigned char * when calling
2159 * html.c (htmlfindurl): Use unsigned char.
2161 * version.c: Changed version to 1.4.3.
2163 1996-11-25 Hrvoje Niksic <hniksic@srce.hr>
2165 * version.c: Released 1.4.2.
2167 * ftp.c (getftp): Simplified assertion.
2168 (ftp_loop_internal): Remove symlink before downloading.
2169 (ftp_retrieve_list): Unlink the symlink name before attempting to
2172 * options.h (struct options): Renamed print_server_response to
2175 * ftp.c (rel_constr): Removed.
2176 (ftp_retrieve_list): Don't use it.
2177 (ftp_retrieve_list): Use opt.retr_symlinks.
2179 1996-11-24 Hrvoje Niksic <hniksic@srce.hr>
2181 * main.c (main): New option retr_symlinks.
2183 * url.c (convert_links): Print verbose message.
2185 1996-11-24 Hrvoje Niksic <hniksic@srce.hr>
2187 * http.c (http_loop): Reset newloc in the beginning of function;
2188 would cause FMR in retrieve_url.
2190 1996-11-23 Hrvoje Niksic <hniksic@srce.hr>
2192 * recur.c (convert_all_links): Find the URL of each HTML document,
2193 and feed it to get_urls_html; would bug out.
2194 (convert_all_links): Check for l2 instead of dl; removed dl.
2196 * url.c (convert_links): Don't refer to freed newname.
2198 * recur.c (recursive_retrieve): Add this_url to urls_downloaded.
2200 * main.c (main): Print the OS_TYPE in the debug output, too.
2202 * recur.c (recursive_retrieve): Check for opt.delete_after.
2204 * main.c (main): New option delete-after.
2206 * init.c (setval): Cleaned up.
2208 1996-11-21 Hrvoje Niksic <hniksic@srce.hr>
2210 * Makefile.in (wget): Make `wget' the default target.
2212 * ftp.c (ftp_loop_internal): Move noclobber checking out of the
2214 (ftp_retrieve_list): Warn about non-matching sizes.
2216 * http.c (http_loop): Made -nc non-dependent on opt.recursive.
2218 * init.c (setnum): Renamed from setnuminf; New argument flags.
2221 * main.c (main): Sorted the options.
2222 (main): New option --wait.
2224 1996-11-21 Shawn McHorse <riffraff@txdirect.net>
2226 * html.c (htmlfindurl): Reset s->in_quote after getting out of
2229 1996-11-20 Hrvoje Niksic <hniksic@srce.hr>
2231 * version.c: Changed version to 1.4.2.
2233 1996-11-20 Hrvoje Niksic <hniksic@srce.hr>
2235 * version.c: Released 1.4.1.
2237 * html.c (html_quote_string): New function.
2238 (ftp_index): Use it.
2239 (htmlfindurl): A more gentle ending debug message.
2241 * ftp.c (ftp_loop): Check for opt.htmlify.
2243 * init.c: New command htmlify.
2245 * ftp.c (getftp): Nicer error messages, with `'-encapsulated
2247 (ftp_loop): Print size of index.html.
2249 * init.c (setval): Implement "styles".
2251 * main.c (main): New option dotstyle.
2253 1996-11-19 Hrvoje Niksic <hniksic@srce.hr>
2255 * ftp.c (getftp): Close the master socket in case of errors, after
2258 * connect.c (bindport): Initialize msock to -1.
2260 * ftp.c (getftp): Initialize dtsock to -1.
2262 * connect.c (closeport): Don't close sock if sock == -1.
2264 1996-11-18 Hrvoje Niksic <hniksic@srce.hr>
2266 * init.c (setnuminf): Nuked default value -- just leave unchanged.
2267 (setval): Don't send default values.
2268 (defaults): Use DEFAULT_TIMEOUT -- aaargh.
2270 * options.h (struct options): Use long for dot_bytes.
2272 * init.c (setquota): Renamed to setbytes.
2273 (setval): Use setbytes on DOTBYTES.
2275 1996-11-17 Hrvoje Niksic <hniksic@srce.hr>
2277 * ftp.c (getftp): Initialize con->dltime.
2279 * recur.c (recursive_retrieve): Use same_host instead of
2280 try_robots; simply load robots_txt whenever the host is changed.
2281 (recursive_retrieve): Free forbidden before calling parse_robots.
2283 1996-11-16 Hrvoje Niksic <hniksic@srce.hr>
2285 * retr.c (show_progress): Use them.
2287 * options.h (struct options): New options dot_bytes, dots_on_line
2290 1996-11-16 Mark Boyns <boyns@sdsu.edu>
2292 * recur.c (recursive_retrieve): Retrieve directories regardless of
2293 acc/rej rules; check for empty u->file.
2295 1996-11-14 Hrvoje Niksic <hniksic@srce.hr>
2297 * init.c (setval): Use it.
2299 * utils.c (merge_vecs): New function.
2301 * init.c (setval): Reset the list-type functions when encountering
2304 1996-11-14 Shawn McHorse <riffraff@txdirect.net>
2306 * recur.c (recursive_retrieve): Use base_url instead of this_url
2309 1996-11-14 Shawn McHorse <riffraff@txdirect.net>
2311 * html.c (htmlfindurl): Reset s->in_quote after exiting the quote.
2313 1996-11-13 Hrvoje Niksic <hniksic@srce.hr>
2315 * utils.c (sepstring): Rewrote; don't use strtok.
2317 * recur.c (recursive_retrieve): Enter assorted this_url to slist
2318 when running the first time.
2319 (retrieve_robots): Warn to ignore errors when robots are loaded.
2321 * utils.c (load_file): Moved from url.c.
2323 * http.c: Made static variables const too in h* functions.
2325 * main.c (main): Renamed --continue-ftp to --continue.
2327 * recur.c (recursive_retrieve): Use it.
2329 * utils.c (frontcmp): New function.
2331 * url.c (accdir): New function.
2333 * html.c (htmlfindurl): Recognize <area href=...>.
2335 * ftp.c (ftp_retrieve_dirs): Implemented opt.includes.
2337 * init.c (setval): Free the existing opt.excludes and
2338 opt.includes, if available.
2340 * main.c (main): New option -I.
2342 1996-11-12 Hrvoje Niksic <hniksic@srce.hr>
2344 * ftp.c (ftp_retrieve_glob): Do not weed out directories.
2346 * version.c: Changed version to 1.4.1.
2348 1996-11-11 Hrvoje Niksic <hniksic@srce.hr>
2350 * version.c: Released 1.4.0.
2352 1996-11-10 Hrvoje Niksic <hniksic@srce.hr>
2354 * main.c (main): Free com and val after parse_line.
2355 (printhelp): Reorder the listing.
2357 * http.c: More robust header parsing.
2359 * http.c: Allow any number of spaces, or no spaces, precede ':'.
2360 (hskip_lws): New function.
2361 (haccepts_bytes): New function.
2364 * init.c (setval): Check header sanity.
2365 (setval): Allow resetting of headers.
2367 1996-11-10 Hrvoje Niksic <hniksic@srce.hr>
2369 * http.c (http_loop): Don't use has_wildcards.
2371 * http.c (gethttp): Free all_headers -- would leak.
2373 * recur.c (recursive_retrieve): Initialize depth to 1 instead of
2374 0 -- this fixes a long-standing bug in -rl.
2376 1996-11-09 Hrvoje Niksic <hniksic@srce.hr>
2378 * ftp.c: Use -1 as "impossible" value for con->fd.
2380 * url.h (URL_SEPARATOR): Don't treat `*' and `+' as separators.
2382 * init.c (parse_line): Use isalpha.
2384 * ftp-unix.c: Use HAVE_UNISTD_H.
2386 * mtch.c (has_wildcards): Don't match \.
2388 * http.c (http_loop): Warn on HTTP wildcard usage.
2390 1996-11-08 Hrvoje Niksic <hniksic@srce.hr>
2392 * url.c (url_filename): Do not create numbered suffixes if
2393 opt.noclobber -- would bug out on -nc.
2395 1996-11-07 Hrvoje Niksic <hniksic@srce.hr>
2397 * recur.c (parse_robots): Don't chuck out the commands without
2398 arguments (`Disallow:<empty>' didn't work).
2399 (parse_robots): Compare versions lowercase.
2400 (parse_robots): Match on base_version, not version_string!
2401 (parse_robots): Handle comments properly.
2402 (parse_robots): Match versions in a sane way.
2404 * init.c: Print nicer error messages.
2406 * version.c: Changed version to 1.4.0.
2408 1996-11-06 Hrvoje Niksic <hniksic@srce.hr>
2410 * version.c: Released 1.4.0-test2.
2412 * init.c (run_wgetrc): Close fp.
2414 * ftp.c (ftp_retrieve_dirs): Allocate the correct length for
2417 1996-11-06 Hrvoje Niksic <hniksic@srce.hr>
2419 * init.c (setquota): Allow inf as quota specification.
2421 1996-11-05 Hrvoje Niksic <hniksic@srce.hr>
2423 * ftp.c (ftp_retrieve_dirs): Return QUOTEXC if quota exceeded.
2424 (ftp_retrieve_glob): Return QUOTEXC on quota exceeded.
2426 * main.c (main): Check for quota by comparison with downloaded
2427 stuff, not from status.
2429 * connect.c (select_fd): Should compile on HPUX without warnings now.
2431 * ftp.c (ftp_get_listing): Check whether ftp_loop_internal
2434 1996-11-04 Hrvoje Niksic <hniksic@srce.hr>
2436 * ftp.c (ftp_retrieve_glob): Print the pattern nicely.
2437 (getftp): Return FTPRETRINT on control connection error.
2439 * html.c (htmlfindurl): Recognize <embed src=...> and
2441 (ftp_index): Handle username and password correctly.
2443 * main.c (main): Made `-np' a synonim for --no-parent.
2445 1996-11-02 Hrvoje Niksic <hniksic@srce.hr>
2447 * ftp.c (ftp_loop): Check for opt.ftp_glob too before calling
2450 * version.c: Changed version to 1.4.0-test2.
2452 1996-11-02 Hrvoje Niksic <hniksic@srce.hr>
2454 * version.c: Released 1.4.0-test1.
2456 * url.c (str_url): Don't use sprintf when creating %2F-prefixed
2458 (convert_links): Removed definition of make_backup.
2460 * http.h: Removed definition of MAX_ERROR_LENGTH.
2462 * host.c (ftp_getaddress): Check for "(none)" domains.
2464 * ftp.c (ftp_retrieve_dirs): Docfix.
2466 * http.c (gethttp): Use ou->referer instead of u->referer.
2468 * retr.c (retrieve_url): Reset u to avoid freeing pointers twice;
2469 this was known to cause coredumps on Linux.
2471 * html.c (ftp_index): Cast the argument to local_time to time_t *.
2473 1996-11-01 Hrvoje Niksic <hniksic@srce.hr>
2475 * connect.c (select_fd): Use exceptfds -- once and for all.
2477 * retr.c (retrieve_from_file): Free filename after
2479 (retrieve_from_file): Send RFIRST_TIME to recursive_retrieve on
2480 first-time retrieval.
2481 (retrieve_from_file): Return uerr_t; new argument, count.
2482 (retrieve_from_file): Break on QUOTEXC.
2484 * init.c (setquota): Fixed a bug that caused rejection of
2485 non-postfixed values..
2487 1996-10-30 Hrvoje Niksic <hniksic@srce.hr>
2489 * version.c: Changed name to wget.
2491 * connect.c (iread): Smarter use of select.
2492 (select_fd): Set errno on timeout. If not timeout, return 1
2495 1996-10-29 Hrvoje Niksic <hniksic@srce.hr>
2497 * ftp.c (ftp_loop_internal): Don't use con->cmd before
2500 1996-10-26 Hrvoje Niksic <hniksic@srce.hr>
2502 * http.c (gethttp): Send correct referer when using proxy.
2503 (gethttp): Use struct urlinfo ou to access the relevant data; send
2504 correct authorization in all cases.
2506 * host.c (same_host): Use skip_uname to skip username and
2509 * url.c (skip_uname): New function.
2512 * host.c (same_host): Do not assume HTTP -- same_host should now
2513 be totally foolproof.
2515 * url.c (skip_proto): New function.
2516 (parse_uname): Use it.
2518 * http.c (gethttp): Create local user and passwd from what is
2521 * url.c (parseurl): Check for HTTP username and password too.
2523 1996-10-25 Hrvoje Niksic <hniksic@srce.hr>
2525 * config.h.in: Removed #define gethostbyname R...
2527 1996-10-22 Hrvoje Niksic <hniksic@srce.hr>
2529 * version.c: Changed version to 1.4.0-test1.
2531 1996-10-21 Hrvoje Niksic <hniksic@srce.hr>
2533 * version.c: "Released" 1.4b29.
2535 * recur.c (recursive_retrieve): Check for no_parent.
2537 * init.c (setval): Option update.
2539 * main.c (main): New option no-parent.
2541 * options.h (struct options): New variable no_parent.
2543 * recur.c (recursive_retrieve): Only files are checked for
2544 opt.accepts and opt.rejects.
2545 (recursive_retrieve): Check directories for opt.excludes.
2546 (recursive_retrieve): Make the dir absolute when checking
2549 * html.c (htmlfindurl): Recognize <applet code=...> and <script
2552 1996-10-18 Hrvoje Niksic <hniksic@srce.hr>
2554 * ftp.c (getftp): Do not line-break assert entries at all.
2555 (ftp_retrieve_dirs): docfix.
2557 * connect.c (select_fd): Use fd + 1 as nfds.
2559 * version.c: Changed version to 1.4b29.
2561 1996-10-18 Hrvoje Niksic <hniksic@srce.hr>
2563 * version.c: "Released" 1.4b28.
2565 * ftp.c (ftp_loop_internal): Check whether f->size == len and
2566 don't continue the loop if it is.
2567 (ftp_get_listing): Remove list_filename on unsuccesful loop.
2569 1996-10-17 Hrvoje Niksic <hniksic@srce.hr>
2571 * ftp.c (ftp_loop_internal): Use strcpy to initialize tmp.
2572 (getftp): Do not use multiline assert.
2574 * http.c (hparsestatline): Use mjr and mnr instead of major and
2575 minor, which don't compile on Ultrix.
2576 (http_loop): Use strcpy() to initialize tmp.
2578 * all: Geturl -> Fetch
2580 1996-10-17 Hrvoje Niksic <hniksic@srce.hr>
2582 * recur.c (parse_robots): Fixed an off-by-one bug when looking for
2585 * html.c (htmlfindurl): Fixed several possible off-by-one bugs by
2586 moving `bufsize &&' to the beginning of each check in for-loops.
2588 * recur.c (parse_robots): Close fp on exit.
2590 * url.c (mymkdir): Check for each directory before creating.
2592 1996-10-16 Hrvoje Niksic <hniksic@srce.hr>
2594 * version.c: Changed version to 1.4b28.
2596 1996-10-16 Hrvoje Niksic <hniksic@srce.hr>
2598 * version.c: "Released" 1.4b27.
2600 * init.c (parse_line): Use isspace.
2601 (parse_line): Free *com on all errors.
2603 * ftp.c (ftp_loop): Change FTPOK to RETROK before exiting.
2604 (delelement): Use next instead of f->next and prev instead of
2606 (delelement): Free the members of the deleted element.
2608 * http.c (http_loop): Do not return RETROK on code != 20x.
2610 * init.c (cleanup): Free opt.user_header.
2611 (cleanup): Free opt.domains.
2613 * url.c (freelists): Moved to cleanup().
2615 * http.c (hparsestatline): Docfix.
2617 * main.c (main): Return with error status on unsuccesful
2620 * init.c (setval): Do not remove listing when mirroring.
2622 * url.c (url_filename): Use opt.fileprefix.
2624 * ftp.c (ftp_get_listing): Use url_filename to get filename for
2627 * main.c (main): New option: -rn.
2629 1996-10-15 Hrvoje Niksic <hniksic@srce.hr>
2631 * Makefile.in (RM): Added RM = rm -f.
2633 * host.c (clean_hosts): New function.
2634 (free_hlist): Just free the list, no reset.
2636 * version.c: Changed version to 1.4b27.
2638 1996-10-13 Hrvoje Niksic <hniksic@srce.hr>
2640 * version.c: "Released" 1.4b26.
2642 * retr.c (retrieve_from_file): If call get_urls_html with
2643 opt.spider to make it silent in spider mode.
2645 * url.c (str_url): Use CLEANDUP instead of URL_CLEANSE.
2647 * url.h (CLEANDUP): New macro.
2649 * http.c (gethttp): Fixed a bug that freed location only when it
2652 * retr.c (retrieve_url): Free url if it will not be stored,
2653 i.e. newloc is NULL.
2655 * html.c (htmlfindurl): Handle exiting from quotes correctly; the
2656 old version would bug out on <a href="x#a"href="y">.
2658 * html.h (state_t): New member in_quote.
2660 * html.c (htmlfindurl): Free s->attr at the beginning of
2663 * recur.c (recursive_retrieve): Recognize RCLEANUP.
2664 (tried_robots): Make hosts a global variable.
2665 (recursive_retrieve): Free constr after URL host optimization.
2666 (tried_robots): Free urlinfo before exiting.
2668 * utils.c (free_slist): New function.
2670 * recur.c (recursive_retrieve): Use flags to add cleanup
2673 * main.c (main): Free filename after recursive_retrieve.
2675 * http.c (gethttp): Store successful responses too.
2677 1996-10-12 Hrvoje Niksic <hniksic@srce.hr>
2679 * all: Constified the whole source. This required some minor
2680 changes in many functions in url.c, possibly introducing bugs -- I
2683 * ftp-basic.c: Removed last_respline.
2685 * http.c (gethttp): Free type.
2687 * host.c (same_host): Free real1 and real2.
2689 * main.c (main): New option --spider.
2691 * retr.c (get_contents): Don't reset errno.
2693 * main.c (main): Sorted the options.
2695 * connect.c (iread): Set errno to ETIMEDOUT only if it was left
2696 uninitialized by select().
2698 * http.c (http_loop): Print the time when the connection is
2700 (gethttp): Debug-print the HTTP request.
2702 1996-10-11 Hrvoje Niksic <hniksic@srce.hr>
2704 * connect.c (iread): Do not try reading after timeout.
2706 * main.c (main): Would bug out on -T.
2708 * connect.c (select_fd): Do not use exceptfds.
2709 (iread): Set ETIMEDOUT on select_fd <= 0.
2711 * version.c: Changed version to 1.4b26.
2713 1996-10-10 Hrvoje Niksic <hniksic@srce.hr>
2715 * version.c: "Released" 1.4b25.
2717 * ftp-unix.c (ftp_parse_unix_ls): Ignore lines without file name
2720 * http.c (gethttp): Add errcode to struct hstat.
2721 (http_loop): Use it.
2723 * url.c (no_proxy_match): Simplify using char** for no_proxy.
2725 * options.h (struct options): Make opt.no_proxy a vector.
2727 * utils.c (sepstring): Use !*s instead of !strlen(s).
2729 * init.c (setval): Set opt.maxreclevel to 0 on --mirror.
2730 (getperms): Use ISODIGIT instead of isdigit.
2732 * ftp.c (getftp): Print time.
2734 * main.c (main): Use legible output of downloaded quantity.
2736 * ftp.c (getftp): Use elapsed_time().
2737 (ftp_loop_internal): Use rate().
2739 * http.c (http_loop): Add download ratio output; Use rate().
2741 * utils.c (rate): New function.
2743 1996-10-09 Hrvoje Niksic <hniksic@srce.hr>
2745 * http.c (http_loop): Use timer.
2747 * ftp.c: Split to ftp-basic.c and ftp.c
2749 * utils.c (reset_timer): New function.
2750 (elapsed_time): New function.
2752 * retr.c (show_progress): Make bytes_in_line and offs long; should
2753 work on 16-bit machines.
2755 1996-10-08 Hrvoje Niksic <hniksic@srce.hr>
2757 * url.c (in_acclist): New argument backward.
2759 * ftp.c (ftp_retrieve_glob): Use acceptable() to determine whether
2760 a file should be retrieved according to suffix.
2761 (ftp_get_listing): Check the return value of unlink; Do not call
2762 ftp_retrieve_dirs if depth reached maxreclevel.
2763 (ftp_retrieve_dirs): Check whether the directory is in
2766 * main.c (main): Print the version number at the beginning of
2768 (main): Use strrchr when creating exec_name.
2770 * ftp.c (ftp_retrieve_glob): Do not close control connection.
2772 * version.c: Changed version to 1.4b25.
2774 1996-10-07 Hrvoje Niksic <hniksic@srce.hr>
2776 * version.c: "Released" 1.4b24.
2778 * Makefile.in: Rewrite.
2780 * ftp.c (ftp_loop_internal): Likewise.
2782 * retr.c (time_str): Check for failed time().
2784 * html.c (htmlfindurl): Recognize <fig src> and <overlay src> from
2787 * retr.c (time_str): Return time_t *.
2789 * connect.c (bindport): Close msock on unsuccesful bind.
2790 (bindport): The same for getsockname and listen.
2792 * retr.c (retrieve_url): Allow any number of retries on
2795 * http.c (gethttp): Do not treat errno == 0 as timeout.
2796 (http_loop): Likewise.
2797 (http_loop): Cosmetic changes.
2799 * connect.c (iread): Set errno to ETIMEDOUT in case of timeout.
2801 * retr.c (get_contents): Reset errno.
2803 * ftp.c (getftp): Minor fixes.
2805 1996-10-06 Hrvoje Niksic <hniksic@srce.hr>
2807 * http.c: Do not use backups.
2809 * geturl.1 (WARNING): Warn that man-page could be obsolete.
2811 * getopt.c (getopt_long): Moved to getopt.c
2813 * geturl.texi: Enhanced.
2815 * main.c (main): Use it.
2817 * recur.c (convert_all_links): New function.
2819 * utils.c (add_slist): New argument flags.
2821 * recur.c (recursive_retrieve): Update a list of downloaded URLs.
2822 (parse_robots): Do not chuck out empty value fields.
2823 (parse_robots): Make yourself welcome on empty Disallow.
2825 * version.c: Changed version to 1.4b24.
2827 1996-10-06 Hrvoje Niksic <hniksic@srce.hr>
2829 * version.c: "Released" 1.4b23.
2831 * ftp.c (ftp_loop_internal): Get the time after getftp.
2833 * Makefile.in (install.info): New target.
2836 * http.c (http_loop): Fix output when doing -O.
2838 1996-10-05 Hrvoje Niksic <hniksic@srce.hr>
2840 * geturl.texi: New file.
2842 * main.c (main): Do not print the warnings and download summary if
2845 * version.c: Changed version to 1.4b23.
2847 1996-10-05 Hrvoje Niksic <hniksic@srce.hr>
2849 * "Released" 1.4b22.
2851 * atotm.c (atotm): Use True and False instead of TRUE and FALSE,
2852 to avoid redefinition warnings.
2854 * host.c (store_hostaddress): Use memcpy() to copy the address
2855 returned by inet_addr.
2857 * version.c: Changed version to 1.4b22.
2859 1996-10-04 Hrvoje Niksic <hniksic@srce.hr>
2861 * version.c: "Released" 1.4b21.
2863 * ftp-unix.c (ftp_parse_ls): Renamed to ftp_parse_unix_ls.
2865 * ftp.c (ftp_port): Use conaddr.
2866 (getftp): Print the file length.
2867 (ftp_retrieve_list): Check the stamps of plain files only.
2869 * connect.c (closeport): Do not call shutdown().
2870 (conaddr): New function.
2872 * html.c (ftp_index): Made it dfp-aware.
2874 * init.c (cleanup): New name of freemem. Close opt.dfp.
2876 * ftp.c (getftp): Use opt.dfp if it is set.
2878 * ftp-unix.c (ftp_parse_ls): Recognize time in h:mm format.
2880 * ftp.c (ftp_retrieve_dirs): Fixed a bug that caused incorrect
2881 CWDs to be sent with recursive FTP retrievals.
2883 1996-10-03 Hrvoje Niksic <hniksic@srce.hr>
2885 * recur.c (parse_robots): Made it more compliant with "official"
2888 * http.c: New function.
2890 * ftp-unix.c (ftp_parse_ls): Added better debug output.
2892 * ftp.c (getftp): Print out the LIST in case of
2893 opt.print_server_response.
2895 * version.c: Changed version to 1.4b21.
2897 1996-10-01 Hrvoje Niksic <hniksic@srce.hr>
2899 * version.c: "Released" 1.4b20.
2903 * http.c (gethttp): Preset lengths of various headers instead of
2904 calculating them dynamically.
2905 (gethttp): Check for 206 partial contents.
2907 1996-09-30 Hrvoje Niksic <hniksic@srce.hr>
2909 * configure.in: Set SYSTEM_GETURLRC to $libdir/geturlrc
2911 * http.c (gethttp): Send the port number in the Host: header.
2913 1996-09-29 Hrvoje Niksic <hniksic@srce.hr>
2915 * http.c (gethttp): Send host: header.
2916 (gethttp): Add the possibility of user-defined headers.
2917 (gethttp): Move decision about pragma: no-cache to http_loop,
2919 (gethttp): Pass a struct instead of enormous argument list.
2920 (http_loop): Use a new, fancier display format.
2921 (ftp_loop): Likewise.
2923 * main.c: (hangup): Turn off buffering of the new log file.
2925 * install-sh: Likewise.
2927 * config.sub: Replace with the one in autoconf-2.10
2931 * init.c: New options httpuser and httppasswd.
2933 * http.c: (base64_encode_line): New function.
2934 (gethttp): Send authentication.
2936 * connect.c (make_connection): Use store_hostaddress.
2938 1996-09-28 Hrvoje Niksic <hniksic@srce.hr>
2940 * host.c (store_hostaddress): New function.
2944 * http.c (hgetrange): New function.
2945 (gethttp): Use ranges.
2947 * utils.c (numdigit): Accept long instead of int.
2949 * http.c (http_loop): Add restart capabilities.
2951 * ftp.c (ftp_retrieve_glob): Fixed a bug that could cause matchres
2952 being used uninitialized.
2953 (ftp_retrieve_list): Similar fix.
2955 * host.c (add_hlist): Fixed a bug that could cause cmp being used
2958 * url.c (construct_relative): New function.
2960 * recur.c (recursive_retrieve): Use it.
2962 * retr.c (convert_links): New function.
2964 1996-09-27 Hrvoje Niksic <hniksic@srce.hr>
2966 * url.c (free_urlpos): New function.
2968 * recur.c (recursive_retrieve): Adapt.
2970 * url.c (get_urls_html): Return a linked list instead of a vector.
2972 * url.c (get_urls_file): Return a linked list instead of a vector.
2976 * http.c (gethttp): Implement it.
2978 * init.c (setval): New option: SAVEHEADERS
2980 * ftp.c (ftp_loop_internal): Do not set restval if listing is to
2981 be retrieved. Lack of this test caused bugs when the connection
2982 was lost during listing.
2984 * retr.c (retrieve_url): Fixed a bug that caused
2985 coredumps. *newloc is now reset by default.
2986 (retrieve_url): Lift the twenty-tries limit on proxies.
2988 * version.c: Changed version to 1.4b20.
2990 1996-09-20 Hrvoje Niksic <hniksic@srce.hr>
2992 * version.c: "Released" 1.4b19.
2994 1996-09-19 Hrvoje Niksic <hniksic@srce.hr>
2996 * ftp.c (ftp_loop_internal): Renamed from ftp_1fl_loop.
2997 (getftp): Changed prototype to accept ccon *.
2999 1996-09-17 Hrvoje Niksic <hniksic@srce.hr>
3001 * ftp.c (ftp_retrieve_list): Fixed a bug that caused setting
3002 incorrect values to files pointed to by symbolic links.
3003 (ftp_1fl_loop): Do not count listings among the downloaded URL-s.
3005 1996-09-16 Hrvoje Niksic <hniksic@srce.hr>
3007 * url.c (mkstruct): Do not prepend "./" in front of a pathname.
3009 * main.c (main): New option: --user-agent.
3015 * init.c (setval): Ditto.
3017 * main.c (main): Rename "server-headers" to "server-response".
3019 * ftp-unix.c (ftp_parse_ls): Check for asterisks at the end of
3020 executables in 'ls -F' listings.
3022 1996-09-15 Hrvoje Niksic <hniksic@srce.hr>
3024 * url.c (parseurl): Remove realloc() and sprintf().
3025 (str_url): Get rid of sprintf().
3027 * recur.c (recursive_retrieve): Enable FTP recursion through proxy
3030 * url.h (URL_CLEANSE): Made it else-resistant.
3031 (USE_PROXY): New macro.
3033 1996-09-14 Hrvoje Niksic <hniksic@srce.hr>
3037 * version.c: Changed version to 1.4b19.
3039 1996-09-14 Hrvoje Niksic <hniksic@srce.hr>
3041 * version.c: "Released" 1.4b18.
3043 * url.c: Made it reallocate space exponentially.
3045 1996-09-14 Drazen Kacar <dave@fly.cc.fer.hr>
3047 * html.c (htmlfindurl): Added <frame src> and <iframe src> among
3048 the list of stuff to fetch.
3050 1996-09-13 Hrvoje Niksic <hniksic@srce.hr>
3052 * url.c (get_urls_html): Fixed a bug that caused SIGSEGV's with
3055 * html.c (htmlfindurl): Rewrite.
3057 * http.c (gethttp): Use opt.proxy_cache.
3059 * main.c (main): Added --cache option.
3061 * ftp.c (ftp_response): Print server response if opt.print_server
3063 (getftp): Print newlines after each request if the server response
3065 (ftp_response): Copy the last response line to last_respline.
3067 * http.c (gethttp): Add Pragma: nocache for retried
3070 * ftp.c (getftp): Use it.
3072 * retr.c (buf_discard): New function.
3074 * ftp.c (ftp_response): Use buf_readchar().
3075 (getftp): Flush the control connection buffer before calling
3078 * retr.c (buf_readchar): New function.
3079 (buf_flush): New function.
3080 (get_contents): Use buf_readchar() instead of read(x, x, 1).
3081 (get_contents): Use buf_flush.
3083 1996-09-12 Hrvoje Niksic <hniksic@srce.hr>
3085 * ftp.c: Incorporate changes to ftp_response.
3087 * ftp.c (ftp_response): Allocate the server response dynamically,
3088 as in read_whole_line and fetch_next_header.
3090 * utils.c (read_whole_line): Fixed a bug that prevented reading
3091 the last line if it is not \n-terminated. Also fixed a possible
3094 * http.c (fetch_next_header): Return malloc-ed string as large as
3096 (gethttp): Use new fetch_next_header.
3098 1996-09-12 Hrvoje Niksic <hniksic@srce.hr>
3100 * http.c (hgetlen): Compute the header length the first time only.
3102 (hgetlocation): Ditto.
3103 (hgetmodified): Ditto.
3105 1996-09-11 Hrvoje Niksic <hniksic@srce.hr>
3107 * sample.geturlrc: Update.
3109 1996-09-10 Hrvoje Niksic <hniksic@srce.hr>
3111 * http.c (http_loop): Ditto.
3113 * ftp.c (getftp): Open the output file as binary.
3115 * version.c: Changed version to 1.4b18.
3117 1996-09-10 Hrvoje Niksic <hniksic@srce.hr>
3119 * version.c: "Released" 1.4b17.
3121 * ftp-unix.c (ftp_parse_ls): If unable to open file, return NULL
3122 instead of failed assertion.
3124 1996-09-09 Hrvoje Niksic <hniksic@srce.hr>
3126 * ftp.c (ftp_get_listing): Add a numbered suffix to LIST_FILENAME
3127 if a file of that name already exists.
3129 1996-09-05 Hrvoje Niksic <hniksic@srce.hr>
3131 * ftp.c (ftp_1fl_loop): Handler FTPPORTERR and FOPENERR correctly.
3133 * config.h.in: Define gethostbyname as Rgethostbyname when using
3136 * configure.in: Check for -lresolv if using Socks.
3138 * version.c: Changed version to 1.4b17.
3140 1996-07-15 Hrvoje Niksic <hniksic@srce.hr>
3142 * version.c: "Released" 1.4b16.
3144 * http.c (gethttp): More intelligent check for first line of HTTP
3146 (gethttp): Would bug out on time-stamping.
3148 * version.c: Changed version to 1.4b16.
3150 1996-07-11 Hrvoje Niksic <hniksic@srce.hr>
3152 * version.c: Released 1.4b15.
3154 * http.c (http_loop): Print \n after the loop entry, not before.
3156 * url.c (url_filename): Use ISDOT.
3158 * url.h (ISDOT): New macro.
3160 * recur.c (recursive_retrieve): Change only opt.recursive for
3163 1996-07-11 Antonio Rosella <antonio.rosella@agip.it>
3165 * socks/geturl.cgi: Fixed version No.
3167 * socks/download-netscape.html: Ditto.
3169 * socks/download.html: Changed socks.html to download.html.
3171 1996-07-11 Hrvoje Niksic <hniksic@srce.hr>
3173 * url.c (url_filename): Check for opt.dirstruct instead for
3174 opt.recursive && opt.dirstruct.
3176 * init.c (defaults): Ditto.
3177 (defaults): Reset dirstruct by default.
3178 (setval): Set opt.dirstruct whenever setting recursive.
3180 * init.h: Removed FORCEDIRHIER.
3182 * INSTALL: Added -L to socks-description.
3184 * version.c: Changed version to 1.4b15.
3186 1996-07-10 Hrvoje Niksic <hniksic@srce.hr>
3188 * version.c: "Released" 1.4b14.
3190 * geturl.1: Update AUTHOR to include Rosella as contributor.
3194 * socks/geturl.cgi: Simplified command creation, nuked <blink>.
3196 * socks/geturl.cgi: Wrap nutscape extensions within if $netscape.
3197 (cal_time): Fix == to eq.
3199 * socks/geturl.cgi: GPL-ized with permission of A. Rosella.
3201 * geturl.1 (hostname): Moved URL CONVENTIONS to the beginning.
3203 * Makefile.in: Use @VERSION@.
3205 * configure.in: Check version from version.c.
3207 * socks/geturl.cgi: Changed /pub/bin/perl to /usr/bin/perl.
3209 * socks/download.html: Created from download-netscape.html, made
3212 * recur.c (recursive_retrieve): Set opt.force_dir_hier when
3213 following FTP links from recursions.
3215 1996-07-09 Hrvoje Niksic <hniksic@srce.hr>
3217 * url.c (mymkdir): Fixed a bug that prevented mymkdir() to create
3218 absolute directories correctly.
3220 * version.c: Changed version to 1.4b14.
3222 1996-07-09 Hrvoje Niksic <hniksic@srce.hr>
3224 * version.c: "Released" 1.4b13.
3226 * url.c (make_backup): New function.
3228 * http.c (http_loop): Make a backup copy of the local file (using
3229 rename(2)) before opening it.
3231 * main.c (main): Added --backups.
3233 * host.c (ftp_getaddress): Bail out on failed mycuserid().
3234 (ftp_getaddress): Check for leading dot on MY_DOMAIN.
3235 (ftp_getaddress): Check for empty, null or (null) domain.
3237 * url.c (get_urls_html): If this_url is NULL, the base must have a
3239 (parseurl): Use has_proto.
3241 * retr.c (retrieve_url): Warn when proxy is used with more than 20
3244 * url.c (mkstruct): Create the directory (calling mymkdir()) only
3245 if it is not already there.
3246 (has_proto): New function.
3247 (get_urls_html): Eliminate the remaining call to findurl -- use
3252 * main.c: Change -X to -x.
3254 * url.c (url_filename): Simplify creation of filename if
3255 prefix_files is set.
3256 (url_filename): Simplify everything. And I do mean *everything*.
3257 (mkstruct): Add dir_prefix before hostname.
3258 (path_simplify): Fixed a bug that caused writing outside the path
3259 string in case of "." and ".." path strings.
3261 1996-07-06 Hrvoje Niksic <hniksic@srce.hr>
3263 * init.c: Added --mirror.
3265 * main.c (main): Added -X to force saving of directory hierarchy.
3267 * ftp.c (ftp_retrieve_list): Added recursion depth counter.
3268 (ftp_retrieve_list): Check whether quota is exceeded.
3270 * url.c (get_urls_html): Skip leading blanks for absolute URIs.
3272 * http.c (gethttp): Use referer if present.
3274 * recur.c (recursive_retrieve): Set u->referer before calling
3277 * url.c (newurl): Use memset to nullify the struct members.
3278 (freeurl): Free the referer field too.
3280 * url.h: Added referer to urlinfo.
3282 * geturl.1: Updated the manual to document some of the new features.
3284 * utils.c (numdigit): Moved from url.c.
3286 * README: Rewritten.
3288 * config.h.in: Add the support for socks.
3290 * configure.in: Add the support for socks.
3292 * url.c (url_filename): If the dir_prefix is ".", work with just
3294 (url_filename): Do not look for .n extensions if timestamping if
3297 * retr.c (show_progress): Skip the over-abundant restval data, and
3298 print the rest of it with ',' instead of '.'.
3300 1996-07-05 Hrvoje Niksic <hniksic@srce.hr>
3302 * retr.c (show_progress): Changed second arg. to long (as it
3304 (show_progress): Moved to retr.c.
3305 (get_contents): Moved to retr.c.
3307 * version.c: Change version to 1.4b13.
3309 1996-07-05 Hrvoje Lacko <hlacko@fly.cc.fer.hr>
3311 * url.c (in_acclist): Would return after the first suffix.
3313 1996-07-04 Hrvoje Niksic <hniksic@srce.hr>
3315 * version.c: "Released" 1.4b12.
3317 * url.c (path_simplify): More kludgifications.
3318 (get_urls_html): Use new parameters for htmlfindurl.
3320 * html.c: Removed memorizing "parser states", since the new
3321 organization does not require them.
3323 * init.c (run_geturlrc): Use read_whole_line.
3325 * ftp-unix.c (ftp_parse_ls): Use read_whole_line.
3327 * recur.c (parse_robots): Use read_whole_line.
3329 * utils.c (read_whole_line): New function.
3331 * recur.c (tried_robots): Use add_slist/in_slist, *much* cleaner.
3333 * host.c (ngethostbyname): Call inet_addr just once. Yet to be
3334 tested on OSF and Ultrix.
3335 (add_hlist): New function.
3336 (free_hlist): New function.
3337 (search_host): New function.
3338 (search_address): New function.
3339 (realhost): Use search_host, search_address and add_hlist.
3340 (same_host): Replaced realloc() with strdupdelim(), made
3341 case-insensitive, fixed a memory leak.
3343 * html.c (ftp_index): Fixed tm_min and tm_sec to be tm_hour and
3344 tm_min, like intended.
3346 * version.c: Change user agent information to
3349 1996-07-03 Hrvoje Niksic <hniksic@srce.hr>
3351 * utils.c: Renamed nmalloc.c to utils.c, .h likewise.
3353 * url.c (acceptable): Always accept directories.
3355 * ftp-unix.c (ftp_parse_ls): Support brain-damaged "ls -F"-loving
3356 servers by stripping trailing @ from symlinks and trailing / from
3359 * ftp.c (ftp_loop): Debugged the "enhanced" heuristics. :-)
3361 * url.c (skip_url): Use toupper instead of UCASE.
3363 * host.c (sufmatch): Made it case-insensitive.
3365 * url.c (match_backwards_or_pattern): Fixed i == -1 to j == -1.
3366 (match_backwards): New function, instead of
3367 match_backwards_or_pattern.
3369 * recur.c (recursive_retrieve): Increased performance by
3370 introducing inl, which reduces number of calls to in_slist to only
3373 * ftp.c (ftp_loop): Enhanced the heuristics that decides which
3376 * main.c (printhelp): Removed the warranty stuff.
3378 1996-07-02 Hrvoje Niksic <hniksic@srce.hr>
3380 * url.c (add_slist): Simplify.
3381 (match_backwards_or_pattern): New function.
3382 (in_acclist): Use match_backwards_or_pattern.
3385 1996-06-30 Hrvoje Niksic <hniksic@srce.hr>
3387 * ftp.c (ftp_loop): Call ftp_index on empty file names, if not
3390 * html.c (ftp_index): Fixed to work. Beautified the output.
3392 * ftp.c (ftp_retrieve_glob): Another argument to control whether
3393 globbing is to be used.
3394 (ftp_retrieve_list): Compare the time-stamps of local and remote
3395 files to determine whether to download.
3397 1996-06-29 Hrvoje Niksic <hniksic@srce.hr>
3399 * ftp.c (rel_constr): New function.
3401 * retr.c (retrieve_from_file): Check for text/html before
3402 retrieving recursively.
3404 * main.c (main): Check whether the file is HTML before going into
3405 recursive HTML retrieving.
3407 * ftp.c (ftp_retrieve_list): Manage directories.
3408 (ftp_retrieve_glob): Pass all the file-types to ftp_retrieve_list.
3409 (ftp_1fl_loop): Fixed a bug that caused con->com to be incorrectly
3410 initialized, causing bugchecks in getftp to fail.
3412 * configure.in: Check for symlink.
3414 * ftp.c (ftp_retrieve_list): Added support for symlinks.
3416 * version.c: "Released" 1.4b10.
3418 * atotm.c (atotm): Redeclared as time_t.
3420 * init.c: New variable "timestamping".
3422 * main.c (main): New option 'N'.
3424 * http.c (hgetlocation): Case-insensitive match.
3425 (hgetmodified): New function.
3426 (http_loop): Implement time-stamping.
3428 1996-06-28 Hrvoje Niksic <hniksic@srce.hr>
3430 * version.c: Changed version to 1.4b10
3432 * atotm.c: New file, from phttpd.
3434 * options.h (struct options): New parameter timestamping.
3436 * version.c: 1.4b9 "released".
3438 * recur.c (recursive_retrieve): Used linked list (ulist) for
3439 faster storing of URLs.
3441 * url.c (get_urls_html): Removed the old kludge with comparing the
3442 outputs of htmlfindurl and findurl.
3443 (get_urls_html): Added better protocol support here.
3444 (create_hash): Removed, as well as add_hash and in_hash.
3445 (addslist): New function.
3448 * version.c: Released 1.4b8, changed version to b9.
3450 1996-06-27 Hrvoje Niksic <hniksic@srce.hr>
3452 * ftp.c (freefileinfo): New function.
3453 (delelement): New function.
3457 * ftp.c (ftp_loop): Use ccon.
3458 (ftp_retrieve_glob): Likewise.
3460 * ftp.h: Define ccon, to define status of control connection.
3462 * ftp.c (ftp_get_listing): New function.
3463 (ftp_retrieve_more): New function.
3464 (ftp_retrieve_glob): New function.
3466 1996-06-25 Hrvoje Niksic <hniksic@srce.hr>
3468 * configure.in: Removed the search for cuserid().
3470 * init.c (getmode): Renamed to getperms.
3472 1996-06-24 Hrvoje Niksic <hniksic@srce.hr>
3474 * version.c: New version.
3476 * main.c (hangup): New function, that handles hangup. Hangup
3477 signal now causes geturl to stop writing on stdout, and to write
3480 * ftp.c (getftp): "Released" 1.4b7.
3482 * html.c (htmlfindurl): Ignore everything inside <head>...</head>.
3483 (ftp_index): Use fileinfo/urlinfo.
3485 * ftp-unix.c (ftp_parse_ls): New function.
3486 (symperms): New function.
3488 * ftp.c (ftp_1fl_loop): New function, to handle 1-file loops.
3490 * retr.c (retrieve_url): Added FTP support.
3492 1996-06-23 Hrvoje Niksic <hniksic@srce.hr>
3494 * geturl.h: Removed NOTFTP2HTML enum.
3495 Added DO_LOGIN, DO_CWD and DO_LIST. LIST_ONLY is obsolete.
3497 * ftp.c (getftp): Resynched with urlinfo.
3498 (getftp): Removed HMTL-ization of index.html from getftp.
3500 * version.c: 1.4b6 "released".
3502 * options.h (options): New struct, to keep options in.
3504 * http.c (http_loop,gethttp): Synched with proxy.
3506 * retr.c (retrieve_url): Implemented proxy retrieval.
3508 * main.c (main): Use retrieve_from_file.
3510 1996-06-22 Hrvoje Niksic <hniksic@srce.hr>
3512 * retr.c (retrieve_from_file): New function.
3514 * url.c (parseurl): Modified to return URLOK if all OK. Protocol
3515 can be found in u->proto.
3517 * ftp.c (ftp_response): Fixed to accept multi-line responses as
3520 * recr.c (recursive_retrieve): Take newloc from retrieve_url.
3522 * url.c (mymkdir): Removed the file of the same name, if one
3524 (isfile): New function.
3525 (mkstruct): Fixed the '/' glitches.
3526 (path_simplify): Hacked to treat something/.. correctly.
3528 1996-06-21 Hrvoje Niksic <hniksic@srce.hr>
3530 * http.c (gethttp): Close the socket after error in headers.
3531 (http_loop): HEOF no longer a fatal header.
3533 * loop.c (retrieve_url): When dt is NULL, do not modify it. This
3534 simplifies the syntax of calling retrieve_url.
3536 * recr.c (recursive_retrieve): Modified to use get_urls_html.
3538 * url.c (get_urls_file): New function.
3539 (get_urls_html): New function.
3541 * recr.c (recursive_retrieve): Patched up to conform to the
3544 * http.c (gethttp): Synched with the rest...
3545 (gethttp): Treat only CONREFUSED specially, with connection
3548 * init.c,geturl.1,http.c (http_loop): Removed kill_error.
3550 1996-06-20 Hrvoje Niksic <hniksic@srce.hr>
3552 * http.c (http_loop): New function.
3554 * loop.c: Removed *lots* of stuff from retrieve_url.
3556 * url.c (parseurl): Changed to work with urlinfo. Integrated
3557 username finding and path parsing.
3558 (newurl): New function.
3559 (freeurl): New function.
3560 (mkstruct): Removed the old bogosities, made it urlinfo-compliant.
3561 (url_filename): Likewise.
3562 (path_simplify): Accept relative paths too.
3563 (opt_url): Made urlinfo-compliant, removed bogosities.
3564 (path_simplify): Expanded to accept relative paths.
3565 (str_url): A replacement for hide_url
3566 (decode_string): Fixed a bug that caused malfunctioning when
3567 encountering an illegal %.. combination.
3568 (opt_url): Removed the argument. Dot-optimizations are now default.
3570 * nmalloc.c (strdupdelim): New function.
3572 * url.h: Added the urlinfo structure
3574 1996-06-19 Hrvoje Niksic <hniksic@srce.hr>
3576 * url.c (hide_url): Thrown out the protocol assertion. Do not
3577 change the URL if the protocol if not recognized.
3578 (findurl): Put continue instead of break.
3580 1996-06-18 Hrvoje Niksic <hniksic@srce.hr>
3582 * sample.geturlrc: Changed the defaults to be commented out and
3583 harmless (previous defaults caused pains if copied to
3586 * http.c (gethttp): Print the HTTP request in debug mode.
3588 * connect.c (iread): Added EINTR check loop to select-ing
3589 too. EINTR is now correctly handled with select().
3593 1996-05-07 Hrvoje Niksic <hniksic@srce.hr>
3595 * host.c (same_host): Made the function a little bit more
3596 intelligent regarding diversified URL syntaxes.
3598 * url.c (skip_url): Spaces are now skipped after URL:
3600 * Released 1.3.1 with the patch to prevent crashing when sending
3601 NULL to robot* functions and the patch to compile "out of the box"
3604 * recr.c (recursive_retrieve): Added checking whether this_url is
3605 NULL when calling the robot functions.
3607 * ChangeLog: New file.