mirror of
https://github.com/mirror/wget.git
synced 2025-01-21 09:41:06 +08:00
[svn] Fix loading of cookies.
Published in <sxslmopyao6.fsf@florida.arsdigita.de>.
This commit is contained in:
parent
425b5af0c9
commit
f0eb1fb758
@ -1,3 +1,10 @@
|
||||
2001-04-25 Hrvoje Niksic <hniksic@arsdigita.com>
|
||||
|
||||
* http.c (http_loop): Would load cookies every time.
|
||||
|
||||
* cookies.c (load_cookies): Handle cookies whose values contain
|
||||
embedded spaces.
|
||||
|
||||
2001-04-25 Hrvoje Niksic <hniksic@arsdigita.com>
|
||||
|
||||
* utils.c: Define each DIGITS_* in one line.
|
||||
|
@ -1192,7 +1192,7 @@ domain_port (const char *domain_b, const char *domain_e,
|
||||
++p; \
|
||||
} while (0)
|
||||
|
||||
#define MARK_WORD(p, b, e) do { \
|
||||
#define SET_WORD_BOUNDARIES(p, b, e) do { \
|
||||
SKIP_WS (p); \
|
||||
b = p; \
|
||||
/* skip non-ws */ \
|
||||
@ -1239,16 +1239,25 @@ load_cookies (const char *file)
|
||||
/* empty line */
|
||||
continue;
|
||||
|
||||
MARK_WORD (p, domain_b, domain_e);
|
||||
MARK_WORD (p, ignore_b, ignore_e);
|
||||
MARK_WORD (p, path_b, path_e);
|
||||
MARK_WORD (p, secure_b, secure_e);
|
||||
MARK_WORD (p, expires_b, expires_e);
|
||||
MARK_WORD (p, name_b, name_e);
|
||||
SET_WORD_BOUNDARIES (p, domain_b, domain_e);
|
||||
SET_WORD_BOUNDARIES (p, ignore_b, ignore_e);
|
||||
SET_WORD_BOUNDARIES (p, path_b, path_e);
|
||||
SET_WORD_BOUNDARIES (p, secure_b, secure_e);
|
||||
SET_WORD_BOUNDARIES (p, expires_b, expires_e);
|
||||
SET_WORD_BOUNDARIES (p, name_b, name_e);
|
||||
|
||||
/* Don't use MARK_WORD for value because it may contain
|
||||
whitespace itself. Instead, . */
|
||||
MARK_WORD (p, value_b, value_e);
|
||||
/* Don't use SET_WORD_BOUNDARIES for value because it may
|
||||
contain whitespace. Instead, set value_e to the end of line,
|
||||
modulo trailing space (this will skip the line separator.) */
|
||||
SKIP_WS (p);
|
||||
value_b = p;
|
||||
value_e = p + strlen (p);
|
||||
while (value_e > value_b && ISSPACE (*(value_e - 1)))
|
||||
--value_e;
|
||||
if (value_b == value_e)
|
||||
/* Hmm, should we check for empty value? I guess that's
|
||||
legal, so I leave it. */
|
||||
;
|
||||
|
||||
cookie = cookie_new ();
|
||||
|
||||
@ -1269,19 +1278,6 @@ load_cookies (const char *file)
|
||||
|
||||
cookie->domain = strdupdelim (domain_b, domain_e);
|
||||
|
||||
/* Don't use MARK_WORD for value because it may contain
|
||||
whitespace itself. Instead, set name_e to the end of line,
|
||||
modulo trailing space (which includes the NL separator.) */
|
||||
SKIP_WS (p);
|
||||
name_b = p;
|
||||
name_e = p + strlen (p);
|
||||
while (name_e >= name_b && ISSPACE (*name_e))
|
||||
--name_e;
|
||||
if (name_b == name_e)
|
||||
/* Hmm, should we check for empty value? I guess that's
|
||||
legal, so I leave it. */
|
||||
;
|
||||
|
||||
/* safe default in case EXPIRES field is garbled. */
|
||||
cookie->expiry_time = cookies_now - 1;
|
||||
|
||||
|
@ -1381,7 +1381,10 @@ http_loop (struct urlinfo *u, char **newloc, int *dt)
|
||||
here so that we don't go through the hoops if we're just using
|
||||
FTP or whatever. */
|
||||
if (opt.cookies && opt.cookies_input && !cookies_loaded_p)
|
||||
load_cookies (opt.cookies_input);
|
||||
{
|
||||
load_cookies (opt.cookies_input);
|
||||
cookies_loaded_p = 1;
|
||||
}
|
||||
|
||||
*newloc = NULL;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user