1 2000-11-01 Hrvoje Niksic <hniksic@arsdigita.com>
3 * url.c (get_urls_html): Decode HTML entities using
6 * html.c (htmlfindurl): Don't count the `#' in numeric entities
7 (&#NNN;) as an HTML fragemnt.
8 (html_decode_entities): New function.
10 2000-11-01 Hrvoje Niksic <hniksic@arsdigita.com>
12 * html.c (htmlfindurl): Fix recognition of # HTML fragments.
14 2000-11-01 Hrvoje Niksic <hniksic@arsdigita.com>
16 * url.c (construct): Rewritten for clarity. Avoids the
17 unnecessary copying and stack-allocation the old version
20 2000-10-31 Hrvoje Niksic <hniksic@arsdigita.com>
22 * ftp.c (getftp): Ditto.
24 * http.c (gethttp): Rewind the stream when retrying from scratch.
26 2000-10-31 Hrvoje Niksic <hniksic@arsdigita.com>
28 * retr.c (retrieve_url): Use url_concat() to handle relative
29 redirections instead of /ad hoc/ code.
31 * url.c (url_concat): New function encapsulating weird
33 (urllen_http_hack): New function.
34 (construct): When constructing new URLs, recognize that `?' does
35 not form part of the file name in HTTP.
37 2000-10-13 Adrian Aichner <adrian@xemacs.org>
39 * retr.c: Add msec timing support for WINDOWS.
40 * retr.c (reset_timer): GetSystemTime() on WINDOWS.
41 * retr.c (elapsed_time): Calculate delta time to msec on WINDOWS.
43 2000-10-27 Dan Harkless <dan-wget@dilvish.speed.net>
45 * retr.c (retrieve_url): Manually applied T. Bharath
46 <TBharath@responsenetworks.com>'s patch to get wget to grok
47 illegal relative URL redirects. Reformatted and re-commented it.
49 2000-10-23 Dan Harkless <dan-wget@dilvish.speed.net>
51 * connect.c (make_connection and bindport): Manually applied Rob
52 Mayoff <mayoff@dqd.com>'s 1.5.3 patch to add --bind-address,
53 changing coding style to GNU's.
55 * ftp.c (ftp_loop_internal): --delete-after wasn't implemented for
56 files downloaded via FTP. Per a comment, .listing files were not
57 counted towards number of bytes and files downloaded because they're
58 deleted anyway. Well, they aren't under -nr, so count them then.
60 * init.c: Manually applied Rob Mayoff's 1.5.3 patch to add
61 --bind-address, alphabetizing, changing coding style to GNU's,
62 commenting, and renaming cmd_ip_address() to cmd_address() to
63 imply hostnames also okay.
65 * main.c (main): --delete-after didn't delete the root of the
66 tree. Ignore --convert-links if --delete-after was specified.
67 Manually applied Rob Mayoff's 1.5.3 patch to add --bind-address,
68 fixing duplicate use of added-since-1.5.3 case value.
69 (print_help): Clarified that --delete-after deletes local files.
70 Rob forgot to add a line for his new --bind-address option.
72 * options.h (struct options): Manually applied Rob Mayoff's patch
73 to add --bind-address (bind_address structure member).
75 * recur.c (recursive_retrieve): Improved comment; added DEBUGP().
76 Ignore --convert-links if --delete-after was specified.
78 * retr.c (retrieve_from_file): Just added a DEBUGP().
80 2000-10-19 Dan Harkless <dan-wget@dilvish.speed.net>
82 * ftp.c (ftp_loop_internal): downloaded_file() enumerators changed.
83 (getftp): Applied Piotr Sulecki <Piotr.Sulecki@ios.krakow.pl>'s
84 patch to work around FTP servers that incorrectly respond to the
85 "REST" command with the remaining size rather than the total file size.
87 * http.c (gethttp): Improved a comment and added code to tack on
88 ".html" to text/html files without that extension when -E specified.
89 (http_loop): Use new downloaded_file() enumerators and deal with
90 the case of gethttp() called xrealloc() on u->local.
92 * init.c (commands): Added new "htmlextension" command.
93 Also renamed John Daily's cmd_quad() to the more descriptive
94 cmd_lockable_boolean(), alpha-sorted the CMD_DECLARE()s and
95 removed duplicate cmd_boolean() declaration.
97 * main.c (print_help): Added my new -E / --html-extension option.
98 (main): Undocumented --email-address option previously used -E synonym.
99 Stole it away for the much more deserving --html-extension's use.
101 * options.h (struct options): Added html_extension field.
103 * url.c (convert_links): URL X that we saved as X.html locally due
104 to -E needs to be backed up as X.orig, not X.html.orig. Added comments.
105 (downloaded_file): Now remembers if we added .html extension to a file.
107 * url.h (downloaded_file_t): Added extra enumerators to support above.
108 (downloaded_file): Now takes and returns a downloaded_file_t.
110 * wget.h (unnamed "dt" enum): Added ADDED_HTML_EXTENSION enumerator.
112 2000-10-09 Dan Harkless <dan-wget@dilvish.speed.net>
114 * html.c (htmlfindurl): Added unneeded initialization to quiet warning.
116 * main.c (print_help): Clarified what --retr-symlinks does.
118 2000-09-15 John Daily <jdaily@cyberdude.com>
120 * init.c: Add support for "always" and "never" values to allow
121 .wgetrc to override commandline (useful e.g. with .pm files
122 calling `wget --passive-ftp' when your firewall doesn't allow that).
124 * ftp.c (getftp): passive_ftp is first option to support always/never.
126 2000-08-30 Dan Harkless <dan-wget@dilvish.speed.net>
128 * ftp.c (ftp_retrieve_list): Use new INFINITE_RECURSION #define.
130 * html.c: htmlfindurl() now takes final `dash_p_leaf_HTML' parameter.
131 Wrapped some > 80-column lines. When -p is specified and we're at a
132 leaf node, do not traverse <A>, <AREA>, or <LINK> tags other than
133 <LINK REL="stylesheet">.
135 * html.h (htmlfindurl): Now takes final `dash_p_leaf_HTML' parameter.
137 * init.c: Added new -p / --page-requisites / page_requisites option.
139 * main.c (print_help): Clarified that -l inf and -l 0 both allow
140 infinite recursion. Changed the unhelpful --mirrior description
141 to simply give the options it's equivalent to. Added new -p option.
142 (main): Added some comments; handle new -p / --page-requisites.
144 * options.h (struct options): Added new page_requisites field.
146 * recur.c: Changed "URL-s" to "URLs" and "HTML-s" to "HTMLs".
147 Calculate and pass down new `dash_p_leaf_HTML' parameter to
148 get_urls_html(). Use new INFINITE_RECURSION #define.
150 * retr.c: Changed "URL-s" to "URLs". get_urls_html() now takes
151 final `dash_p_leaf_HTML' parameter.
153 * url.c: get_urls_html() and htmlfindurl() now take final
154 `dash_p_leaf_HTML' parameter.
156 * url.h (get_urls_html): Now takes final `dash_p_leaf_HTML' parameter.
158 * wget.h: Added some comments and new INFINITE_RECURSION #define.
160 2000-08-23 Dan Harkless <dan-wget@dilvish.speed.net>
162 * main.c (print_help): -B / --base was not mentioned.
164 2000-08-22 Dan Harkless <dan-wget@dilvish.speed.net>
166 * main.c (print_help): Modified -nc description to mention that it
167 also prevents the creation of multiple versions of the same file
168 with ".<number>" suffixes.
170 2000-07-14 Jan Prikryl <prikryl@cg.tuwien.ac.at>
172 * retr.c (retrieve_url): Consistently strdup opt.referer when
175 2000-06-09 Dan Harkless <dan-wget@dilvish.speed.net>
177 * main.c (print_help): --help output for --waitretry was over 80 cols.
179 2000-06-09 Hrvoje Niksic <hniksic@iskon.hr>
181 * url.c (encode_string): Fix comment.
182 Suggested by Herold Heiko <Heiko.Herold@previnet.it>.
184 2000-06-01 Const Kaplinsky <const@ce.cctpu.edu.ru>
186 * ftp.c (ftp_retrieve_list): Change permissions only on plain
189 2000-06-01 Hrvoje Niksic <hniksic@iskon.hr>
191 * url.c (str_url): Print the port number only if it's different
192 from the default port number for that protocol.
194 2000-05-22 Dan Harkless <dan-wget@dilvish.speed.net>
196 * main.c (print_help): Added --help line for Damir Dzeko
197 <ddzeko@zesoi.fer.hr>'s until-now-undocumented --referer option.
198 Removed comments that --referer and --waitretry were undocumented.
199 Changed "`.wgetrc' command" to "`.wgetrc'-style command" on --help
202 2000-05-18 Hrvoje Niksic <hniksic@iskon.hr>
204 * ftp.c (getftp): Ditto.
206 * http.c (gethttp): Check for return value of fclose/fflush.
208 2000-04-12 Hrvoje Niksic <hniksic@iskon.hr>
210 * host.c (store_hostaddress): Instead of shifting ADDR, start
211 copying from the correct address.
213 2000-04-12 Hrvoje Niksic <hniksic@iskon.hr>
215 * http.c (gethttp): Don't free REQUEST -- it was allocated with
217 Pointed out by Gisle Vanem <gvanem@eunet.no>.
219 2000-04-04 Dan Harkless <dan-wget@dilvish.speed.net>
221 * host.c (store_hostaddress): R. K. Owen's patch introduces a
222 "left shift count >= width of type" warning on 32-bit
223 architectures. Got rid of it by tricking the compiler w/ a variable.
225 * url.c (UNSAFE_CHAR): The macro didn't include all the illegal
226 characters per RFC1738, namely everything above '~'. It also
227 generated a warning on OSes where char =~ unsigned char. Fixed.
229 1998-10-17 Hrvoje Niksic <hniksic@srce.hr>
231 * http.c (http_process_type): Removed needless strdup(), a memory
234 1998-09-25 Hrvoje Niksic <hniksic@srce.hr>
236 * html.c (htmlfindurl): Set PH to the first occurrence of `#'.
238 1998-09-25 Simon Munton <simonm@m4data.co.uk>
240 * init.c (wgetrc_file_name): Don't free HOME under Windows.
242 1998-12-01 "R. K. Owen" <rkowen@Nersc.GOV>
244 * host.c (store_hostaddress): Fix for big endian 64-bit machines.
246 1998-12-01 Hrvoje Niksic <hniksic@srce.hr>
248 * url.c (UNSAFE_CHAR): New macro.
249 (contains_unsafe): Use it.
250 (encode_string): Ditto.
252 1998-12-01 Hrvoje Niksic <hniksic@srce.hr>
254 * main.c (i18n_initialize): Use LC_MESSAGES only if available.
256 2000-03-31 Hrvoje Niksic <hniksic@srce.hr>
258 * Use TOUPPER/TOLOWER.
260 1998-12-22 Alexander V. Lukyanov <lav@yars.free.net>
262 * ftp-opie.c (btoe): Zero-terminate OSTORE.
264 2000-03-21 Hrvoje Niksic <hniksic@iskon.hr>
266 * wget.h (DO_REALLOC_FROM_ALLOCA): Ditto.
268 * sysdep.h (ISALNUM): New macro.
272 2000-03-10 Dan Harkless <dan-wget@dilvish.speed.net>
274 * html.c (idmatch): Implemented checking of my new --follow-tags
275 and --ignore-tags options.
277 * init.c (commands): Added comment reminding people adding new
278 entries doing allocation to add corresponding freeing in cleanup().
279 (commands): Added new followtags and ignoretags commands.
280 (cleanup): Free storage for new followtags and ignoretags.
282 * main.c: Use of "comma-separated list" was random -- normalized
283 it. Did some alphabetization. Added comments pointing out
284 "Options without arguments" and "Options accepting an argument"
285 sections of long_options[]. Added new options --follow-tags and
286 -G / --ignore-tags. Added comment that Damir's --referer is
287 currently undocumented. Added comment that Heiko's --waitretry is
288 partially undocumented (mentioned in --help but not in
289 wget.texi). Moved improperly sorted 24, 129, and 'G' cases.
291 * options.h (struct options): Added new fields follow_tags and
294 * wget.h: Added "#define EQ 0" so we can say "strcmp(a, b) == EQ".
296 2000-03-02 Dan Harkless <dan-wget@dilvish.speed.net>
298 * ftp.c (ftp_loop_internal): Heiko introduced "suggest explicit
299 braces to avoid ambiguous `else'" warnings. Eliminated them.
301 * http.c (gethttp): Dan Berger's query string patch is totally
302 bogus. If you have two different URLs, gen_page.cgi?page1 and
303 get_page.cgi?page2, they'll both be saved as get_page.cgi and the
304 second will overwrite the first. Also, parameters to implicit
305 CGIs, like "http://www.host.com/db/?2000-03-02" cause the URLs to
306 be printed with trailing garbage characters, and could seg fault.
307 Backing out the patch, which Dan B. informed me by email was just
308 a kludge to download StarOffice from Sun made necessary due to
309 wget's unconditional escaping of certain characters (room for an
311 (http_loop): Heiko introduced "suggest explicit braces to avoid
312 ambiguous `else'" warnings. Eliminated them.
314 * main.c: Heiko's --wait / --waitretry backwards compatibility
315 code looks to have been totally untested -- automatic variable
316 'wr' was used without being initialized, and a long int was passed
317 into setval()'s char* val parameter.
319 * recur.c (parse_robots): Applied Edward J. Sabol
320 <sabol@alderaan.gsfc.nasa.gov>'s patch for Guan Yang's reported
321 problem with "User-agent:<space>*<space>" lines in robots.txt.
323 * url.c (parseurl, str_url): Removing Dan Berger's code (see
324 http.c above for explanation).
326 1999-08-25 Heiko Herold <Heiko.Herold@previnet.it>
328 * ftp.c: Respect new option waitretry.
330 2000-01-30 Damir Dzeko <ddzeko@zesoi.fer.hr>
332 * http.c (gethttp): Send custom Referer, if required.
334 1999-09-24 Charles G Waldman <cgw@fnal.gov>
336 * netrc.c (parse_netrc): Allow passwords to contain spaces.
338 * netrc.c (parse_netrc): New function.
340 1999-09-17 Dan Berger <dberger@ix.netcom.com>
342 * http.c (gethttp): Send it.
344 * url.c (parseurl): Detect query string in HTTP URL-s.
347 2000-03-02 HIROSE Masaaki <hirose31@t3.rim.or.jp>
349 * html.c (html_allow): Add <link href=...> and <script src=...>.
351 1999-05-02 andrew deryabin <djsf@softhome.net>
353 * http.c (gethttp): Specify port in `Host' header only if it's
356 1998-11-03 Edward J. Sabol <sabol@alderaan.gsfc.nasa.gov>
358 * recur.c (recursive_retrieve): If a finite maximum depth is
359 specified, and we're are already at that depth, don't download the
360 HTML file for parsing.
362 2000-03-01 Dan Harkless <dan-wget@dilvish.speed.net>
364 * ftp.c (ftp_loop_internal): Call new downloaded_file() function,
365 even though we don't do conversion on HTML files retrieved via
366 FTP, so _current_ usage of downloaded_file() makes this call unneeded.
367 (ftp_retrieve_list): Added a comment saying where we need to
368 stat() a .orig file if FTP'd HTML file conversion is ever implemented.
369 (ftp_retrieve_list): "Local file '%s' is more recent," is sometimes
370 a lie -- reworded as "Server file no newer than local file '%s' --".
372 * http.c (http_loop): Fixed a typo and clarified a comment.
373 (http_loop): When -K and -N are specified together, compare size
374 and timestamp of server file X against local file X.orig (if
375 extant) rather than converted local file X.
376 (http_loop): "Local file '%s' is more recent," is sometimes a lie
377 -- reworded as "Server file no newer than local file '%s' --".
378 (http_loop): Call new downloaded_file() function to prevent
379 wrongful overwriting of .orig file when -N is specified.
381 * url.c (convert_links): When -K specified, only rename X to
382 X.orig if downloaded_file() returns TRUE. Otherwise when we skip
383 file X due to -N, we clobber an X.orig from a previous invocation.
384 (convert_links): Call the failsafe xstrdup(), not the real strdup().
385 (convert_links): Added a note asking anyone who understands how
386 multiple URLs can correspond to a single file to comment it.
387 (downloaded_file): Added this new function.
389 * url.h (downloaded_file): Added prototype for this new function
390 as well as its downloaded_file_t enum type.
392 * wget.h (boolean): Added this new typedef and TRUE and FALSE #defines.
394 2000-02-29 Dan Harkless <dan-wget@dilvish.speed.net>
396 * version.c: Upped version to developer-only "1.5.3+dev".
398 2000-02-18 Dan Harkless <dan-wget@dilvish.speed.net>
400 * init.c (backup_converted): Added this new option.
402 * main.c (-K / --backup-converted): Added this new option.
404 * options.h (backup_converted): Added this new option.
406 * url.c (convert_links): When backup_converted is specified, save
407 file X as X.orig before converting.
409 * url.h (urlpos): Fixed typo -- said "Rekative" instead of "Relative".
411 1998-09-21 Hrvoje Niksic <hniksic@srce.hr>
413 * version.c: Wget 1.5.3 is released.
415 1998-09-21 Hrvoje Niksic <hniksic@srce.hr>
417 * host.c (ftp_getaddress): Don't warn when reverse-lookup of local
418 address doesn't yield FQDN.
420 1998-09-21 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
422 * cmpt.c (strerror): Fix declaration of sys_errlist.
424 1998-09-11 Hrvoje Niksic <hniksic@srce.hr>
426 * main.c (main): Don't use an array subscript as the first
427 argument to STRDUP_ALLOCA.
430 1998-09-11 Szakacsits Szabolcs <szaka@sienet.hu>
432 * html.c (htmlfindurl): Download table background.
434 1998-09-11 Hans Grobler <grobh@conde.ee.sun.ac.za>
436 * init.c (parse_line): Would free *com before allocating it.
437 (parse_line): Would free com instead of *com.
439 1998-09-10 Howard Gayle <howard@fjst.com>
441 * url.c (get_urls_html): Would drop the last character of the
444 1998-09-10 Hrvoje Niksic <hniksic@srce.hr>
446 * http.c (http_loop): Don't print status code if quiet.
448 1998-09-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
450 * log.c: Use <stdarg.h> only when __STDC__.
452 1998-09-10 Adam D. Moss <adam@foxbox.org>
454 * html.c (htmlfindurl): Download <layer src=...>.
456 1998-09-10 Howard Gayle <howard@fjst.com>
458 * ftp.c (ftp_retrieve_list): Don't update the time stamp of a file
461 1998-06-27 Hrvoje Niksic <hniksic@srce.hr>
463 * utils.c: Include <libc.h> on NeXT.
465 1998-06-26 Heinz Salzmann <heinz.salzmann@intermetall.de>
467 * url.c (get_urls_html): Fix calculation of URL position.
469 1998-06-23 Hrvoje Niksic <hniksic@srce.hr>
471 * version.c: Wget 1.5.2 is released.
473 1998-06-23 Dave Love <d.love@dl.ac.uk>
475 * ftp.c, init.c, netrc.c: Include errno.h.
477 * http.c: Include errno.h and time header.
479 * Makefile.in (exext): Define.
480 (install.bin, uninstall.bin): Use it.
482 1998-06-21 Hrvoje Niksic <hniksic@srce.hr>
484 * http.c (http_loop): Don't attempt to compare local and remote
485 sizes if the remote size is unknown.
487 1998-06-16 Hrvoje Niksic <hniksic@srce.hr>
489 * url.c (get_urls_html): Use malloc() instead of alloca in the
492 1998-06-13 Hrvoje Niksic <hniksic@srce.hr>
494 * version.c: Wget 1.5.2-b4 is released.
496 1998-06-13 Hrvoje Niksic <hniksic@srce.hr>
498 * url.c (get_urls_html): Ignore spaces before and after the URI.
500 1998-06-08 Wanderlei Antonio Cavassin <cavassin@conectiva.com.br>
502 * ftp.c (getftp): Translate `done'.
504 1998-06-06 Hrvoje Niksic <hniksic@srce.hr>
506 * version.c: Wget 1.5.2-b3 is released.
508 1998-06-06 Alexander Kourakos <awk@bnt.com>
510 * init.c (cleanup): Close dfp, don't free it.
512 1998-06-06 Hrvoje Niksic <hniksic@srce.hr>
514 * utils.c (make_directory): Twiddle.
516 * config.h.in: Added template for access().
518 1998-06-05 Mathieu Guillaume <mat@cythere.com>
520 * html.c (htmlfindurl): Download <input src=...>
522 1998-06-03 Hrvoje Niksic <hniksic@srce.hr>
524 * utils.c (file_exists_p): Use access() with two arguments.
526 1998-05-27 Martin Kraemer <Martin.Kraemer@mch.sni.de>
528 * netrc.c (parse_netrc): Correct logic.
530 1998-05-27 Hrvoje Niksic <hniksic@srce.hr>
532 * ftp.c (getftp): Added `break'; suggested by Lin Zhe Min
533 <ljm@ljm.wownet.net>.
535 1998-05-24 Hrvoje Niksic <hniksic@srce.hr>
537 * version.c: Wget 1.5.2-b2 is released.
539 1998-05-18 Juan Jose Rodriguez <jcnsoft@jal1.telmex.net.mx>
541 * mswindows.h: Don't translate mkdir to _mkdir under Borland.
543 1998-05-17 Hrvoje Niksic <hniksic@srce.hr>
545 * retr.c (elapsed_time): Return correct value when
546 HAVE_GETTIMEOFDAY is undefined.
548 1998-05-13 Hrvoje Niksic <hniksic@srce.hr>
550 * version.c: Wget 1.5.2-b1 is released.
552 1998-05-08 Hrvoje Niksic <hniksic@srce.hr>
554 * getopt.c (_getopt_internal): Use exec_name instead of argv[0].
555 (_getopt_internal): Don't translate `#if 0'-ed strings.
557 1998-05-06 Douglas E. Wegscheid <wegscd@whirlpool.com>
559 * mswindows.c (ws_handler): Use fork_to_background().
561 1998-05-05 Hrvoje Niksic <hniksic@srce.hr>
563 * version.c: Wget 1.5.1 is released.
565 1998-05-05 Hrvoje Niksic <hniksic@srce.hr>
567 * http.c (parse_http_status_line): Avoid `minor' and `major'
570 1998-05-02 Hrvoje Niksic <hniksic@srce.hr>
572 * utils.c (mkdirhier): Renamed to make_directory.
574 1998-05-01 Hrvoje Niksic <hniksic@srce.hr>
576 * mswindows.c (fork_to_background): Define under Windows.
578 * utils.c (fork_to_background): New function.
580 * html.c (htmlfindurl): Removed rerdundant casts.
582 1998-05-01 Douglas E. Wegscheid <wegscd@whirlpool.com>
584 * mswindows.c (ws_mypath): Cache the path.
586 1998-04-30 Douglas E. Wegscheid <wegscd@whirlpool.com>
588 * ftp.h: Prefix enum ftype members with FT_.
590 * ftp-ls.c, ftp.c, html.h: Adjust accordingly.
592 * mswindows.h: Use stat under Borland, _stat under MSVC.
594 1998-04-28 Hrvoje Niksic <hniksic@srce.hr>
596 * http.c (known_authentication_scheme_p): New function.
597 (gethttp): Handle authorization more correctly.
599 * ftp-basic.h: Removed.
603 * utils.c: Include <unistd.h> before <pwd.h>; needed under SunOS
605 (numdigit): Use `while' loop.
607 * http.c (create_authorization_line): Detect authentication
608 schemes case-insensitively.
610 * http.c (extract_header_attr): Use strdupdelim().
611 (digest_authentication_encode): Move declaration of local
612 variables to smaller scope.
613 (digest_authentication_encode): Reset REALM, OPAQUE and NONCE.
614 (create_authorization_line): Detect authentication schemes
617 * utils.c (touch): Constify.
619 * http.c (gethttp): Report a nicer error when no data is received.
621 * rbuf.h (RBUF_READCHAR): Ditto.
623 * ftp-basic.c (ftp_response): Use sizeof.
625 1998-04-27 Hrvoje Niksic <hniksic@srce.hr>
627 * retr.c (print_percentage): EXPECTED is long, not int.
628 (print_percentage): Use floating-point arithmetic to avoid
629 overflow with large files' sizes multiplied with 100.
631 1998-04-27 Gregor Hoffleit <flight@mathi.uni-heidelberg.de>
633 * config.h.in: Added pid_t stub.
635 * sysdep.h (S_ISREG): Moved here from mswindows.h (NeXT doesn't
638 1998-04-20 Hrvoje Niksic <hniksic@srce.hr>
640 * version.c: Wget 1.5.0 is released.
642 1998-04-18 Hrvoje Niksic <hniksic@srce.hr>
644 * url.c (str_url): Ditto.
646 * ftp-basic.c (ftp_rest): Use new name.
648 * utils.c (long_to_string): Renamed from prnum().
650 1998-04-16 Hrvoje Niksic <hniksic@srce.hr>
652 * version.c: Wget 1.5-b17 is released.
654 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
656 * headers.c (header_get): New argument FLAGS.
658 * http.c (gethttp): If request is malformed, bail out of the
660 (gethttp): Check for empty header *after* the status line checks.
661 (gethttp): Disallow continuations for status line.
663 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
665 * version.c: Wget 1.5-b16 is released.
667 1998-04-08 Hrvoje Niksic <hniksic@srce.hr>
669 * init.c (commands): Renamed `always_rest' to `continue'.
671 1998-04-05 Hrvoje Niksic <hniksic@srce.hr>
675 * log.c (logputs): New argument.
679 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
681 * http.c (http_atotm): Update comment.
683 * main.c (i18n_initialize): Set LC_MESSAGES, not LC_ALL.
685 * wget.h: Renamed ENABLED_NLS to HAVE_NLS.
687 * main.c (i18n_initialize): New function.
690 * log.c: Include <unistd.h>.
692 * retr.c (show_progress): Cast alloca to char *.
694 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
696 * version.c: Wget 1.5-b15 is released.
698 1998-04-04 Hrvoje Niksic <hniksic@srce.hr>
700 * utils.h: Declare file_non_directory_p().
702 1998-04-03 Hrvoje Niksic <hniksic@srce.hr>
704 * main.c (main): It's `tries', not `numtries' now.
706 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
708 * init.c (getperms): Removed.
710 1998-04-01 Tim Charron <tcharron@interlog.com>
712 * log.c (logvprintf): Don't use ARGS twice.
714 1998-04-01 John <john@futuresguide.com>
716 * mswindows.c: Cleaned up.
718 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
720 * version.c: Wget 1.5-b14 is released.
722 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
724 * ftp-opie.c (STRLEN4): New macro.
727 1998-04-01 Junio Hamano <junio@twinsun.com>
729 * http.c: Document all the Digest functions.
731 1998-04-01 Hrvoje Niksic <hniksic@srce.hr>
733 * utils.c (file_non_directory_p): Renamed from isfile().
735 * mswindows.h (S_ISREG): New macro, suggested by Tim Adam.
737 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
739 * utils.c (mkdirhier): Use 0777 instead of opt.dirmode.
741 * init.c (cmd_spec_dotstyle): Use 48 dots per line for binary
743 (cmd_permissions): Removed.
745 * config.h.in: Add template for WORDS_BIGENDIAN.
747 1998-03-31 Junio Hamano <junio@twinsun.com>
749 * http.c (HEXD2asc): New macro.
752 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
754 * version.c: Wget 1.5-b13 is released.
756 1998-03-31 Hrvoje Niksic <hniksic@srce.hr>
758 * main.c (main): Don't try to use `com'.
760 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
762 * init.c (cmd_permissions): New function.
764 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
766 * version.c: Wget 1.5-b12 is released.
768 1998-03-30 Hrvoje Niksic <hniksic@srce.hr>
770 * init.c (commands): Renamed `numtries' to `tries'.
771 (cmd_spec_debug): Removed.
772 (home_dir): Under Windows, return `C:\' if HOME is undefined.
774 1998-03-29 Hrvoje Niksic <hniksic@srce.hr>
776 * config.h.in: Define _XOPEN_SOURCE.
778 * init.c (check_user_specified_header): New function.
779 (cmd_spec_header): Use it.
780 (cmd_spec_useragent): New function.
782 1998-03-29 Hrvoje Niksic <hniksic@srce.hr>
784 * version.c: Wget 1.5-b11 is released.
786 1998-03-28 Hrvoje Niksic <hniksic@srce.hr>
788 * wget.h: Include <libintl.h> only if NLS is enabled.
790 1998-03-26 Hrvoje Niksic <hniksic@srce.hr>
792 * options.h (struct options): Made `wait' a long.
793 (struct options): Ditto for `timeout'.
795 1998-03-19 Hrvoje Niksic <hniksic@srce.hr>
797 * utils.c (exists): Renamed to file_exists_p.
798 (file_exists_p): Use access() if available.
800 1998-03-17 Hrvoje Niksic <hniksic@srce.hr>
802 * utils.c (memfatal): Set save_log_p to 0 to avoid potential
805 * log.c: do_logging -> save_log_p.
807 * config.h.in: Added template for HAVE_VSNPRINTF.
809 1998-03-16 Hrvoje Niksic <hniksic@srce.hr>
813 * http.c: Protect declaration against non-ANSI compiler.
815 * log.c (logvprintf): Use vsnprintf() if available.
817 * getopt.c (main): Don't translate test stuff.
819 1998-03-16 Hrvoje Niksic <hniksic@srce.hr>
821 * version.c: Wget 1.5-b10 is released.
823 1998-03-11 Hrvoje Niksic <hniksic@srce.hr>
825 * ftp.c (getftp): Don't translate "CWD %s".
827 * wget.h (GCC_FORMAT_ATTR): Renamed from FORMAT_ATTR.
829 1998-03-07 Hrvoje Niksic <hniksic@srce.hr>
831 * ftp-opie.c (btoe): Use memcpy() instead of strncat().
833 * log.c (logputs): New function.
834 (logvprintf): Renamed from vlogmsg; use logputs().
836 * retr.c (show_progress): Print `[100%]' when the retrieval is
839 * init.c (run_wgetrc): Use FILE, not PATH.
840 (wgetrc_file_name): Ditto.
842 1998-03-07 Tim Adam <tma@osa.com.au>
844 * recur.c (parse_robots): Correctly reset `entries' on empty
847 1998-03-07 Hrvoje Niksic <hniksic@srce.hr>
849 * init.c (cmd_spec_debug): Use cmd_boolean().
851 1998-02-23 Hrvoje Niksic <hniksic@srce.hr>
853 * http.c (gethttp): Create proxy-authorization correctly.
855 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
859 * getopt.c: Use ANSI function definitions.
861 * ftp-opie.c: New file.
863 * options.h: Don't redefine EXTERN.
865 * init.c: Sort it correctly.
867 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
869 * version.c: Wget 1.5-b9 is released.
871 1998-02-22 Hrvoje Niksic <hniksic@srce.hr>
873 * recur.c (recursive_retrieve): Reset `first_time'.
875 * ftp.c (getftp): Added `default' clause to switches of uerr_t.
877 * rbuf.c (rbuf_peek): Simplified.
878 (rbuf_flush): Use MINVAL.
880 * wget.h (MINVAL): Moved from url.h.
882 * rbuf.h (RBUF_FD): New macro.
884 * url.c (add_url): Add to the head of the list.
886 * ftp.c (ftp_retrieve_list): Set the permissions to downloaded
888 (getftp): Set the default permissions to 0600.
890 1998-02-21 Hrvoje Niksic <hniksic@srce.hr>
892 * url.c (get_urls_html): Ditto.
893 (convert_links): Ditto.
895 * recur.c (parse_robots): Ditto.
897 * html.c (ftp_index): Ditto.
899 * ftp-ls.c (ftp_parse_unix_ls): Open file as binary.
901 * init.c (defaults): Initialize `opt' to zero via memset.
903 * http.c (digest_authentication_encode): goto considered harmful.
905 1998-02-19 Hrvoje Niksic <hniksic@srce.hr>
907 * ftp.c (delelement): Simplify and fix leak.
909 1998-02-18 Hrvoje Niksic <hniksic@srce.hr>
911 * http.c (dump_hash): Use HEXD2ASC instead of home-grown stuff.
913 * url.h (HEXD2ASC): Removed warning.
915 * init.c (comind): Use binary search.
916 (commands): Reorganized.
918 (cmd_boolean): New function.
920 (cmd_number_inf): Ditto.
923 (cmd_directory_vector): Ditto.
926 (cmd_spec_debug): Ditto.
927 (cmd_spec_dirmode): Ditto.
928 (cmd_spec_dirstruct): Ditto.
929 (cmd_spec_dotstyle): Ditto.
930 (cmd_spec_header): Ditto.
931 (cmd_spec_htmlify): Ditto.
932 (cmd_spec_mirror): Ditto.
933 (cmd_spec_outputdocument): Ditto.
934 (cmd_spec_recursive): Ditto.
935 (settime): Merged with cmd_time().
936 (setbytes): Merged with cmd_bytes().
937 (setonoff): Merged with cmd_boolean().
940 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
942 * Makefile.in (distclean): Remove `config.h'.
944 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
946 * version.c: Wget 1.5-b8 is released.
948 1998-02-17 Hrvoje Niksic <hniksic@srce.hr>
950 * http.c (digest_authentication_encode): New function.
951 (create_authorization_line): Use it.
952 (dump_hash): New function.
953 (digest_authentication_encode): Use it.
955 * fnmatch.c: Renamed from `mtch.c'.
957 1998-02-15 Karl Eichwalder <ke@suse.de>
959 * main.c (main): Tag "Written by..." string as translatable.
961 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
963 * wget.h (FREE_MAYBE): New macro.
965 * http.c (create_authorization_line): Don't use ANSI C string
966 concatenation feature.
967 (basic_authentication_encode): Use alloca() for temporary
976 * ftp-basic.c: Protect declaration against non-ANSI compiler.
978 * http.c (create_authorization_line): Cast `unsigned char *' to
979 `char *' for sprintf, to shut up the noisy Digital Unix cc.
981 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
983 * version.c: Wget 1.5-b7 is released.
985 1998-02-15 Hrvoje Niksic <hniksic@srce.hr>
987 * cmpt.c (strstr): Synched with glibc-2.0.6.
989 * ftp-basic.c (calculate_skey_response): Ditto.
990 (calculate_skey_response): Use alloca().
992 * http.c (create_authorization_line): Work with FSF's version of
995 * md5.c: New file, from GNU libc.
997 1998-02-14 Hrvoje Niksic <hniksic@srce.hr>
999 * url.h (URL_CLEANSE): Name the temporary variable more carefully.
1001 1998-02-13 Hrvoje Niksic <hniksic@srce.hr>
1003 * http.c (basic_authentication_encode): New function, instead of
1006 1998-02-13 Junio Hamano <junio@twinsun.com>
1008 * http.c: Add HTTP-DA support.
1009 * ftp-basic.c: Add Opie/S-key support.
1010 * config.h.in, Makefile.in: Add HTTP-DA and Opie/S-key support.
1011 * md5.c, md5.h: New files.
1013 1998-02-13 Hrvoje Niksic <hniksic@srce.hr>
1015 * http.c (http_process_range): Renamed from hprocrange().
1016 (http_process_range): Parse the whole header.
1018 * headers.c: New file.
1019 (header_process): New function.
1020 (header_get): Renamed from fetch_next_header.
1022 * all: Include utils.h only where necessary.
1024 * wget.h: Declare xmalloc(), xrealloc() and xstrdup() here.
1026 * wget.h: Add provisions for dmalloc.
1028 1998-02-12 Hrvoje Niksic <hniksic@srce.hr>
1030 * version.c: Wget 1.5-b6 is released.
1032 1998-02-12 Hrvoje Niksic <hniksic@srce.hr>
1034 * ftp.c (ftp_loop): Determine `filename' more precisely.
1036 * init.c (setval): Don't set `opt.quiet' if output-document is
1039 * log.c (log_init): Print to STDERR instead of STDOUT.
1040 (vlogmsg): Use STDERR by default.
1043 1998-02-11 Simon Josefsson <jas@pdc.kth.se>
1045 * host.c: Use addr_in again.
1047 1998-02-08 Karl Eichwalder <karl@suse.de>
1049 * http.c (gethttp): Fixed typo.
1051 1998-02-08 Hrvoje Niksic <hniksic@srce.hr>
1053 * version.c: Wget 1.5-b5 is released.
1055 1998-02-08 Hrvoje Niksic <hniksic@srce.hr>
1057 * retr.c (show_progress): Use it.
1059 * log.c (logflush): New function.
1061 * wget.h: Utilize __attribute__ if on gcc.
1063 1998-02-07 Hrvoje Niksic <hniksic@srce.hr>
1065 * http.c (base64_encode_line): New argument LENGTH.
1066 (BASIC_AUTHENTICATION_ENCODE): Use it.
1067 (BASIC_AUTHENTICATION_ENCODE): Take length of HEADER into account.
1069 * main.c (main): Fixed fprintf() format mismatch.
1071 1998-02-06 Hrvoje Niksic <hniksic@srce.hr>
1073 * version.c: Wget 1.5-b4 is released.
1075 1998-02-03 Simon Josefsson <jas@pdc.kth.se>
1077 * host.c: use sockaddr_in instead of addr_in.
1079 1998-02-04 Hrvoje Niksic <hniksic@srce.hr>
1081 * init.c (cleanup): Use it.
1083 * recur.c (recursive_cleanup): New function.
1085 * retr.c (retrieve_from_file): Ditto.
1087 * main.c (main): Use it.
1089 * recur.c (recursive_reset): New function.
1091 * retr.c (retrieve_from_file): Ditto.
1093 * main.c (main): Simplify call to recursive_retrieve().
1095 * recur.c (recursive_retrieve): Removed FLAGS argument.
1097 * http.c (gethttp): Changed call to iwrite().
1099 1998-02-03 Hrvoje Niksic <hniksic@srce.hr>
1101 * url.c (get_urls_html): Ditto.
1102 (free_urlpos): Ditto.
1106 * retr.c (retrieve_url): Move declaration of local variables to
1109 * url.c (urlproto): Use it.
1112 (get_urls_html): Ditto.
1114 * utils.h (ARRAY_SIZE): New macro.
1116 * url.c (proto): Moved from url.h.
1118 * url.h (URL_CLEANSE): Reformatted.
1119 (USE_PROXY_P): Renamed from USE_PROXY.
1121 * ftp-basic.c: Adjust to the new interface of iwrite().
1123 * ftp-basic.c (ftp_port): Use alloca().
1125 1998-02-03 Hrvoje Niksic <hniksic@srce.hr>
1127 * version.c: Wget 1.5-b3 is released.
1129 * host.c (ftp_getaddress): Don't print to stderr directly.
1131 * init.c (setbytes): Support `g' for gigabytes.
1132 (cmdtype): New specification CTIME.
1133 (setval): Use it with settime().
1134 (commands): Use it for WAIT and TIMEOUT.
1136 1998-02-02 Hrvoje Niksic <hniksic@srce.hr>
1138 * http.c (BASIC_AUTHENTICATION_ENCODE): New macro.
1141 * utils.c (unique_name_1): Moved from url.c.
1142 (unique_name): Ditto.
1144 * url.c (url_filename): Ditto.
1146 * log.c (redirect_output): Changed call to unique_name().
1148 * url.c (unique_name_1): Renamed from unique_name().
1149 (unique_name): Changed interface.
1151 * init.c (enum cmdid): Moved from init.h.
1153 (struct cmd): Ditto.
1155 * main.c (main): Use it.
1156 (main): Moved `--backups' to not have a short option.
1158 * options.h (struct options): New member BACKGROUND.
1160 * main.c (print_help): Rearranged.
1161 (main): New long options for -n* short options: --no-directories,
1162 --no-host-directories, --non-verbose, --no-host-lookup and
1163 --dont-remove-listing.
1165 1998-02-01 Hrvoje Niksic <hniksic@srce.hr>
1167 * main.c (main): Use log_close().
1169 * log.c: New variable LOGFP.
1171 (redirect_output): Don't open /dev/null; set LOGFP to stdin
1173 (log_close): New function.
1175 * options.h (struct options): Removed LFILE.
1177 * log.c (log_enable): Removed.
1179 * main.c (main): Use it.
1181 * log.c (log_init): New function.
1183 * url.c (get_urls_html): Removed needless assignment to BASE.
1185 * host.c (add_hlist): Don't set CMP needlessly.
1187 * utils.c (match_backwards): Ditto.
1188 (in_acclist): Ditto.
1190 * url.c (findurl): Ditto.
1192 * netrc.c (parse_netrc): Ditto.
1194 * log.c (log_dump): Ditto.
1196 * html.c (html_quote_string): Ditto.
1198 * ftp-basic.c (ftp_request): Made static.
1200 * connect.c: Made global variables static.
1202 * url.c (construct): Ditto.
1204 * init.c (init_path): Avoid assignment inside `if'-condition.
1206 * ftp.c: Don't include in.h or winsock.h.
1208 * ftp.c (ftp_loop): Use SZ.
1210 * connect.c (bindport): Cast &addrlen to int *.
1213 * init.c (initialize): Don't use SYSTEM_WGETRC unconditionally.
1215 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1217 * ftp.c (getftp): Initialize opt.ftp_pass here.
1218 (ftp_retrieve_dirs): Use alloca().
1220 * init.c (defaults): Don't initialize opt.ftp_pass.
1222 * sysdep.h (S_ISLNK): Declare for OS/2; ditto for lstat.
1223 From Ivan F. Martinez <ivanfm@ecodigit.com.br>.
1225 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1227 * recur.c (parse_robots): Check for comments more correctly.
1229 * host.c (ftp_getaddress): Use STRDUP_ALLOCA.
1230 (ftp_getaddress): Add diagnostics when reverse-lookup yields only
1233 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1235 * version.c: Wget 1.5-b2 is released.
1237 * netrc.c (NETRC_FILE_NAME): Moved from netrc.h.
1239 * utils.c (proclist): Pass FNM_PATHNAME to fnmatch().
1241 * ftp-basic.c (ftp_pasv): Avoid unnecessary casting to unsigned
1244 * log.c: Don't attempt to hide arguments from ansi2knr.
1246 * cmpt.c: Synched strptime() and mktime() with glibc-2.0.6.
1248 * ansi2knr.c: Use a later version, from fileutils-3.16l alpha.
1250 * ftp.c (getftp): Ditto.
1252 * http.c (gethttp): Use it.
1254 * retr.c (get_contents): New argument EXPECTED; pass it to
1256 (show_progress): New argument EXPECTED; use it to display
1259 * init.c (setval): Ditto.
1261 * http.c (gethttp): Ditto.
1264 * ftp.c (getftp): Ditto.
1265 (ftp_loop_internal): Ditto.
1267 * ftp-ls.c (ftp_parse_unix_ls): Use abort() instead of assert(0).
1269 * sysdep.h (CLOSE): Simplify; use DEBUGP.
1271 * netrc.c (search_netrc): Use alloca().
1273 * init.c (defaults): Initialize no_flush.
1275 * log.c (vlogmsg): Don't flush if no_flush.
1277 * options.h (struct options): New variable no_flush.
1279 * main.c (main): Don't play games with buffering.
1281 * log.c (vlogmsg): Flush the output after every message.
1283 1998-01-31 Hrvoje Niksic <hniksic@srce.hr>
1285 * init.c (parse_line): Ditto.
1287 * url.c (get_urls_html): Ditto.
1289 * main.c (main): Don't cast to unsigned char.
1291 * init.c (run_wgetrc): Don't cast to unsigned char.
1292 (parse_line): Accept char instead of unsigned char.
1294 * html.c (htmlfindurl): Use char instead of unsigned char.
1298 * sysdep.h: Add wrappers to ctype macros to make them
1301 1998-01-30 Hrvoje Niksic <hniksic@srce.hr>
1303 * html.c (htmlfindurl): Download <img lowsrc=...>
1305 * main.c (main): Ignore SIGPIPE.
1307 * connect.c (select_fd): New argument WRITEP.
1308 (iwrite): Call select_fd().
1310 1997-02-27 Fila Kolodny <fila@ibi.com>
1312 * ftp.c (ftp_retrieve_list): If retrieving symlink and the proper
1313 one already exists, just skip it.
1315 1998-01-30 Hrvoje Niksic <hniksic@srce.hr>
1317 * http.c (gethttp): Cosmetic changes.
1319 * http.c (check_end): Allow `+D...' instead of `GMT'.
1320 From Fabrizio Pollastri <pollastri@cstv.to.cnr.it>.
1322 * url.c (process_ftp_type): New function.
1325 * connect.c (iwrite): Allow writing in a few chunks.
1326 (bindport): Made SRV static, so addr can point to it.
1327 (select_fd): Removed HPUX kludge.
1329 * host.c (free_hlist): Incorporated into clean_hosts().
1331 1998-01-29 Hrvoje Niksic <hniksic@srce.hr>
1333 * host.c (hlist): Made static.
1334 (search_address): Cosmetic change.
1336 1998-01-29 Hrvoje Niksic <hniksic@srce.hr>
1338 * version.c: Wget v1.5-b1 is released.
1340 * http.c (hgetlen): Use sizeof() to get the header length.
1343 (hgetlocation): Ditto.
1344 (hgetmodified): Ditto.
1345 (haccepts_none): Ditto.
1347 * main.c (main): Updated `--version' and `--help' output, as per
1348 Francois Pinard's suggestions.
1350 * main.c: Include locale.h; call setlocale(), bindtextdomain() and
1353 * config.h.in: Define stubs for I18N3.
1355 * wget.h: Include libintl.h.
1357 1998-01-28 Hrvoje Niksic <hniksic@srce.hr>
1359 * url.c (mkstruct): Check for opt.cut_dirs.
1360 (mkstruct): alloca()-te more, xmalloc() less.
1362 * utils.c (load_file): Check for ferror().
1364 * url.c (get_urls_file): Close only the files we opened.
1365 (get_urls_html): Ditto.
1366 (count_slashes): New function.
1370 * http.c (gethttp): Respect username and password provided by
1372 (base64_encode_line): Write into an existing buffer instead of
1373 malloc-ing a new one.
1374 (struct http_stat): Moved from http.h
1376 * retr.c (retrieve_url): Free SUF.
1378 * all: Removed lots of unnecessary .h dependencies.
1380 * html.c (global_state): Made static.
1382 * utils.h (ALLOCA_ARRAY): New macro.
1384 * main.c (main): New option `--cut-dirs'.
1386 * url.c (construct): Use alloca() for T.
1388 * utils.c (mkdirhier): Use STRDUP_ALLOCA.
1390 * host.c (_host_t): Moved from host.h.
1391 (struct host): Renamed from _host_t.
1392 (store_hostaddress): Use STRDUP_ALLOCA for INET_S.
1395 * host.h: Don't include url.h.
1397 * ftp.c (LIST_FILENAME): Moved from ftp.h.
1399 * init.c (DEFAULT_FTP_ACCT): Moved from ftp.h.
1401 * main.c (main): Enable log if the output goes to a TTY.
1403 * connect.h: Removed unused constant `BACKLOG'.
1405 * config.h.in: Check for isatty().
1407 * Makefile.in (LINK): Use CFLAGS when linking.
1409 1998-01-27 Hrvoje Niksic <hniksic@srce.hr>
1411 * mswindows.c (ws_hangup): Use redirect_output().
1413 * main.c (redirect_output_signal): New function; use
1416 * log.c (redirect_output): New function, based on hangup(), which
1419 * log.c (vlogmsg): New function.
1421 * wget.h (DEBUGP): Use debug_logmsg().
1423 * main.c (hangup): Use it.
1425 * log.c (log_dump): New function.
1427 * utils.h (DO_REALLOC): Use `long' for various sizes.
1429 * http.c (hskip_lws): Use `while', for clarity.
1430 (HTTP_DYNAMIC_LINE_BUFFER): New constant.
1431 (fetch_next_header): Use it instead of DYNAMIC_LINE_BUFFER.
1433 * ftp-basic.c (FTP_DYNAMIC_LINE_BUFFER): New constant.
1434 (ftp_response): Use it instead of DYNAMIC_LINE_BUFFER.
1436 * utils.c (DYNAMIC_LINE_BUFFER): Moved from utils.c.
1437 (LEGIBLE_SEPARATOR): Ditto.
1438 (FILE_BUFFER_SIZE): Ditto.
1440 * retr.c (BUFFER_SIZE): Moved from retr.h.
1443 (logmsg): Moved from utils.c.
1444 (debug_logmsg): New function.
1446 * mswindows.h: Include it here.
1450 * utils.c: Don't include <windows.h>.
1452 1998-01-25 Hrvoje Niksic <hniksic@srce.hr>
1454 * host.c (ftp_getaddress): Ditto.
1456 * main.c (main): Use it.
1458 * utils.h (STRDUP_ALLOCA): New macro.
1460 * init.c: Prepend `wget: ' to error messages printed on stderr.
1462 * utils.c (mkdirhier): Renamed from mymkdir.
1463 (touch): Renamed from my_touch.
1464 (pwd_cuserid): Renamed from my_cuserid().
1466 1998-01-24 Andy Eskilsson <andy.eskilsson@telelogic.se>
1468 * utils.c (accdir): Process wildcards.
1469 (proclist): New function.
1470 (accdir): Use it to avoid code repetition.
1472 1998-01-24 Hrvoje Niksic <hniksic@srce.hr>
1474 * recur.c (parse_robots): Respect opt.useragent; use alloca().
1476 * http.c (gethttp): Construct useragent accordingly.
1478 * version.c: Changed version string to numbers-only.
1480 * main.c (print_help): List all the options.
1482 * mswindows.c (windows_main_junk): Initialize argv0 here.
1484 1998-01-24 Karl Heuer <kwzh@gnu.org>
1486 * netrc.c (search_netrc): Initialize `l' only after processing
1489 * main.c (main): Don't trap SIGHUP if it's being ignored.
1491 1998-01-24 Hrvoje Niksic <hniksic@srce.hr>
1493 * all: Use logmsg().
1495 * utils.c (time_str): Moved from retr.c.
1496 (logmsg): New function.
1497 (logmsg_noflush): Ditto.
1499 * rbuf.c: New file, moved buf_* functions here.
1501 * ftp.c (ftp_expected_bytes): Moved from ftp-basic.c.
1503 * ftp-basic.c (ftp_rest): Use prnum().
1505 * ftp-basic.c: Ditto.
1507 * ftp.c: Use the new reading functions and macros.
1509 * retr.c (buf_initialize): New function.
1510 (buf_initialized_p): Ditto.
1511 (buf_uninitialize): Ditto.
1514 * http.c (fetch_next_header): Use the BUF_READCHAR macro for
1516 (gethttp): Use alloca() where appropriate.
1518 * retr.c (buf_readchar): Use it.
1519 (buf_peek): Use rstreams.
1521 * retr.h (BUF_READCHAR): New macro.
1523 * init.c (home_dir): Rewritten for clarity.
1526 * mswindows.c (ws_backgnd): Made static.
1527 (read_registry): Ditto.
1528 (ws_cleanup): Ditto.
1529 (ws_handler): Ditto.
1531 1998-01-23 Hrvoje Niksic <hniksic@srce.hr>
1533 * alloca.c: New file.
1535 * Makefile.in (ALLOCA): Define.
1537 * mswindows.c (ws_help): Constify.
1538 (ws_help): Use alloca.
1540 * mswindows.c: Reformat.
1542 * all: Added _(...) annotations for I18N snarfing and translation.
1544 * host.c (ftp_getaddress): Nuke SYSINFO.
1545 (ftp_getaddress): Don't use getdomainname().
1546 (ftp_getaddress): Use uname(), where available.
1548 * http.c (gethttp): Protect a stray fprintf().
1550 * init.c (settime): New function.
1551 (setval): Treat WAIT specially, allowing suffixes like `m' for
1554 1998-01-21 Hrvoje Niksic <hniksic@srce.hr>
1556 * url.c (get_urls_html): Use alloca() for TEMP.
1558 1998-01-21 Jordan Mendelson <jordy@wserv.com>
1560 * url.c (rotate_backups): New function.
1562 * http.c (gethttp): Ditto.
1564 * ftp.c (getftp): Rotate backups.
1566 1997-12-18 Hrvoje Niksic <hniksic@srce.hr>
1568 * all: Renamed nmalloc(), nrealloc() and nstrdup() to xmalloc(),
1569 xrealloc() and xstrdup(). Use the new functions.
1571 * url.c (decode_string): Made static.
1574 (parse_uname): Ditto.
1577 (construct_relative): Ditto.
1579 * retr.c (show_progress): Made static.
1581 * recur.c (robots_url): Made static.
1582 (retrieve_robots): Ditto.
1583 (parse_robots): Ditto.
1584 (robots_match): Ditto.
1588 * main.c (printhelp): Made static.
1591 * init.c (comind): Made static.
1594 (run_wgetrc): Ditto.
1602 * http.c (fetch_next_header): Made static.
1603 (hparsestatline): Ditto.
1608 (hgetlocation): Ditto.
1609 (hgetmodified): Ditto.
1610 (haccepts_none): Ditto.
1612 (base64_encode_line): Ditto.
1613 (mktime_from_utc): Ditto.
1614 (http_atotm): Ditto.
1616 * html.c (idmatch): Made static.
1618 * host.c (search_host): Made static.
1619 (search_address): Ditto.
1620 (free_hlist): Ditto.
1622 * ftp.c (getftp): Made static.
1623 (ftp_loop_internal): Ditto.
1624 (ftp_get_listing): Ditto.
1625 (ftp_retrieve_list): Ditto.
1626 (ftp_retrieve_dirs): Ditto.
1627 (ftp_retrieve_glob): Ditto.
1628 (freefileinfo): Ditto.
1629 (delelement): Ditto.
1631 * ftp-ls.c (symperms): Made static.
1632 (ftp_parse_unix_ls): Ditto.
1634 * connect.c (select_fd): Made static.
1636 * utils.c (xmalloc): Renamed from nmalloc.
1637 (xrealloc): Renamed from nrealloc.
1638 (xstrdup): Renamed from nstrdup.
1640 * getopt.c (exchange): Use alloca.
1642 * mswindows.c (mycuserid): Use strncpy.
1644 * New files mswindows.c, mswindows.h, sysdep.h. winjunk.c,
1645 systhings.h, windecl.h and winjunk.h removed.
1647 * mswindows.c (sleep): New function.
1649 * utils.c: Include <windows.h> under Windows.
1651 1997-06-12 Darko Budor <dbudor@zesoi.fer.hr>
1653 * url.h (URL_UNSAFE): Change default under Windows.
1655 * retr.c (retrieve_from_file): Respect opt.delete_after.
1657 * main.c (main): Call ws_help on Windows.
1659 * winjunk.c (windows_main_junk): New function.
1661 * main.c (main): Junk-process argv[0].
1663 * http.c (mktime_from_utc): Return -1 if mktime failed.
1665 * http.c (http_loop): Ditto.
1667 * ftp.c (ftp_loop_internal): Change title on Windows when using a
1670 * winjunk.c (getdomainname): Lots of functions.
1672 1997-06-12 Hrvoje Niksic <hniksic@srce.hr>
1674 * cmpt.c (strptime_internal): Handle years more correctly for
1677 1997-06-09 Mike Thomas <mthomas@reality.ctron.com>
1679 * http.c (gethttp): Allocate enough space for
1680 `Proxy-Authorization' header.
1682 1997-05-10 Hrvoje Niksic <hniksic@srce.hr>
1684 * version.c: Wget/1.4.5 is released.
1686 1997-05-10 Hrvoje Niksic <hniksic@srce.hr>
1688 * retr.c (get_contents): Check return value of fwrite more
1691 1997-03-30 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1693 * cmpt.c (strptime_internal) [case 'Y']: Always subtract 1900 from
1694 year, regardless of century.
1696 1997-03-30 Hrvoje Niksic <hniksic@srce.hr>
1698 * utils.c (isfile): Use `lstat' instead of `stat'.
1700 1997-03-29 Hrvoje Niksic <hniksic@srce.hr>
1702 * utils.c (numdigit): Use explicit test.
1704 1997-03-21 Hrvoje Niksic <hniksic@srce.hr>
1706 * http.c (http_loop): Always use `url_filename' to get u->local.
1708 1997-03-20 Hrvoje Niksic <hniksic@srce.hr>
1710 * url.c: Recognize https.
1712 1997-03-13 Hrvoje Niksic <hniksic@srce.hr>
1714 * recur.c (recursive_retrieve): Lowercase just the host name.
1716 1997-03-09 Hrvoje Niksic <hniksic@srce.hr>
1718 * url.c (get_urls_file): Use the correct test.
1719 (get_urls_html): Ditto.
1721 1997-03-07 Hrvoje Niksic <hniksic@srce.hr>
1723 * connect.c: Reverted addrlen to int.
1725 * init.c (parse_line): Check for -1 instead of NONE.
1727 * version.c: Changed version to 1.4.5.
1729 1997-02-17 Hrvoje Niksic <hniksic@srce.hr>
1731 * init.c: New option netrc.
1732 (initialize): Don't parse .netrc.
1734 * cmpt.c (recursive): Return rp.
1735 (strptime_internal): Match the long strings first, the abbreviated
1738 1997-02-16 Hrvoje Niksic <hniksic@srce.hr>
1740 * http.c (check_end): New function.
1741 (http_atotm): Use it.
1743 1997-02-13 gilles Cedoc <gilles@cedocar.fr>
1745 * http.c (gethttp): Use them.
1747 * init.c: New options proxy_user and proxy_passwd.
1749 1997-02-14 Hrvoje Niksic <hniksic@srce.hr>
1751 * ftp.c (ftp_retrieve_list): Create links even if not relative.
1753 1997-02-10 Hrvoje Niksic <hniksic@srce.hr>
1755 * recur.c (recursive_retrieve): Lowercase the host name, if the
1756 URL is not "optimized".
1758 * host.c (realhost): Return l->hostname, even if it matches with
1761 1997-02-10 Marin Purgar <pmc@asgard.hr>
1763 * connect.c: Make addrlen size_t instead of int.
1766 1997-02-09 Gregor Hoffleit <flight@mathi.uni-heidelberg.DE>
1768 * systhings.h: Define S_ISLNK on NeXT too.
1770 1997-02-09 Hrvoje Niksic <hniksic@srce.hr>
1772 * version.c: Released 1.4.3.
1774 * url.c: Futher update to list of protostrings.
1775 (skip_proto): Skip `//' correctly for FTP and HTTP.
1777 * url.c (get_urls_html): Handle bogus `http:' things a little
1780 * main.c (main): Removed `follow-ftp' from `f'.
1781 (main): Dumped the `prefix-files' and `file-prefix' options and
1782 features; old and bogus.
1783 (main): Exit on failed setval() in `-e'.
1785 * http.c (fetch_next_header): Use it to detect header continuation
1788 * retr.c (buf_peek): New function.
1790 1997-02-08 Hrvoje Niksic <hniksic@srce.hr>
1792 * wget.h: Include time.h and stuff.
1794 1997-02-08 Roger Beeman <beeman@cisco.com>
1796 * ftp.c: Include <time.h>
1798 1997-02-07 Hrvoje Niksic <hniksic@srce.hr>
1800 * url.c (findurl): Would read over buffer limits.
1802 1997-02-06 Hrvoje Niksic <hniksic@srce.hr>
1804 * ftp-ls.c (ftp_parse_unix_ls): Allow spaces in file names.
1806 1997-02-05 Hrvoje Niksic <hniksic@srce.hr>
1808 * http.c (http_atotm): Initialize tm.is_dst.
1810 1997-02-02 Hrvoje Niksic <hniksic@srce.hr>
1812 * http.c (gethttp): Don't print the number of retrieved headers.
1814 * main.c (main): New option `--no-clobber', alias for `-nc'.
1816 * url.c: Recognize `https://'.
1818 1997-02-01 Hrvoje Niksic <hniksic@srce.hr>
1820 * host.c (herrmsg): Don't use h_errno.
1822 1997-01-30 Hrvoje Niksic <hniksic@srce.hr>
1824 * host.c (accept_domain): Use it.
1826 * main.c (main): New option `--exclude-domains'.
1828 * retr.c (retrieve_url): Use it.
1829 (retrieve_url): Bail out when an URL is redirecting to itself.
1831 * url.c (url_equal): New function.
1833 1997-01-29 Hrvoje Niksic <hniksic@srce.hr>
1835 * connect.c: Include arpa/inet.h instead of arpa/nameser.h.
1837 * http.c (mk_utc_time): New function.
1838 (http_atotm): Use it; handle time zones correctly.
1840 1997-01-28 Hrvoje Niksic <hniksic@srce.hr>
1844 * ftp-basic.c: Use it instead of WRITE.
1846 * connect.c (iwrite): New function.
1848 1997-01-27 Hrvoje Niksic <hniksic@srce.hr>
1850 * cmpt.c (mktime): New function.
1852 * netrc.c: Include <sys/types.h>.
1854 * main.c (main): Wouldn't recognize --spider.
1856 * retr.c (rate): Use `B', `KB' and `MB'.
1857 (reset_timer,elapsed_time): Moved from utils.c.
1859 * ftp.c (ftp_retrieve_list): Ditto.
1861 * http.c (http_loop): Don't touch the file if opt.dfp.
1863 1997-01-24 Hrvoje Niksic <hniksic@srce.hr>
1867 * ftp.c (ftp_retrieve_glob): New argument semantics.
1868 (ftp_retrieve_dirs): Use it.
1871 * html.c (htmlfindurl): Recognize `'' as the quote char.
1873 1997-01-23 Hrvoje Niksic <hniksic@srce.hr>
1875 * ftp.c (ftp_loop_internal): Use it.
1877 * utils.c (remove_link): New function.
1879 1997-01-22 Hrvoje Niksic <hniksic@srce.hr>
1881 * retr.c (retrieve_url): Require STRICT redirection URL.
1883 * url.c (parseurl): New argument STRICT.
1885 * http.c (hparsestatline): Be a little-bit less strict about
1888 1997-01-21 Hrvoje Niksic <hniksic@srce.hr>
1890 * http.c (gethttp): Use it.
1892 * main.c (main): Don't use '<digit>' as options.
1894 * init.c: New option ignore_length.
1896 * http.c (gethttp): Ditto.
1897 (http_loop): Check for redirection without Location:.
1898 (gethttp): Don't print Length unless RETROKF.
1900 * ftp.c (getftp): Use it.
1902 * url.c (mkalldirs): New function.
1904 * utils.c (mymkdir): Don't check for existing non-directory.
1906 * url.c (mkstruct): Don't create the directory.
1908 1997-01-20 Hrvoje Niksic <hniksic@srce.hr>
1910 * init.c (setval): Removed NO_RECURSION checks.
1912 1997-01-19 Hrvoje Niksic <hniksic@srce.hr>
1914 * version.c: "Released" 1.4.3-pre2.
1916 * recur.c (recursive_retrieve): Bypass host checking only if URL
1917 is ftp AND parent URL is not ftp.
1919 * ftp-basic.c (ftp_request): Print out Turtle Power.
1921 * ftp.c (ftp_loop): Call ftp_retrieve_glob with 0 if there's no
1923 (ftp_retrieve_glob): Call ftp_loop_internal even on empty list, if
1926 * http.c (gethttp): Be a little bit smarter about status codes.
1928 * recur.c (recursive_retrieve): Always reset opt.recursive when
1931 1997-01-18 Hrvoje Niksic <hniksic@srce.hr>
1933 * retr.c (retrieve_url): New variable location_changed; use it for
1934 tests instead of mynewloc.
1935 (retrieve_url): Allow heuristic adding of html.
1937 * url.c (url_filename): Don't use the `%' in Windows file names.
1939 * http.c (http_loop): Always time-stamp the local file.
1941 * http.c (http_loop): Ditto.
1943 * ftp.c (ftp_retrieve_list): Use it.
1945 * utils.c (my_touch): New function.
1947 * ftp.c (ftp_retrieve_list): Use #ifdef HAVE_STRUCT_UTIMBUF
1948 instead of #ifndef NeXT.
1950 * utils.c (strptime): New version, by Ulrich Drepper.
1952 1997-01-17 Hrvoje Niksic <hniksic@srce.hr>
1954 * http.c (haccepts_none): Renamed from `haccepts_bytes'.
1955 (gethttp): If haccepts_none(), disable ACCEPTRANGES.
1956 (http_loop): Would remove ACCEPTRANGES.
1958 * ftp.c (getftp): Call ftp_list with NULL.
1960 1997-01-15 Hrvoje Niksic <hniksic@srce.hr>
1962 * html.c (ftp_index): Don't print minutes and seconds if we don't
1963 know them; beautify the output.
1965 * ftp.c (getftp): Don't close the socket on FTPNSFOD.
1967 1997-01-14 Hrvoje Niksic <hniksic@srce.hr>
1969 * utils.c (strptime): New function.
1970 (strptime): Don't use get_alt_number.
1971 (strptime): Don't use locale.
1972 (match_string): Made it a function.
1974 1997-01-12 Hrvoje Niksic <hniksic@srce.hr>
1976 * http.c (http_atotm): New function.
1977 (http_loop): Use it.
1979 * atotm.c: Removed from the distribution.
1981 * http.c (base64_encode_line): Rewrite.
1983 1997-01-09 Hrvoje Niksic <hniksic@srce.hr>
1985 * ftp.c (getftp): Use ftp_expected_bytes; print size.
1987 * ftp-basic.c (ftp_response): Use ftp_last_respline.
1988 (ftp_expected_bytes): New function.
1990 * ftp.c (getftp): Print the unauthoritative file length.
1992 * ftp-ls.c: Renamed from ftp-unix.c.
1993 (ftp_parse_ls): Moved from ftp.c.
1994 (ftp_parse_unix_ls): Recognize seconds in time spec.
1995 (ftp_parse_unix_ls): Recognize year-less dates of the previous
1998 1997-01-08 Hrvoje Niksic <hniksic@srce.hr>
2000 * ftp-basic.c: Don't declare errno if #defined.
2002 * host.c (ftp_getaddress): Check for sysinfo legally.
2004 1997-01-08 Darko Budor <dbudor@diana.zems.fer.hr>
2006 * connect.c (iread): Use READ.
2008 1996-12-23 Hrvoje Niksic <hniksic@srce.hr>
2010 * url.c: Recognize finger, rlogin, tn3270, mid and cid as valid
2013 1996-12-22 Hrvoje Niksic <hniksic@srce.hr>
2015 * host.c (ftp_getaddress): Allow `.' in hostname.
2017 1996-12-26 Darko Budor <dbudor@zems.fer.hr>
2019 * wget.h: READ and WRITE macros for use instead of read and write
2020 on sockets, grep READ *.c, grep WRITE *.c
2022 * wsstartup.c: new file - startup for winsock
2024 * wsstartup.h: new file
2026 * win32decl.h: new file - fixup for <errno.h> and winsock trouble
2028 * configure.bat: Configure utility for MSVC
2030 * src/Makefile.ms,config.h.ms: new files for use with MSVC 4.x
2032 1996-12-22 Hrvoje Niksic <hniksic@srce.hr>
2034 * version.c: Released 1.4.3-pre.
2036 * utils.c (prnum): Accept long.
2037 (legible): Use prnum().
2039 * connect.c (make_connection): Accept port as short.
2042 * http.c (gethttp): Use search_netrc.
2044 1996-12-21 Hrvoje Niksic <hniksic@srce.hr>
2046 * ftp.c (getftp): Use search_netrc.
2048 * netrc.c (free_netrc): New function.
2050 * init.c (home_dir): New function.
2052 * url.c (convert_links): Allow REL2ABS changes.
2054 1996-12-21 Gordon Matzigkeit <gord@gnu.ai.mit.edu>
2056 * netrc.c: New file.
2057 (parse_netrc, maybe_add_to_list): New functions.
2059 1996-12-17 Hrvoje Niksic <hniksic@srce.hr>
2061 * retr.c (retrieve_url): Reset opt.recursion before calling
2062 ftp_loop if it is reached through newloc.
2064 * init.c (run_wgetrc): Print the wgetrc path too, when reporting
2065 error; don't use "Syntax error", since we don't know if it is
2066 really a syntax error.
2068 1996-12-16 Hrvoje Niksic <hniksic@srce.hr>
2070 * utils.c (acceptable): Extract the filename part of the path.
2072 * recur.c (recursive_retrieve): Call acceptable() with the right
2073 argument; would bug out on wildcards.
2075 * init.c (parse_line): Likewise.
2077 * html.c (htmlfindurl): Cast to char * when calling stuff.
2079 1996-12-15 Hrvoje Niksic <hniksic@srce.hr>
2081 * ftp.c (getftp): Use ftp_pasv.
2083 * ftp-basic.c (ftp_request): Accept NULL value.
2084 (ftp_pasv): New function.
2086 * options.h (struct options): Add passive FTP option.
2088 1996-12-15 Hrvoje Niksic <hniksic@srce.hr>
2090 * url.c (parseurl): Debug output.
2092 * utils.c (path_simplify): New one, adapted from bash's
2093 canonicalize_pathname().
2095 1996-12-14 Hrvoje Niksic <hniksic@srce.hr>
2097 * ftp.c (getftp): Don't discard the buffer.
2099 * retr.c (get_contents): New parameter nobuf.
2101 1996-12-13 Shawn McHorse <riffraff@txdirect.net>
2103 * html.c (htmlfindurl): Recognize <meta contents="d; URL=...".
2105 * init.c (setval): Strip the trailing slashes on CVECDIR.
2107 1996-12-13 Hrvoje Niksic <hniksic@srce.hr>
2109 * init.c: Make excludes and includes under CVECDIR instead of
2112 1996-12-13 Shawn McHorse <riffraff@txdirect.net>
2114 * url.c (get_urls_html): Skip "http:".
2116 1996-12-13 Hrvoje Niksic <hniksic@srce.hr>
2118 * utils.c (strcasecmp): From glibc.
2119 (strncasecmp): Also.
2122 * url.c: Added javascript: to the list of URLs prefixes.
2124 1996-12-12 Shawn McHorse <riffraff@txdirect.net>
2126 * recur.c (retrieve_robots): Print the warning message only if
2129 1996-12-12 Gregor Hoffleit <flight@mathi.uni-heidelberg.DE>
2131 * ftp.c (ftp_retrieve_list): Use NeXT old utime interface.
2133 1996-12-12 Hrvoje Niksic <hniksic@srce.hr>
2135 * systhings.h: New file.
2137 * ../configure.in: Check for utime.h
2139 * ftp.c: Check whether we have unistd.h.
2141 1996-11-27 Hrvoje Niksic <hniksic@srce.hr>
2143 * recur.c (recursive_retrieve): Send the canonical URL as referer.
2144 (recursive_retrieve): Call get_urls_html with the canonical URL.
2146 1996-12-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
2148 * (configure.in, config.h.in, src/Makefile.in, src/*.[ch]): Add
2149 ansi2knr support for compilers which don't support ANSI style
2150 function prototypes and signatures.
2152 * (aclocal.m4, src/ansi2knr.c, src/ansi2knr.1): New files.
2154 1996-11-26 Hrvoje Niksic <hniksic@srce.hr>
2156 * url.c: Use it; Recognize paths ending with "." and ".." as
2158 (url_filename): Append .n whenever file exists and could be a
2161 * url.h (ISDDOT): New macro.
2163 * init.c (parse_line): Use unsigned char.
2165 * url.c (get_urls_html): Cast to unsigned char * when calling
2168 * html.c (htmlfindurl): Use unsigned char.
2170 * version.c: Changed version to 1.4.3.
2172 1996-11-25 Hrvoje Niksic <hniksic@srce.hr>
2174 * version.c: Released 1.4.2.
2176 * ftp.c (getftp): Simplified assertion.
2177 (ftp_loop_internal): Remove symlink before downloading.
2178 (ftp_retrieve_list): Unlink the symlink name before attempting to
2181 * options.h (struct options): Renamed print_server_response to
2184 * ftp.c (rel_constr): Removed.
2185 (ftp_retrieve_list): Don't use it.
2186 (ftp_retrieve_list): Use opt.retr_symlinks.
2188 1996-11-24 Hrvoje Niksic <hniksic@srce.hr>
2190 * main.c (main): New option retr_symlinks.
2192 * url.c (convert_links): Print verbose message.
2194 1996-11-24 Hrvoje Niksic <hniksic@srce.hr>
2196 * http.c (http_loop): Reset newloc in the beginning of function;
2197 would cause FMR in retrieve_url.
2199 1996-11-23 Hrvoje Niksic <hniksic@srce.hr>
2201 * recur.c (convert_all_links): Find the URL of each HTML document,
2202 and feed it to get_urls_html; would bug out.
2203 (convert_all_links): Check for l2 instead of dl; removed dl.
2205 * url.c (convert_links): Don't refer to freed newname.
2207 * recur.c (recursive_retrieve): Add this_url to urls_downloaded.
2209 * main.c (main): Print the OS_TYPE in the debug output, too.
2211 * recur.c (recursive_retrieve): Check for opt.delete_after.
2213 * main.c (main): New option delete-after.
2215 * init.c (setval): Cleaned up.
2217 1996-11-21 Hrvoje Niksic <hniksic@srce.hr>
2219 * Makefile.in (wget): Make `wget' the default target.
2221 * ftp.c (ftp_loop_internal): Move noclobber checking out of the
2223 (ftp_retrieve_list): Warn about non-matching sizes.
2225 * http.c (http_loop): Made -nc non-dependent on opt.recursive.
2227 * init.c (setnum): Renamed from setnuminf; New argument flags.
2230 * main.c (main): Sorted the options.
2231 (main): New option --wait.
2233 1996-11-21 Shawn McHorse <riffraff@txdirect.net>
2235 * html.c (htmlfindurl): Reset s->in_quote after getting out of
2238 1996-11-20 Hrvoje Niksic <hniksic@srce.hr>
2240 * version.c: Changed version to 1.4.2.
2242 1996-11-20 Hrvoje Niksic <hniksic@srce.hr>
2244 * version.c: Released 1.4.1.
2246 * html.c (html_quote_string): New function.
2247 (ftp_index): Use it.
2248 (htmlfindurl): A more gentle ending debug message.
2250 * ftp.c (ftp_loop): Check for opt.htmlify.
2252 * init.c: New command htmlify.
2254 * ftp.c (getftp): Nicer error messages, with `'-encapsulated
2256 (ftp_loop): Print size of index.html.
2258 * init.c (setval): Implement "styles".
2260 * main.c (main): New option dotstyle.
2262 1996-11-19 Hrvoje Niksic <hniksic@srce.hr>
2264 * ftp.c (getftp): Close the master socket in case of errors, after
2267 * connect.c (bindport): Initialize msock to -1.
2269 * ftp.c (getftp): Initialize dtsock to -1.
2271 * connect.c (closeport): Don't close sock if sock == -1.
2273 1996-11-18 Hrvoje Niksic <hniksic@srce.hr>
2275 * init.c (setnuminf): Nuked default value -- just leave unchanged.
2276 (setval): Don't send default values.
2277 (defaults): Use DEFAULT_TIMEOUT -- aaargh.
2279 * options.h (struct options): Use long for dot_bytes.
2281 * init.c (setquota): Renamed to setbytes.
2282 (setval): Use setbytes on DOTBYTES.
2284 1996-11-17 Hrvoje Niksic <hniksic@srce.hr>
2286 * ftp.c (getftp): Initialize con->dltime.
2288 * recur.c (recursive_retrieve): Use same_host instead of
2289 try_robots; simply load robots_txt whenever the host is changed.
2290 (recursive_retrieve): Free forbidden before calling parse_robots.
2292 1996-11-16 Hrvoje Niksic <hniksic@srce.hr>
2294 * retr.c (show_progress): Use them.
2296 * options.h (struct options): New options dot_bytes, dots_on_line
2299 1996-11-16 Mark Boyns <boyns@sdsu.edu>
2301 * recur.c (recursive_retrieve): Retrieve directories regardless of
2302 acc/rej rules; check for empty u->file.
2304 1996-11-14 Hrvoje Niksic <hniksic@srce.hr>
2306 * init.c (setval): Use it.
2308 * utils.c (merge_vecs): New function.
2310 * init.c (setval): Reset the list-type functions when encountering
2313 1996-11-14 Shawn McHorse <riffraff@txdirect.net>
2315 * recur.c (recursive_retrieve): Use base_url instead of this_url
2318 1996-11-14 Shawn McHorse <riffraff@txdirect.net>
2320 * html.c (htmlfindurl): Reset s->in_quote after exiting the quote.
2322 1996-11-13 Hrvoje Niksic <hniksic@srce.hr>
2324 * utils.c (sepstring): Rewrote; don't use strtok.
2326 * recur.c (recursive_retrieve): Enter assorted this_url to slist
2327 when running the first time.
2328 (retrieve_robots): Warn to ignore errors when robots are loaded.
2330 * utils.c (load_file): Moved from url.c.
2332 * http.c: Made static variables const too in h* functions.
2334 * main.c (main): Renamed --continue-ftp to --continue.
2336 * recur.c (recursive_retrieve): Use it.
2338 * utils.c (frontcmp): New function.
2340 * url.c (accdir): New function.
2342 * html.c (htmlfindurl): Recognize <area href=...>.
2344 * ftp.c (ftp_retrieve_dirs): Implemented opt.includes.
2346 * init.c (setval): Free the existing opt.excludes and
2347 opt.includes, if available.
2349 * main.c (main): New option -I.
2351 1996-11-12 Hrvoje Niksic <hniksic@srce.hr>
2353 * ftp.c (ftp_retrieve_glob): Do not weed out directories.
2355 * version.c: Changed version to 1.4.1.
2357 1996-11-11 Hrvoje Niksic <hniksic@srce.hr>
2359 * version.c: Released 1.4.0.
2361 1996-11-10 Hrvoje Niksic <hniksic@srce.hr>
2363 * main.c (main): Free com and val after parse_line.
2364 (printhelp): Reorder the listing.
2366 * http.c: More robust header parsing.
2368 * http.c: Allow any number of spaces, or no spaces, precede ':'.
2369 (hskip_lws): New function.
2370 (haccepts_bytes): New function.
2373 * init.c (setval): Check header sanity.
2374 (setval): Allow resetting of headers.
2376 1996-11-10 Hrvoje Niksic <hniksic@srce.hr>
2378 * http.c (http_loop): Don't use has_wildcards.
2380 * http.c (gethttp): Free all_headers -- would leak.
2382 * recur.c (recursive_retrieve): Initialize depth to 1 instead of
2383 0 -- this fixes a long-standing bug in -rl.
2385 1996-11-09 Hrvoje Niksic <hniksic@srce.hr>
2387 * ftp.c: Use -1 as "impossible" value for con->fd.
2389 * url.h (URL_SEPARATOR): Don't treat `*' and `+' as separators.
2391 * init.c (parse_line): Use isalpha.
2393 * ftp-unix.c: Use HAVE_UNISTD_H.
2395 * mtch.c (has_wildcards): Don't match \.
2397 * http.c (http_loop): Warn on HTTP wildcard usage.
2399 1996-11-08 Hrvoje Niksic <hniksic@srce.hr>
2401 * url.c (url_filename): Do not create numbered suffixes if
2402 opt.noclobber -- would bug out on -nc.
2404 1996-11-07 Hrvoje Niksic <hniksic@srce.hr>
2406 * recur.c (parse_robots): Don't chuck out the commands without
2407 arguments (`Disallow:<empty>' didn't work).
2408 (parse_robots): Compare versions lowercase.
2409 (parse_robots): Match on base_version, not version_string!
2410 (parse_robots): Handle comments properly.
2411 (parse_robots): Match versions in a sane way.
2413 * init.c: Print nicer error messages.
2415 * version.c: Changed version to 1.4.0.
2417 1996-11-06 Hrvoje Niksic <hniksic@srce.hr>
2419 * version.c: Released 1.4.0-test2.
2421 * init.c (run_wgetrc): Close fp.
2423 * ftp.c (ftp_retrieve_dirs): Allocate the correct length for
2426 1996-11-06 Hrvoje Niksic <hniksic@srce.hr>
2428 * init.c (setquota): Allow inf as quota specification.
2430 1996-11-05 Hrvoje Niksic <hniksic@srce.hr>
2432 * ftp.c (ftp_retrieve_dirs): Return QUOTEXC if quota exceeded.
2433 (ftp_retrieve_glob): Return QUOTEXC on quota exceeded.
2435 * main.c (main): Check for quota by comparison with downloaded
2436 stuff, not from status.
2438 * connect.c (select_fd): Should compile on HPUX without warnings now.
2440 * ftp.c (ftp_get_listing): Check whether ftp_loop_internal
2443 1996-11-04 Hrvoje Niksic <hniksic@srce.hr>
2445 * ftp.c (ftp_retrieve_glob): Print the pattern nicely.
2446 (getftp): Return FTPRETRINT on control connection error.
2448 * html.c (htmlfindurl): Recognize <embed src=...> and
2450 (ftp_index): Handle username and password correctly.
2452 * main.c (main): Made `-np' a synonim for --no-parent.
2454 1996-11-02 Hrvoje Niksic <hniksic@srce.hr>
2456 * ftp.c (ftp_loop): Check for opt.ftp_glob too before calling
2459 * version.c: Changed version to 1.4.0-test2.
2461 1996-11-02 Hrvoje Niksic <hniksic@srce.hr>
2463 * version.c: Released 1.4.0-test1.
2465 * url.c (str_url): Don't use sprintf when creating %2F-prefixed
2467 (convert_links): Removed definition of make_backup.
2469 * http.h: Removed definition of MAX_ERROR_LENGTH.
2471 * host.c (ftp_getaddress): Check for "(none)" domains.
2473 * ftp.c (ftp_retrieve_dirs): Docfix.
2475 * http.c (gethttp): Use ou->referer instead of u->referer.
2477 * retr.c (retrieve_url): Reset u to avoid freeing pointers twice;
2478 this was known to cause coredumps on Linux.
2480 * html.c (ftp_index): Cast the argument to local_time to time_t *.
2482 1996-11-01 Hrvoje Niksic <hniksic@srce.hr>
2484 * connect.c (select_fd): Use exceptfds -- once and for all.
2486 * retr.c (retrieve_from_file): Free filename after
2488 (retrieve_from_file): Send RFIRST_TIME to recursive_retrieve on
2489 first-time retrieval.
2490 (retrieve_from_file): Return uerr_t; new argument, count.
2491 (retrieve_from_file): Break on QUOTEXC.
2493 * init.c (setquota): Fixed a bug that caused rejection of
2494 non-postfixed values..
2496 1996-10-30 Hrvoje Niksic <hniksic@srce.hr>
2498 * version.c: Changed name to wget.
2500 * connect.c (iread): Smarter use of select.
2501 (select_fd): Set errno on timeout. If not timeout, return 1
2504 1996-10-29 Hrvoje Niksic <hniksic@srce.hr>
2506 * ftp.c (ftp_loop_internal): Don't use con->cmd before
2509 1996-10-26 Hrvoje Niksic <hniksic@srce.hr>
2511 * http.c (gethttp): Send correct referer when using proxy.
2512 (gethttp): Use struct urlinfo ou to access the relevant data; send
2513 correct authorization in all cases.
2515 * host.c (same_host): Use skip_uname to skip username and
2518 * url.c (skip_uname): New function.
2521 * host.c (same_host): Do not assume HTTP -- same_host should now
2522 be totally foolproof.
2524 * url.c (skip_proto): New function.
2525 (parse_uname): Use it.
2527 * http.c (gethttp): Create local user and passwd from what is
2530 * url.c (parseurl): Check for HTTP username and password too.
2532 1996-10-25 Hrvoje Niksic <hniksic@srce.hr>
2534 * config.h.in: Removed #define gethostbyname R...
2536 1996-10-22 Hrvoje Niksic <hniksic@srce.hr>
2538 * version.c: Changed version to 1.4.0-test1.
2540 1996-10-21 Hrvoje Niksic <hniksic@srce.hr>
2542 * version.c: "Released" 1.4b29.
2544 * recur.c (recursive_retrieve): Check for no_parent.
2546 * init.c (setval): Option update.
2548 * main.c (main): New option no-parent.
2550 * options.h (struct options): New variable no_parent.
2552 * recur.c (recursive_retrieve): Only files are checked for
2553 opt.accepts and opt.rejects.
2554 (recursive_retrieve): Check directories for opt.excludes.
2555 (recursive_retrieve): Make the dir absolute when checking
2558 * html.c (htmlfindurl): Recognize <applet code=...> and <script
2561 1996-10-18 Hrvoje Niksic <hniksic@srce.hr>
2563 * ftp.c (getftp): Do not line-break assert entries at all.
2564 (ftp_retrieve_dirs): docfix.
2566 * connect.c (select_fd): Use fd + 1 as nfds.
2568 * version.c: Changed version to 1.4b29.
2570 1996-10-18 Hrvoje Niksic <hniksic@srce.hr>
2572 * version.c: "Released" 1.4b28.
2574 * ftp.c (ftp_loop_internal): Check whether f->size == len and
2575 don't continue the loop if it is.
2576 (ftp_get_listing): Remove list_filename on unsuccesful loop.
2578 1996-10-17 Hrvoje Niksic <hniksic@srce.hr>
2580 * ftp.c (ftp_loop_internal): Use strcpy to initialize tmp.
2581 (getftp): Do not use multiline assert.
2583 * http.c (hparsestatline): Use mjr and mnr instead of major and
2584 minor, which don't compile on Ultrix.
2585 (http_loop): Use strcpy() to initialize tmp.
2587 * all: Geturl -> Fetch
2589 1996-10-17 Hrvoje Niksic <hniksic@srce.hr>
2591 * recur.c (parse_robots): Fixed an off-by-one bug when looking for
2594 * html.c (htmlfindurl): Fixed several possible off-by-one bugs by
2595 moving `bufsize &&' to the beginning of each check in for-loops.
2597 * recur.c (parse_robots): Close fp on exit.
2599 * url.c (mymkdir): Check for each directory before creating.
2601 1996-10-16 Hrvoje Niksic <hniksic@srce.hr>
2603 * version.c: Changed version to 1.4b28.
2605 1996-10-16 Hrvoje Niksic <hniksic@srce.hr>
2607 * version.c: "Released" 1.4b27.
2609 * init.c (parse_line): Use isspace.
2610 (parse_line): Free *com on all errors.
2612 * ftp.c (ftp_loop): Change FTPOK to RETROK before exiting.
2613 (delelement): Use next instead of f->next and prev instead of
2615 (delelement): Free the members of the deleted element.
2617 * http.c (http_loop): Do not return RETROK on code != 20x.
2619 * init.c (cleanup): Free opt.user_header.
2620 (cleanup): Free opt.domains.
2622 * url.c (freelists): Moved to cleanup().
2624 * http.c (hparsestatline): Docfix.
2626 * main.c (main): Return with error status on unsuccesful
2629 * init.c (setval): Do not remove listing when mirroring.
2631 * url.c (url_filename): Use opt.fileprefix.
2633 * ftp.c (ftp_get_listing): Use url_filename to get filename for
2636 * main.c (main): New option: -rn.
2638 1996-10-15 Hrvoje Niksic <hniksic@srce.hr>
2640 * Makefile.in (RM): Added RM = rm -f.
2642 * host.c (clean_hosts): New function.
2643 (free_hlist): Just free the list, no reset.
2645 * version.c: Changed version to 1.4b27.
2647 1996-10-13 Hrvoje Niksic <hniksic@srce.hr>
2649 * version.c: "Released" 1.4b26.
2651 * retr.c (retrieve_from_file): If call get_urls_html with
2652 opt.spider to make it silent in spider mode.
2654 * url.c (str_url): Use CLEANDUP instead of URL_CLEANSE.
2656 * url.h (CLEANDUP): New macro.
2658 * http.c (gethttp): Fixed a bug that freed location only when it
2661 * retr.c (retrieve_url): Free url if it will not be stored,
2662 i.e. newloc is NULL.
2664 * html.c (htmlfindurl): Handle exiting from quotes correctly; the
2665 old version would bug out on <a href="x#a"href="y">.
2667 * html.h (state_t): New member in_quote.
2669 * html.c (htmlfindurl): Free s->attr at the beginning of
2672 * recur.c (recursive_retrieve): Recognize RCLEANUP.
2673 (tried_robots): Make hosts a global variable.
2674 (recursive_retrieve): Free constr after URL host optimization.
2675 (tried_robots): Free urlinfo before exiting.
2677 * utils.c (free_slist): New function.
2679 * recur.c (recursive_retrieve): Use flags to add cleanup
2682 * main.c (main): Free filename after recursive_retrieve.
2684 * http.c (gethttp): Store successful responses too.
2686 1996-10-12 Hrvoje Niksic <hniksic@srce.hr>
2688 * all: Constified the whole source. This required some minor
2689 changes in many functions in url.c, possibly introducing bugs -- I
2692 * ftp-basic.c: Removed last_respline.
2694 * http.c (gethttp): Free type.
2696 * host.c (same_host): Free real1 and real2.
2698 * main.c (main): New option --spider.
2700 * retr.c (get_contents): Don't reset errno.
2702 * main.c (main): Sorted the options.
2704 * connect.c (iread): Set errno to ETIMEDOUT only if it was left
2705 uninitialized by select().
2707 * http.c (http_loop): Print the time when the connection is
2709 (gethttp): Debug-print the HTTP request.
2711 1996-10-11 Hrvoje Niksic <hniksic@srce.hr>
2713 * connect.c (iread): Do not try reading after timeout.
2715 * main.c (main): Would bug out on -T.
2717 * connect.c (select_fd): Do not use exceptfds.
2718 (iread): Set ETIMEDOUT on select_fd <= 0.
2720 * version.c: Changed version to 1.4b26.
2722 1996-10-10 Hrvoje Niksic <hniksic@srce.hr>
2724 * version.c: "Released" 1.4b25.
2726 * ftp-unix.c (ftp_parse_unix_ls): Ignore lines without file name
2729 * http.c (gethttp): Add errcode to struct hstat.
2730 (http_loop): Use it.
2732 * url.c (no_proxy_match): Simplify using char** for no_proxy.
2734 * options.h (struct options): Make opt.no_proxy a vector.
2736 * utils.c (sepstring): Use !*s instead of !strlen(s).
2738 * init.c (setval): Set opt.maxreclevel to 0 on --mirror.
2739 (getperms): Use ISODIGIT instead of isdigit.
2741 * ftp.c (getftp): Print time.
2743 * main.c (main): Use legible output of downloaded quantity.
2745 * ftp.c (getftp): Use elapsed_time().
2746 (ftp_loop_internal): Use rate().
2748 * http.c (http_loop): Add download ratio output; Use rate().
2750 * utils.c (rate): New function.
2752 1996-10-09 Hrvoje Niksic <hniksic@srce.hr>
2754 * http.c (http_loop): Use timer.
2756 * ftp.c: Split to ftp-basic.c and ftp.c
2758 * utils.c (reset_timer): New function.
2759 (elapsed_time): New function.
2761 * retr.c (show_progress): Make bytes_in_line and offs long; should
2762 work on 16-bit machines.
2764 1996-10-08 Hrvoje Niksic <hniksic@srce.hr>
2766 * url.c (in_acclist): New argument backward.
2768 * ftp.c (ftp_retrieve_glob): Use acceptable() to determine whether
2769 a file should be retrieved according to suffix.
2770 (ftp_get_listing): Check the return value of unlink; Do not call
2771 ftp_retrieve_dirs if depth reached maxreclevel.
2772 (ftp_retrieve_dirs): Check whether the directory is in
2775 * main.c (main): Print the version number at the beginning of
2777 (main): Use strrchr when creating exec_name.
2779 * ftp.c (ftp_retrieve_glob): Do not close control connection.
2781 * version.c: Changed version to 1.4b25.
2783 1996-10-07 Hrvoje Niksic <hniksic@srce.hr>
2785 * version.c: "Released" 1.4b24.
2787 * Makefile.in: Rewrite.
2789 * ftp.c (ftp_loop_internal): Likewise.
2791 * retr.c (time_str): Check for failed time().
2793 * html.c (htmlfindurl): Recognize <fig src> and <overlay src> from
2796 * retr.c (time_str): Return time_t *.
2798 * connect.c (bindport): Close msock on unsuccesful bind.
2799 (bindport): The same for getsockname and listen.
2801 * retr.c (retrieve_url): Allow any number of retries on
2804 * http.c (gethttp): Do not treat errno == 0 as timeout.
2805 (http_loop): Likewise.
2806 (http_loop): Cosmetic changes.
2808 * connect.c (iread): Set errno to ETIMEDOUT in case of timeout.
2810 * retr.c (get_contents): Reset errno.
2812 * ftp.c (getftp): Minor fixes.
2814 1996-10-06 Hrvoje Niksic <hniksic@srce.hr>
2816 * http.c: Do not use backups.
2818 * geturl.1 (WARNING): Warn that man-page could be obsolete.
2820 * getopt.c (getopt_long): Moved to getopt.c
2822 * geturl.texi: Enhanced.
2824 * main.c (main): Use it.
2826 * recur.c (convert_all_links): New function.
2828 * utils.c (add_slist): New argument flags.
2830 * recur.c (recursive_retrieve): Update a list of downloaded URLs.
2831 (parse_robots): Do not chuck out empty value fields.
2832 (parse_robots): Make yourself welcome on empty Disallow.
2834 * version.c: Changed version to 1.4b24.
2836 1996-10-06 Hrvoje Niksic <hniksic@srce.hr>
2838 * version.c: "Released" 1.4b23.
2840 * ftp.c (ftp_loop_internal): Get the time after getftp.
2842 * Makefile.in (install.info): New target.
2845 * http.c (http_loop): Fix output when doing -O.
2847 1996-10-05 Hrvoje Niksic <hniksic@srce.hr>
2849 * geturl.texi: New file.
2851 * main.c (main): Do not print the warnings and download summary if
2854 * version.c: Changed version to 1.4b23.
2856 1996-10-05 Hrvoje Niksic <hniksic@srce.hr>
2858 * "Released" 1.4b22.
2860 * atotm.c (atotm): Use True and False instead of TRUE and FALSE,
2861 to avoid redefinition warnings.
2863 * host.c (store_hostaddress): Use memcpy() to copy the address
2864 returned by inet_addr.
2866 * version.c: Changed version to 1.4b22.
2868 1996-10-04 Hrvoje Niksic <hniksic@srce.hr>
2870 * version.c: "Released" 1.4b21.
2872 * ftp-unix.c (ftp_parse_ls): Renamed to ftp_parse_unix_ls.
2874 * ftp.c (ftp_port): Use conaddr.
2875 (getftp): Print the file length.
2876 (ftp_retrieve_list): Check the stamps of plain files only.
2878 * connect.c (closeport): Do not call shutdown().
2879 (conaddr): New function.
2881 * html.c (ftp_index): Made it dfp-aware.
2883 * init.c (cleanup): New name of freemem. Close opt.dfp.
2885 * ftp.c (getftp): Use opt.dfp if it is set.
2887 * ftp-unix.c (ftp_parse_ls): Recognize time in h:mm format.
2889 * ftp.c (ftp_retrieve_dirs): Fixed a bug that caused incorrect
2890 CWDs to be sent with recursive FTP retrievals.
2892 1996-10-03 Hrvoje Niksic <hniksic@srce.hr>
2894 * recur.c (parse_robots): Made it more compliant with "official"
2897 * http.c: New function.
2899 * ftp-unix.c (ftp_parse_ls): Added better debug output.
2901 * ftp.c (getftp): Print out the LIST in case of
2902 opt.print_server_response.
2904 * version.c: Changed version to 1.4b21.
2906 1996-10-01 Hrvoje Niksic <hniksic@srce.hr>
2908 * version.c: "Released" 1.4b20.
2912 * http.c (gethttp): Preset lengths of various headers instead of
2913 calculating them dynamically.
2914 (gethttp): Check for 206 partial contents.
2916 1996-09-30 Hrvoje Niksic <hniksic@srce.hr>
2918 * configure.in: Set SYSTEM_GETURLRC to $libdir/geturlrc
2920 * http.c (gethttp): Send the port number in the Host: header.
2922 1996-09-29 Hrvoje Niksic <hniksic@srce.hr>
2924 * http.c (gethttp): Send host: header.
2925 (gethttp): Add the possibility of user-defined headers.
2926 (gethttp): Move decision about pragma: no-cache to http_loop,
2928 (gethttp): Pass a struct instead of enormous argument list.
2929 (http_loop): Use a new, fancier display format.
2930 (ftp_loop): Likewise.
2932 * main.c: (hangup): Turn off buffering of the new log file.
2934 * install-sh: Likewise.
2936 * config.sub: Replace with the one in autoconf-2.10
2940 * init.c: New options httpuser and httppasswd.
2942 * http.c: (base64_encode_line): New function.
2943 (gethttp): Send authentication.
2945 * connect.c (make_connection): Use store_hostaddress.
2947 1996-09-28 Hrvoje Niksic <hniksic@srce.hr>
2949 * host.c (store_hostaddress): New function.
2953 * http.c (hgetrange): New function.
2954 (gethttp): Use ranges.
2956 * utils.c (numdigit): Accept long instead of int.
2958 * http.c (http_loop): Add restart capabilities.
2960 * ftp.c (ftp_retrieve_glob): Fixed a bug that could cause matchres
2961 being used uninitialized.
2962 (ftp_retrieve_list): Similar fix.
2964 * host.c (add_hlist): Fixed a bug that could cause cmp being used
2967 * url.c (construct_relative): New function.
2969 * recur.c (recursive_retrieve): Use it.
2971 * retr.c (convert_links): New function.
2973 1996-09-27 Hrvoje Niksic <hniksic@srce.hr>
2975 * url.c (free_urlpos): New function.
2977 * recur.c (recursive_retrieve): Adapt.
2979 * url.c (get_urls_html): Return a linked list instead of a vector.
2981 * url.c (get_urls_file): Return a linked list instead of a vector.
2985 * http.c (gethttp): Implement it.
2987 * init.c (setval): New option: SAVEHEADERS
2989 * ftp.c (ftp_loop_internal): Do not set restval if listing is to
2990 be retrieved. Lack of this test caused bugs when the connection
2991 was lost during listing.
2993 * retr.c (retrieve_url): Fixed a bug that caused
2994 coredumps. *newloc is now reset by default.
2995 (retrieve_url): Lift the twenty-tries limit on proxies.
2997 * version.c: Changed version to 1.4b20.
2999 1996-09-20 Hrvoje Niksic <hniksic@srce.hr>
3001 * version.c: "Released" 1.4b19.
3003 1996-09-19 Hrvoje Niksic <hniksic@srce.hr>
3005 * ftp.c (ftp_loop_internal): Renamed from ftp_1fl_loop.
3006 (getftp): Changed prototype to accept ccon *.
3008 1996-09-17 Hrvoje Niksic <hniksic@srce.hr>
3010 * ftp.c (ftp_retrieve_list): Fixed a bug that caused setting
3011 incorrect values to files pointed to by symbolic links.
3012 (ftp_1fl_loop): Do not count listings among the downloaded URL-s.
3014 1996-09-16 Hrvoje Niksic <hniksic@srce.hr>
3016 * url.c (mkstruct): Do not prepend "./" in front of a pathname.
3018 * main.c (main): New option: --user-agent.
3024 * init.c (setval): Ditto.
3026 * main.c (main): Rename "server-headers" to "server-response".
3028 * ftp-unix.c (ftp_parse_ls): Check for asterisks at the end of
3029 executables in 'ls -F' listings.
3031 1996-09-15 Hrvoje Niksic <hniksic@srce.hr>
3033 * url.c (parseurl): Remove realloc() and sprintf().
3034 (str_url): Get rid of sprintf().
3036 * recur.c (recursive_retrieve): Enable FTP recursion through proxy
3039 * url.h (URL_CLEANSE): Made it else-resistant.
3040 (USE_PROXY): New macro.
3042 1996-09-14 Hrvoje Niksic <hniksic@srce.hr>
3046 * version.c: Changed version to 1.4b19.
3048 1996-09-14 Hrvoje Niksic <hniksic@srce.hr>
3050 * version.c: "Released" 1.4b18.
3052 * url.c: Made it reallocate space exponentially.
3054 1996-09-14 Drazen Kacar <dave@fly.cc.fer.hr>
3056 * html.c (htmlfindurl): Added <frame src> and <iframe src> among
3057 the list of stuff to fetch.
3059 1996-09-13 Hrvoje Niksic <hniksic@srce.hr>
3061 * url.c (get_urls_html): Fixed a bug that caused SIGSEGV's with
3064 * html.c (htmlfindurl): Rewrite.
3066 * http.c (gethttp): Use opt.proxy_cache.
3068 * main.c (main): Added --cache option.
3070 * ftp.c (ftp_response): Print server response if opt.print_server
3072 (getftp): Print newlines after each request if the server response
3074 (ftp_response): Copy the last response line to last_respline.
3076 * http.c (gethttp): Add Pragma: nocache for retried
3079 * ftp.c (getftp): Use it.
3081 * retr.c (buf_discard): New function.
3083 * ftp.c (ftp_response): Use buf_readchar().
3084 (getftp): Flush the control connection buffer before calling
3087 * retr.c (buf_readchar): New function.
3088 (buf_flush): New function.
3089 (get_contents): Use buf_readchar() instead of read(x, x, 1).
3090 (get_contents): Use buf_flush.
3092 1996-09-12 Hrvoje Niksic <hniksic@srce.hr>
3094 * ftp.c: Incorporate changes to ftp_response.
3096 * ftp.c (ftp_response): Allocate the server response dynamically,
3097 as in read_whole_line and fetch_next_header.
3099 * utils.c (read_whole_line): Fixed a bug that prevented reading
3100 the last line if it is not \n-terminated. Also fixed a possible
3103 * http.c (fetch_next_header): Return malloc-ed string as large as
3105 (gethttp): Use new fetch_next_header.
3107 1996-09-12 Hrvoje Niksic <hniksic@srce.hr>
3109 * http.c (hgetlen): Compute the header length the first time only.
3111 (hgetlocation): Ditto.
3112 (hgetmodified): Ditto.
3114 1996-09-11 Hrvoje Niksic <hniksic@srce.hr>
3116 * sample.geturlrc: Update.
3118 1996-09-10 Hrvoje Niksic <hniksic@srce.hr>
3120 * http.c (http_loop): Ditto.
3122 * ftp.c (getftp): Open the output file as binary.
3124 * version.c: Changed version to 1.4b18.
3126 1996-09-10 Hrvoje Niksic <hniksic@srce.hr>
3128 * version.c: "Released" 1.4b17.
3130 * ftp-unix.c (ftp_parse_ls): If unable to open file, return NULL
3131 instead of failed assertion.
3133 1996-09-09 Hrvoje Niksic <hniksic@srce.hr>
3135 * ftp.c (ftp_get_listing): Add a numbered suffix to LIST_FILENAME
3136 if a file of that name already exists.
3138 1996-09-05 Hrvoje Niksic <hniksic@srce.hr>
3140 * ftp.c (ftp_1fl_loop): Handler FTPPORTERR and FOPENERR correctly.
3142 * config.h.in: Define gethostbyname as Rgethostbyname when using
3145 * configure.in: Check for -lresolv if using Socks.
3147 * version.c: Changed version to 1.4b17.
3149 1996-07-15 Hrvoje Niksic <hniksic@srce.hr>
3151 * version.c: "Released" 1.4b16.
3153 * http.c (gethttp): More intelligent check for first line of HTTP
3155 (gethttp): Would bug out on time-stamping.
3157 * version.c: Changed version to 1.4b16.
3159 1996-07-11 Hrvoje Niksic <hniksic@srce.hr>
3161 * version.c: Released 1.4b15.
3163 * http.c (http_loop): Print \n after the loop entry, not before.
3165 * url.c (url_filename): Use ISDOT.
3167 * url.h (ISDOT): New macro.
3169 * recur.c (recursive_retrieve): Change only opt.recursive for
3172 1996-07-11 Antonio Rosella <antonio.rosella@agip.it>
3174 * socks/geturl.cgi: Fixed version No.
3176 * socks/download-netscape.html: Ditto.
3178 * socks/download.html: Changed socks.html to download.html.
3180 1996-07-11 Hrvoje Niksic <hniksic@srce.hr>
3182 * url.c (url_filename): Check for opt.dirstruct instead for
3183 opt.recursive && opt.dirstruct.
3185 * init.c (defaults): Ditto.
3186 (defaults): Reset dirstruct by default.
3187 (setval): Set opt.dirstruct whenever setting recursive.
3189 * init.h: Removed FORCEDIRHIER.
3191 * INSTALL: Added -L to socks-description.
3193 * version.c: Changed version to 1.4b15.
3195 1996-07-10 Hrvoje Niksic <hniksic@srce.hr>
3197 * version.c: "Released" 1.4b14.
3199 * geturl.1: Update AUTHOR to include Rosella as contributor.
3203 * socks/geturl.cgi: Simplified command creation, nuked <blink>.
3205 * socks/geturl.cgi: Wrap nutscape extensions within if $netscape.
3206 (cal_time): Fix == to eq.
3208 * socks/geturl.cgi: GPL-ized with permission of A. Rosella.
3210 * geturl.1 (hostname): Moved URL CONVENTIONS to the beginning.
3212 * Makefile.in: Use @VERSION@.
3214 * configure.in: Check version from version.c.
3216 * socks/geturl.cgi: Changed /pub/bin/perl to /usr/bin/perl.
3218 * socks/download.html: Created from download-netscape.html, made
3221 * recur.c (recursive_retrieve): Set opt.force_dir_hier when
3222 following FTP links from recursions.
3224 1996-07-09 Hrvoje Niksic <hniksic@srce.hr>
3226 * url.c (mymkdir): Fixed a bug that prevented mymkdir() to create
3227 absolute directories correctly.
3229 * version.c: Changed version to 1.4b14.
3231 1996-07-09 Hrvoje Niksic <hniksic@srce.hr>
3233 * version.c: "Released" 1.4b13.
3235 * url.c (make_backup): New function.
3237 * http.c (http_loop): Make a backup copy of the local file (using
3238 rename(2)) before opening it.
3240 * main.c (main): Added --backups.
3242 * host.c (ftp_getaddress): Bail out on failed mycuserid().
3243 (ftp_getaddress): Check for leading dot on MY_DOMAIN.
3244 (ftp_getaddress): Check for empty, null or (null) domain.
3246 * url.c (get_urls_html): If this_url is NULL, the base must have a
3248 (parseurl): Use has_proto.
3250 * retr.c (retrieve_url): Warn when proxy is used with more than 20
3253 * url.c (mkstruct): Create the directory (calling mymkdir()) only
3254 if it is not already there.
3255 (has_proto): New function.
3256 (get_urls_html): Eliminate the remaining call to findurl -- use
3261 * main.c: Change -X to -x.
3263 * url.c (url_filename): Simplify creation of filename if
3264 prefix_files is set.
3265 (url_filename): Simplify everything. And I do mean *everything*.
3266 (mkstruct): Add dir_prefix before hostname.
3267 (path_simplify): Fixed a bug that caused writing outside the path
3268 string in case of "." and ".." path strings.
3270 1996-07-06 Hrvoje Niksic <hniksic@srce.hr>
3272 * init.c: Added --mirror.
3274 * main.c (main): Added -X to force saving of directory hierarchy.
3276 * ftp.c (ftp_retrieve_list): Added recursion depth counter.
3277 (ftp_retrieve_list): Check whether quota is exceeded.
3279 * url.c (get_urls_html): Skip leading blanks for absolute URIs.
3281 * http.c (gethttp): Use referer if present.
3283 * recur.c (recursive_retrieve): Set u->referer before calling
3286 * url.c (newurl): Use memset to nullify the struct members.
3287 (freeurl): Free the referer field too.
3289 * url.h: Added referer to urlinfo.
3291 * geturl.1: Updated the manual to document some of the new features.
3293 * utils.c (numdigit): Moved from url.c.
3295 * README: Rewritten.
3297 * config.h.in: Add the support for socks.
3299 * configure.in: Add the support for socks.
3301 * url.c (url_filename): If the dir_prefix is ".", work with just
3303 (url_filename): Do not look for .n extensions if timestamping if
3306 * retr.c (show_progress): Skip the over-abundant restval data, and
3307 print the rest of it with ',' instead of '.'.
3309 1996-07-05 Hrvoje Niksic <hniksic@srce.hr>
3311 * retr.c (show_progress): Changed second arg. to long (as it
3313 (show_progress): Moved to retr.c.
3314 (get_contents): Moved to retr.c.
3316 * version.c: Change version to 1.4b13.
3318 1996-07-05 Hrvoje Lacko <hlacko@fly.cc.fer.hr>
3320 * url.c (in_acclist): Would return after the first suffix.
3322 1996-07-04 Hrvoje Niksic <hniksic@srce.hr>
3324 * version.c: "Released" 1.4b12.
3326 * url.c (path_simplify): More kludgifications.
3327 (get_urls_html): Use new parameters for htmlfindurl.
3329 * html.c: Removed memorizing "parser states", since the new
3330 organization does not require them.
3332 * init.c (run_geturlrc): Use read_whole_line.
3334 * ftp-unix.c (ftp_parse_ls): Use read_whole_line.
3336 * recur.c (parse_robots): Use read_whole_line.
3338 * utils.c (read_whole_line): New function.
3340 * recur.c (tried_robots): Use add_slist/in_slist, *much* cleaner.
3342 * host.c (ngethostbyname): Call inet_addr just once. Yet to be
3343 tested on OSF and Ultrix.
3344 (add_hlist): New function.
3345 (free_hlist): New function.
3346 (search_host): New function.
3347 (search_address): New function.
3348 (realhost): Use search_host, search_address and add_hlist.
3349 (same_host): Replaced realloc() with strdupdelim(), made
3350 case-insensitive, fixed a memory leak.
3352 * html.c (ftp_index): Fixed tm_min and tm_sec to be tm_hour and
3353 tm_min, like intended.
3355 * version.c: Change user agent information to
3358 1996-07-03 Hrvoje Niksic <hniksic@srce.hr>
3360 * utils.c: Renamed nmalloc.c to utils.c, .h likewise.
3362 * url.c (acceptable): Always accept directories.
3364 * ftp-unix.c (ftp_parse_ls): Support brain-damaged "ls -F"-loving
3365 servers by stripping trailing @ from symlinks and trailing / from
3368 * ftp.c (ftp_loop): Debugged the "enhanced" heuristics. :-)
3370 * url.c (skip_url): Use toupper instead of UCASE.
3372 * host.c (sufmatch): Made it case-insensitive.
3374 * url.c (match_backwards_or_pattern): Fixed i == -1 to j == -1.
3375 (match_backwards): New function, instead of
3376 match_backwards_or_pattern.
3378 * recur.c (recursive_retrieve): Increased performance by
3379 introducing inl, which reduces number of calls to in_slist to only
3382 * ftp.c (ftp_loop): Enhanced the heuristics that decides which
3385 * main.c (printhelp): Removed the warranty stuff.
3387 1996-07-02 Hrvoje Niksic <hniksic@srce.hr>
3389 * url.c (add_slist): Simplify.
3390 (match_backwards_or_pattern): New function.
3391 (in_acclist): Use match_backwards_or_pattern.
3394 1996-06-30 Hrvoje Niksic <hniksic@srce.hr>
3396 * ftp.c (ftp_loop): Call ftp_index on empty file names, if not
3399 * html.c (ftp_index): Fixed to work. Beautified the output.
3401 * ftp.c (ftp_retrieve_glob): Another argument to control whether
3402 globbing is to be used.
3403 (ftp_retrieve_list): Compare the time-stamps of local and remote
3404 files to determine whether to download.
3406 1996-06-29 Hrvoje Niksic <hniksic@srce.hr>
3408 * ftp.c (rel_constr): New function.
3410 * retr.c (retrieve_from_file): Check for text/html before
3411 retrieving recursively.
3413 * main.c (main): Check whether the file is HTML before going into
3414 recursive HTML retrieving.
3416 * ftp.c (ftp_retrieve_list): Manage directories.
3417 (ftp_retrieve_glob): Pass all the file-types to ftp_retrieve_list.
3418 (ftp_1fl_loop): Fixed a bug that caused con->com to be incorrectly
3419 initialized, causing bugchecks in getftp to fail.
3421 * configure.in: Check for symlink.
3423 * ftp.c (ftp_retrieve_list): Added support for symlinks.
3425 * version.c: "Released" 1.4b10.
3427 * atotm.c (atotm): Redeclared as time_t.
3429 * init.c: New variable "timestamping".
3431 * main.c (main): New option 'N'.
3433 * http.c (hgetlocation): Case-insensitive match.
3434 (hgetmodified): New function.
3435 (http_loop): Implement time-stamping.
3437 1996-06-28 Hrvoje Niksic <hniksic@srce.hr>
3439 * version.c: Changed version to 1.4b10
3441 * atotm.c: New file, from phttpd.
3443 * options.h (struct options): New parameter timestamping.
3445 * version.c: 1.4b9 "released".
3447 * recur.c (recursive_retrieve): Used linked list (ulist) for
3448 faster storing of URLs.
3450 * url.c (get_urls_html): Removed the old kludge with comparing the
3451 outputs of htmlfindurl and findurl.
3452 (get_urls_html): Added better protocol support here.
3453 (create_hash): Removed, as well as add_hash and in_hash.
3454 (addslist): New function.
3457 * version.c: Released 1.4b8, changed version to b9.
3459 1996-06-27 Hrvoje Niksic <hniksic@srce.hr>
3461 * ftp.c (freefileinfo): New function.
3462 (delelement): New function.
3466 * ftp.c (ftp_loop): Use ccon.
3467 (ftp_retrieve_glob): Likewise.
3469 * ftp.h: Define ccon, to define status of control connection.
3471 * ftp.c (ftp_get_listing): New function.
3472 (ftp_retrieve_more): New function.
3473 (ftp_retrieve_glob): New function.
3475 1996-06-25 Hrvoje Niksic <hniksic@srce.hr>
3477 * configure.in: Removed the search for cuserid().
3479 * init.c (getmode): Renamed to getperms.
3481 1996-06-24 Hrvoje Niksic <hniksic@srce.hr>
3483 * version.c: New version.
3485 * main.c (hangup): New function, that handles hangup. Hangup
3486 signal now causes geturl to stop writing on stdout, and to write
3489 * ftp.c (getftp): "Released" 1.4b7.
3491 * html.c (htmlfindurl): Ignore everything inside <head>...</head>.
3492 (ftp_index): Use fileinfo/urlinfo.
3494 * ftp-unix.c (ftp_parse_ls): New function.
3495 (symperms): New function.
3497 * ftp.c (ftp_1fl_loop): New function, to handle 1-file loops.
3499 * retr.c (retrieve_url): Added FTP support.
3501 1996-06-23 Hrvoje Niksic <hniksic@srce.hr>
3503 * geturl.h: Removed NOTFTP2HTML enum.
3504 Added DO_LOGIN, DO_CWD and DO_LIST. LIST_ONLY is obsolete.
3506 * ftp.c (getftp): Resynched with urlinfo.
3507 (getftp): Removed HMTL-ization of index.html from getftp.
3509 * version.c: 1.4b6 "released".
3511 * options.h (options): New struct, to keep options in.
3513 * http.c (http_loop,gethttp): Synched with proxy.
3515 * retr.c (retrieve_url): Implemented proxy retrieval.
3517 * main.c (main): Use retrieve_from_file.
3519 1996-06-22 Hrvoje Niksic <hniksic@srce.hr>
3521 * retr.c (retrieve_from_file): New function.
3523 * url.c (parseurl): Modified to return URLOK if all OK. Protocol
3524 can be found in u->proto.
3526 * ftp.c (ftp_response): Fixed to accept multi-line responses as
3529 * recr.c (recursive_retrieve): Take newloc from retrieve_url.
3531 * url.c (mymkdir): Removed the file of the same name, if one
3533 (isfile): New function.
3534 (mkstruct): Fixed the '/' glitches.
3535 (path_simplify): Hacked to treat something/.. correctly.
3537 1996-06-21 Hrvoje Niksic <hniksic@srce.hr>
3539 * http.c (gethttp): Close the socket after error in headers.
3540 (http_loop): HEOF no longer a fatal header.
3542 * loop.c (retrieve_url): When dt is NULL, do not modify it. This
3543 simplifies the syntax of calling retrieve_url.
3545 * recr.c (recursive_retrieve): Modified to use get_urls_html.
3547 * url.c (get_urls_file): New function.
3548 (get_urls_html): New function.
3550 * recr.c (recursive_retrieve): Patched up to conform to the
3553 * http.c (gethttp): Synched with the rest...
3554 (gethttp): Treat only CONREFUSED specially, with connection
3557 * init.c,geturl.1,http.c (http_loop): Removed kill_error.
3559 1996-06-20 Hrvoje Niksic <hniksic@srce.hr>
3561 * http.c (http_loop): New function.
3563 * loop.c: Removed *lots* of stuff from retrieve_url.
3565 * url.c (parseurl): Changed to work with urlinfo. Integrated
3566 username finding and path parsing.
3567 (newurl): New function.
3568 (freeurl): New function.
3569 (mkstruct): Removed the old bogosities, made it urlinfo-compliant.
3570 (url_filename): Likewise.
3571 (path_simplify): Accept relative paths too.
3572 (opt_url): Made urlinfo-compliant, removed bogosities.
3573 (path_simplify): Expanded to accept relative paths.
3574 (str_url): A replacement for hide_url
3575 (decode_string): Fixed a bug that caused malfunctioning when
3576 encountering an illegal %.. combination.
3577 (opt_url): Removed the argument. Dot-optimizations are now default.
3579 * nmalloc.c (strdupdelim): New function.
3581 * url.h: Added the urlinfo structure
3583 1996-06-19 Hrvoje Niksic <hniksic@srce.hr>
3585 * url.c (hide_url): Thrown out the protocol assertion. Do not
3586 change the URL if the protocol if not recognized.
3587 (findurl): Put continue instead of break.
3589 1996-06-18 Hrvoje Niksic <hniksic@srce.hr>
3591 * sample.geturlrc: Changed the defaults to be commented out and
3592 harmless (previous defaults caused pains if copied to
3595 * http.c (gethttp): Print the HTTP request in debug mode.
3597 * connect.c (iread): Added EINTR check loop to select-ing
3598 too. EINTR is now correctly handled with select().
3602 1996-05-07 Hrvoje Niksic <hniksic@srce.hr>
3604 * host.c (same_host): Made the function a little bit more
3605 intelligent regarding diversified URL syntaxes.
3607 * url.c (skip_url): Spaces are now skipped after URL:
3609 * Released 1.3.1 with the patch to prevent crashing when sending
3610 NULL to robot* functions and the patch to compile "out of the box"
3613 * recr.c (recursive_retrieve): Added checking whether this_url is
3614 NULL when calling the robot functions.
3616 * ChangeLog: New file.