Fix compiler warnings

This commit is contained in:
Tim Ruehsen 2014-05-11 23:20:49 +02:00 committed by Giuseppe Scrivano
parent 351e438e51
commit 38a7829dcb
25 changed files with 261 additions and 266 deletions

View File

@ -1,3 +1,58 @@
2014-05-03 Tim Ruehsen <tim.ruehsen@gmx.de>
* ftp-ls.c (ftp_parse_vms_ls): Explicitly typecast strlen's output
* ftp.c (getftp): Prevent declaration of shadow variable
* html-url.c (tag_handle_base, tag_handle_form, tag_handle_link,
tag_handle_meta): Compiler directive to ignore unused variable
* html-url.h (cleanup_html_url): Add function declaration
* http-ntlm.c (ntlm_input, mkhash): Use ssize_t to declare variables that store
sizes.
(mkhash): Explicitly typecast output of c_toupper
(short_pair): Add typecasts to prevent compiler warnings
(ntlm-output): Fix datatypes of various variables
* http.c (gethttp): Prevent declaration of shadow variable err
(gethttp): remove unreachable code
(test_parse_content_disposition): Fix variable declarations and use
countof() macro
* init.c (run_command): Prevent declaration of ghost variable
(cmd_string, cmd_string_uppercase, cmd_file, cnd_vector,
cmd_directory_vector, cmd_spec_dirstruct, cmd_spec_header,
cmd_spec_warc_header, cmd_spec_htmlify, cmd_spec_mirror,
cmd_spec_prefer_family, cmd_spec_progress, cmd_spec_recursive,
cmd_spec_regex_type, cmd_spec_restrict_file_names, cmd_spec_report_speed,
cmd_spec_timeout, cmd_spec_useragent, cmd_spec_verbose): Add compiler
directive to ignore unused variable
(cleanup_html_url, spider_cleanup): Remove declarations
(test_commands_sorted): Cleanup code
(test_cmd_spec_restrict_file_names): Use correct data types
* iri.c (remote_to_utf8): Use more verbose variable name
* main.c (init_switches): Prevent declaration of ghost variable
* netrc.c (netrc_cleanup): Create cleanup function on common naming scheme
* netrc.h (netrc_cleanup): Declare function
* openssl.c (openssl_write, openssl_errstr): Compiler directive to ignore
unused parameter
(openssl_errstr): Explcicitly typecasr output of ASN1_STRING_length
* options.h (struct options): Declare includes and excludes as const char **
* progress.c (progress_interactive_p, progress_handle_sigwinch): Compiler
directive to ignore unused parameter
* res.c (test_is_robots_txt_url): Fix datatypes
* retr.c (line_terminator): Add compiler directive for ignoring unused
paramter. Remove unused variable.
* spider.h (spider_cleanup): Declare function
* test,c (main): declare unused paramter
* test.h (test_*): Declare functions
* url.c (url_string): Explicit typecast of password strings
(run_test): Declare *test, struct tests and *expected_result as const
(test_path_simplify, test_append_uri_pathl, test_are_urls_equal): Fix datatypes
* utls.c (fork_to_background): Be more verbose when errors occur
(dir_matches_p, test_dir_matches_p): Declare char * as const as required
(base64_encode, base64_decode, get_max_length): Set correct return type
(match_pcre_regex, match_posix_regex): Use correct datatypes and typecasts
(test_subdir_p): static const struct
* utils.h (base64_encode, base64_decode, get_max_length): Fix return type
* warc.c (ward_write_cdx_record): unused parameter
(struct hash_table *warc_cdx_dedup_table): Declare as static
2014-05-01 Benjamin Goose <gans+wget@tngtech.com> 2014-05-01 Benjamin Goose <gans+wget@tngtech.com>
* http.c: Fix small memory leak * http.c: Fix small memory leak

View File

@ -64,41 +64,6 @@ typedef struct yy_buffer_state *YY_BUFFER_STATE;
extern YY_BUFFER_STATE yy_scan_bytes (const char *bytes,int len ); extern YY_BUFFER_STATE yy_scan_bytes (const char *bytes,int len );
extern int yylex (void); extern int yylex (void);
#if 1
const char *token_names[] = {
"CSSEOF",
"S",
"CDO",
"CDC",
"INCLUDES",
"DASHMATCH",
"LBRACE",
"PLUS",
"GREATER",
"COMMA",
"STRING",
"INVALID",
"IDENT",
"HASH",
"IMPORT_SYM",
"PAGE_SYM",
"MEDIA_SYM",
"CHARSET_SYM",
"IMPORTANT_SYM",
"EMS",
"EXS",
"LENGTH",
"ANGLE",
"TIME",
"FREQ",
"DIMENSION",
"PERCENTAGE",
"NUMBER",
"URI",
"FUNCTION"
};
#endif
/* /*
Given a detected URI token, get only the URI specified within. Given a detected URI token, get only the URI specified within.
Also adjust the starting position and length of the string. Also adjust the starting position and length of the string.

View File

@ -895,7 +895,8 @@ ftp_parse_vms_ls (const char *file)
/* Protections (permissions). */ /* Protections (permissions). */
perms = 0; perms = 0;
j = 0; j = 0;
for (i = 0; i < strlen(tok); i++) /*FIXME: Should not be using the variable like this. */
for (i = 0; i < (int) strlen(tok); i++)
{ {
switch (tok[ i]) switch (tok[ i])
{ {

View File

@ -990,15 +990,14 @@ Error in server response, closing control connection.\n"));
if (opt.spider) if (opt.spider)
{ {
bool exists = false; bool exists = false;
uerr_t res;
struct fileinfo *f; struct fileinfo *f;
res = ftp_get_listing (u, con, &f); uerr_t _res = ftp_get_listing (u, con, &f);
/* Set the DO_RETR command flag again, because it gets unset when /* Set the DO_RETR command flag again, because it gets unset when
calling ftp_get_listing() and would otherwise cause an assertion calling ftp_get_listing() and would otherwise cause an assertion
failure earlier on when this function gets repeatedly called failure earlier on when this function gets repeatedly called
(e.g., when recursing). */ (e.g., when recursing). */
con->cmd |= DO_RETR; con->cmd |= DO_RETR;
if (res == RETROK) if (_res == RETROK)
{ {
while (f) while (f)
{ {
@ -1235,8 +1234,7 @@ Error in server response, closing control connection.\n"));
{ {
if (opt.unlink && file_exists_p (con->target)) if (opt.unlink && file_exists_p (con->target))
{ {
int res = unlink (con->target); if (unlink (con->target) < 0)
if (res < 0)
{ {
logprintf (LOG_NOTQUIET, "%s: %s\n", con->target, logprintf (LOG_NOTQUIET, "%s: %s\n", con->target,
strerror (errno)); strerror (errno));

View File

@ -472,7 +472,7 @@ tag_find_urls (int tagid, struct taginfo *tag, struct map_context *ctx)
/* Handle the BASE tag, for <base href=...>. */ /* Handle the BASE tag, for <base href=...>. */
static void static void
tag_handle_base (int tagid, struct taginfo *tag, struct map_context *ctx) tag_handle_base (int tagid _GL_UNUSED, struct taginfo *tag, struct map_context *ctx)
{ {
struct urlpos *base_urlpos; struct urlpos *base_urlpos;
int attrind; int attrind;
@ -498,7 +498,7 @@ tag_handle_base (int tagid, struct taginfo *tag, struct map_context *ctx)
/* Mark the URL found in <form action=...> for conversion. */ /* Mark the URL found in <form action=...> for conversion. */
static void static void
tag_handle_form (int tagid, struct taginfo *tag, struct map_context *ctx) tag_handle_form (int tagid _GL_UNUSED, struct taginfo *tag, struct map_context *ctx)
{ {
int attrind; int attrind;
char *action = find_attr (tag, "action", &attrind); char *action = find_attr (tag, "action", &attrind);
@ -516,7 +516,7 @@ tag_handle_form (int tagid, struct taginfo *tag, struct map_context *ctx)
links will be followed in -p mode depends on the REL attribute. */ links will be followed in -p mode depends on the REL attribute. */
static void static void
tag_handle_link (int tagid, struct taginfo *tag, struct map_context *ctx) tag_handle_link (int tagid _GL_UNUSED, struct taginfo *tag, struct map_context *ctx)
{ {
int attrind; int attrind;
char *href = find_attr (tag, "href", &attrind); char *href = find_attr (tag, "href", &attrind);
@ -565,7 +565,7 @@ tag_handle_link (int tagid, struct taginfo *tag, struct map_context *ctx)
refresh feature and because of robot exclusion. */ refresh feature and because of robot exclusion. */
static void static void
tag_handle_meta (int tagid, struct taginfo *tag, struct map_context *ctx) tag_handle_meta (int tagid _GL_UNUSED, struct taginfo *tag, struct map_context *ctx)
{ {
char *name = find_attr (tag, "name", NULL); char *name = find_attr (tag, "name", NULL);
char *http_equiv = find_attr (tag, "http-equiv", NULL); char *http_equiv = find_attr (tag, "http-equiv", NULL);

View File

@ -47,5 +47,6 @@ struct urlpos *get_urls_file (const char *);
struct urlpos *get_urls_html (const char *, const char *, bool *, struct iri *); struct urlpos *get_urls_html (const char *, const char *, bool *, struct iri *);
struct urlpos *append_url (const char *, int, int, struct map_context *); struct urlpos *append_url (const char *, int, int, struct map_context *);
void free_urlpos (struct urlpos *); void free_urlpos (struct urlpos *);
void cleanup_html_url (void);
#endif /* HTML_URL_H */ #endif /* HTML_URL_H */

View File

@ -73,42 +73,13 @@ as that of the covered work. */
/* Define this to make the type-3 message include the NT response message */ /* Define this to make the type-3 message include the NT response message */
#define USE_NTRESPONSES 1 #define USE_NTRESPONSES 1
/* Flag bits definitions available at on /* Flag bits definitions available at on
http://davenport.sourceforge.net/ntlm.html */ http://davenport.sourceforge.net/ntlm.html */
#define NTLMFLAG_NEGOTIATE_UNICODE (1<<0)
#define NTLMFLAG_NEGOTIATE_OEM (1<<1) #define NTLMFLAG_NEGOTIATE_OEM (1<<1)
#define NTLMFLAG_REQUEST_TARGET (1<<2)
/* unknown (1<<3) */
#define NTLMFLAG_NEGOTIATE_SIGN (1<<4)
#define NTLMFLAG_NEGOTIATE_SEAL (1<<5)
#define NTLMFLAG_NEGOTIATE_DATAGRAM_STYLE (1<<6)
#define NTLMFLAG_NEGOTIATE_LM_KEY (1<<7)
#define NTLMFLAG_NEGOTIATE_NETWARE (1<<8)
#define NTLMFLAG_NEGOTIATE_NTLM_KEY (1<<9) #define NTLMFLAG_NEGOTIATE_NTLM_KEY (1<<9)
/* unknown (1<<10) */
/* unknown (1<<11) */
#define NTLMFLAG_NEGOTIATE_DOMAIN_SUPPLIED (1<<12)
#define NTLMFLAG_NEGOTIATE_WORKSTATION_SUPPLIED (1<<13)
#define NTLMFLAG_NEGOTIATE_LOCAL_CALL (1<<14)
#define NTLMFLAG_NEGOTIATE_ALWAYS_SIGN (1<<15)
#define NTLMFLAG_TARGET_TYPE_DOMAIN (1<<16)
#define NTLMFLAG_TARGET_TYPE_SERVER (1<<17)
#define NTLMFLAG_TARGET_TYPE_SHARE (1<<18)
#define NTLMFLAG_NEGOTIATE_NTLM2_KEY (1<<19)
#define NTLMFLAG_REQUEST_INIT_RESPONSE (1<<20)
#define NTLMFLAG_REQUEST_ACCEPT_RESPONSE (1<<21)
#define NTLMFLAG_REQUEST_NONNT_SESSION_KEY (1<<22)
#define NTLMFLAG_NEGOTIATE_TARGET_INFO (1<<23)
/* unknown (1<24) */
/* unknown (1<25) */
/* unknown (1<26) */
/* unknown (1<27) */
/* unknown (1<28) */
#define NTLMFLAG_NEGOTIATE_128 (1<<29)
#define NTLMFLAG_NEGOTIATE_KEY_EXCHANGE (1<<30)
#define NTLMFLAG_NEGOTIATE_56 (1<<31)
/* /*
(*) = A "security buffer" is a triplet consisting of two shorts and one (*) = A "security buffer" is a triplet consisting of two shorts and one
@ -146,7 +117,7 @@ ntlm_input (struct ntlmdata *ntlm, const char *header)
(40) Target Information (optional) security buffer(*) (40) Target Information (optional) security buffer(*)
32 (48) start of data block 32 (48) start of data block
*/ */
int size; ssize_t size;
char *buffer = (char *) alloca (strlen (header)); char *buffer = (char *) alloca (strlen (header));
DEBUGP (("Received a type-2 NTLM message.\n")); DEBUGP (("Received a type-2 NTLM message.\n"));
@ -277,8 +248,7 @@ mkhash(const char *password,
static const unsigned char magic[] = { static const unsigned char magic[] = {
0x4B, 0x47, 0x53, 0x21, 0x40, 0x23, 0x24, 0x25 0x4B, 0x47, 0x53, 0x21, 0x40, 0x23, 0x24, 0x25
}; };
int i; size_t i, len = strlen(password);
int len = strlen(password);
/* make it fit at least 14 bytes */ /* make it fit at least 14 bytes */
pw = (unsigned char *) alloca (len < 7 ? 14 : len * 2); pw = (unsigned char *) alloca (len < 7 ? 14 : len * 2);
@ -287,7 +257,7 @@ mkhash(const char *password,
len = 14; len = 14;
for (i=0; i<len; i++) for (i=0; i<len; i++)
pw[i] = c_toupper (password[i]); pw[i] = (unsigned char) c_toupper (password[i]);
for (; i<14; i++) for (; i<14; i++)
pw[i] = 0; pw[i] = 0;
@ -330,13 +300,13 @@ mkhash(const char *password,
len = strlen(password); len = strlen(password);
for (i=0; i<len; i++) { for (i=0; i<len; i++) {
pw[2*i] = password[i]; pw[2*i] = (unsigned char) password[i];
pw[2*i+1] = 0; pw[2*i+1] = 0;
} }
#ifdef HAVE_NETTLE #ifdef HAVE_NETTLE
nettle_md4_init(&MD4); nettle_md4_init(&MD4);
nettle_md4_update(&MD4, 2*len, pw); nettle_md4_update(&MD4, (unsigned) (2 * len), pw);
nettle_md4_digest(&MD4, MD4_DIGEST_SIZE, ntbuffer); nettle_md4_digest(&MD4, MD4_DIGEST_SIZE, ntbuffer);
#else #else
/* create NT hashed password */ /* create NT hashed password */
@ -352,7 +322,7 @@ mkhash(const char *password,
#endif #endif
} }
#define SHORTPAIR(x) ((x) & 0xff), ((x) >> 8) #define SHORTPAIR(x) (char) ((x) & 0xff), (char) ((x) >> 8)
#define LONGQUARTET(x) ((x) & 0xff), (((x) >> 8)&0xff), \ #define LONGQUARTET(x) ((x) & 0xff), (((x) >> 8)&0xff), \
(((x) >>16)&0xff), ((x)>>24) (((x) >>16)&0xff), ((x)>>24)
@ -361,19 +331,19 @@ char *
ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd, ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
bool *ready) bool *ready)
{ {
const char *domain=""; /* empty */ const char *domain = ""; /* empty */
const char *host=""; /* empty */ const char *host = ""; /* empty */
int domlen=strlen(domain); size_t domlen = strlen(domain);
int hostlen = strlen(host); size_t hostlen = strlen(host);
int hostoff; /* host name offset */ size_t hostoff; /* host name offset */
int domoff; /* domain name offset */ size_t domoff; /* domain name offset */
int size; size_t size;
char *base64; char *base64;
char ntlmbuf[256]; /* enough, unless the host/domain is very long */ char ntlmbuf[256]; /* enough, unless the host/domain is very long */
/* point to the address of the pointer that holds the string to sent to the /* point to the address of the pointer that holds the string to sent to the
server, which is for a plain host or for a HTTP proxy */ server, which is for a plain host or for a HTTP proxy */
char *output; char *output = NULL;
*ready = false; *ready = false;
@ -386,7 +356,8 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
switch(ntlm->state) { switch(ntlm->state) {
case NTLMSTATE_TYPE1: case NTLMSTATE_TYPE1:
default: /* for the weird cases we (re)start here */ case NTLMSTATE_NONE:
case NTLMSTATE_LAST:
hostoff = 32; hostoff = 32;
domoff = hostoff + hostlen; domoff = hostoff + hostlen;
@ -464,15 +435,15 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
*/ */
{ {
int lmrespoff; size_t lmrespoff;
int ntrespoff; size_t ntrespoff;
int useroff; size_t useroff;
unsigned char lmresp[0x18]; /* fixed-size */ unsigned char lmresp[0x18]; /* fixed-size */
#ifdef USE_NTRESPONSES #ifdef USE_NTRESPONSES
unsigned char ntresp[0x18]; /* fixed-size */ unsigned char ntresp[0x18]; /* fixed-size */
#endif #endif
const char *usr; const char *usr;
int userlen; size_t userlen;
DEBUGP (("Creating a type-3 NTLM message.\n")); DEBUGP (("Creating a type-3 NTLM message.\n"));
@ -482,7 +453,7 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
if (usr) { if (usr) {
domain = user; domain = user;
domlen = usr - domain; domlen = (size_t) (usr - domain);
usr++; usr++;
} }
else else
@ -503,7 +474,7 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
/* Create the big type-3 message binary blob */ /* Create the big type-3 message binary blob */
size = snprintf (ntlmbuf, sizeof(ntlmbuf), size = (size_t) snprintf (ntlmbuf, sizeof(ntlmbuf),
"NTLMSSP%c" "NTLMSSP%c"
"\x03%c%c%c" /* type-3, 32 bits */ "\x03%c%c%c" /* type-3, 32 bits */
@ -586,7 +557,7 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
/* Make sure that the user and domain strings fit in the target buffer /* Make sure that the user and domain strings fit in the target buffer
before we copy them there. */ before we copy them there. */
if(((size_t) size + userlen + domlen) >= sizeof(ntlmbuf)) if((size + userlen + domlen) >= sizeof(ntlmbuf))
return NULL; return NULL;
memcpy(&ntlmbuf[size], domain, domlen); memcpy(&ntlmbuf[size], domain, domlen);
@ -596,20 +567,20 @@ ntlm_output (struct ntlmdata *ntlm, const char *user, const char *passwd,
size += userlen; size += userlen;
/* we append the binary hashes to the end of the blob */ /* we append the binary hashes to the end of the blob */
if(size < ((int)sizeof(ntlmbuf) - 0x18)) { if(size < (sizeof(ntlmbuf) - 0x18)) {
memcpy(&ntlmbuf[size], lmresp, 0x18); memcpy(&ntlmbuf[size], lmresp, 0x18);
size += 0x18; size += 0x18;
} }
#ifdef USE_NTRESPONSES #ifdef USE_NTRESPONSES
if(size < ((int)sizeof(ntlmbuf) - 0x18)) { if(size < (sizeof(ntlmbuf) - 0x18)) {
memcpy(&ntlmbuf[size], ntresp, 0x18); memcpy(&ntlmbuf[size], ntresp, 0x18);
size += 0x18; size += 0x18;
} }
#endif #endif
ntlmbuf[56] = size & 0xff; ntlmbuf[56] = (char) (size & 0xff);
ntlmbuf[57] = size >> 8; ntlmbuf[57] = (char) (size >> 8);
/* convert the binary blob into base64 */ /* convert the binary blob into base64 */
base64 = (char *) alloca (BASE64_LENGTH (size) + 1); base64 = (char *) alloca (BASE64_LENGTH (size) + 1);

View File

@ -2335,23 +2335,23 @@ read_header:
But if we are writing a WARC file we are: we like to keep everyting. */ But if we are writing a WARC file we are: we like to keep everyting. */
if (warc_enabled) if (warc_enabled)
{ {
int err; int _err;
type = resp_header_strdup (resp, "Content-Type"); type = resp_header_strdup (resp, "Content-Type");
err = read_response_body (hs, sock, NULL, contlen, 0, _err = read_response_body (hs, sock, NULL, contlen, 0,
chunked_transfer_encoding, chunked_transfer_encoding,
u->url, warc_timestamp_str, u->url, warc_timestamp_str,
warc_request_uuid, warc_ip, type, warc_request_uuid, warc_ip, type,
statcode, head); statcode, head);
xfree_null (type); xfree_null (type);
if (err != RETRFINISHED || hs->res < 0) if (_err != RETRFINISHED || hs->res < 0)
{ {
CLOSE_INVALIDATE (sock); CLOSE_INVALIDATE (sock);
request_free (req); request_free (req);
xfree_null (message); xfree_null (message);
resp_free (resp); resp_free (resp);
xfree (head); xfree (head);
return err; return _err;
} }
else else
CLOSE_FINISH (sock); CLOSE_FINISH (sock);
@ -2661,18 +2661,18 @@ read_header:
But if we are writing a WARC file we are: we like to keep everyting. */ But if we are writing a WARC file we are: we like to keep everyting. */
if (warc_enabled) if (warc_enabled)
{ {
int err = read_response_body (hs, sock, NULL, contlen, 0, int _err = read_response_body (hs, sock, NULL, contlen, 0,
chunked_transfer_encoding, chunked_transfer_encoding,
u->url, warc_timestamp_str, u->url, warc_timestamp_str,
warc_request_uuid, warc_ip, type, warc_request_uuid, warc_ip, type,
statcode, head); statcode, head);
if (err != RETRFINISHED || hs->res < 0) if (_err != RETRFINISHED || hs->res < 0)
{ {
CLOSE_INVALIDATE (sock); CLOSE_INVALIDATE (sock);
xfree_null (type); xfree_null (type);
xfree (head); xfree (head);
return err; return _err;
} }
else else
CLOSE_FINISH (sock); CLOSE_FINISH (sock);
@ -2708,7 +2708,6 @@ read_header:
{ {
case HTTP_STATUS_TEMPORARY_REDIRECT: case HTTP_STATUS_TEMPORARY_REDIRECT:
return NEWLOCATION_KEEP_POST; return NEWLOCATION_KEEP_POST;
break;
case HTTP_STATUS_MOVED_PERMANENTLY: case HTTP_STATUS_MOVED_PERMANENTLY:
if (opt.method && strcasecmp (opt.method, "post") != 0) if (opt.method && strcasecmp (opt.method, "post") != 0)
return NEWLOCATION_KEEP_POST; return NEWLOCATION_KEEP_POST;
@ -2719,7 +2718,6 @@ read_header:
break; break;
default: default:
return NEWLOCATION; return NEWLOCATION;
break;
} }
return NEWLOCATION; return NEWLOCATION;
} }
@ -2840,18 +2838,18 @@ read_header:
But if we are writing a WARC file we are: we like to keep everyting. */ But if we are writing a WARC file we are: we like to keep everyting. */
if (warc_enabled) if (warc_enabled)
{ {
int err = read_response_body (hs, sock, NULL, contlen, 0, int _err = read_response_body (hs, sock, NULL, contlen, 0,
chunked_transfer_encoding, chunked_transfer_encoding,
u->url, warc_timestamp_str, u->url, warc_timestamp_str,
warc_request_uuid, warc_ip, type, warc_request_uuid, warc_ip, type,
statcode, head); statcode, head);
if (err != RETRFINISHED || hs->res < 0) if (_err != RETRFINISHED || hs->res < 0)
{ {
CLOSE_INVALIDATE (sock); CLOSE_INVALIDATE (sock);
xfree (head); xfree (head);
xfree_null (type); xfree_null (type);
return err; return _err;
} }
else else
CLOSE_FINISH (sock); CLOSE_FINISH (sock);
@ -4070,12 +4068,12 @@ ensure_extension (struct http_stat *hs, const char *ext, int *dt)
#ifdef TESTING #ifdef TESTING
const char * const char *
test_parse_content_disposition() test_parse_content_disposition(void)
{ {
int i; unsigned i;
struct { static const struct {
char *hdrval; const char *hdrval;
char *filename; const char *filename;
bool result; bool result;
} test_array[] = { } test_array[] = {
{ "filename=\"file.ext\"", "file.ext", true }, { "filename=\"file.ext\"", "file.ext", true },
@ -4086,7 +4084,7 @@ test_parse_content_disposition()
{ "attachement; filename*0=\"hello\"; filename*1=\"world.txt\"", "helloworld.txt", true }, { "attachement; filename*0=\"hello\"; filename*1=\"world.txt\"", "helloworld.txt", true },
}; };
for (i = 0; i < sizeof(test_array)/sizeof(test_array[0]); ++i) for (i = 0; i < countof(test_array); ++i)
{ {
char *filename; char *filename;
bool res; bool res;

View File

@ -68,6 +68,7 @@ as that of the covered work. */
#include "http.h" /* for http_cleanup */ #include "http.h" /* for http_cleanup */
#include "retr.h" /* for output_stream */ #include "retr.h" /* for output_stream */
#include "warc.h" /* for warc_close */ #include "warc.h" /* for warc_close */
#include "spider.h" /* for spider_cleanup */
#ifdef TESTING #ifdef TESTING
#include "test.h" #include "test.h"
@ -862,11 +863,11 @@ setoptval (const char *com, const char *val, const char *optname)
This is used by the `--execute' flag in main.c. */ This is used by the `--execute' flag in main.c. */
void void
run_command (const char *opt) run_command (const char *cmdopt)
{ {
char *com, *val; char *com, *val;
int comind; int comind;
switch (parse_line (opt, &com, &val, &comind)) switch (parse_line (cmdopt, &com, &val, &comind))
{ {
case line_ok: case line_ok:
if (!setval_internal (comind, com, val)) if (!setval_internal (comind, com, val))
@ -876,7 +877,7 @@ run_command (const char *opt)
break; break;
default: default:
fprintf (stderr, _("%s: Invalid --execute command %s\n"), fprintf (stderr, _("%s: Invalid --execute command %s\n"),
exec_name, quote (opt)); exec_name, quote (cmdopt));
exit (2); exit (2);
} }
} }
@ -959,7 +960,7 @@ cmd_number_inf (const char *com, const char *val, void *place)
/* Copy (strdup) the string at COM to a new location and place a /* Copy (strdup) the string at COM to a new location and place a
pointer to *PLACE. */ pointer to *PLACE. */
static bool static bool
cmd_string (const char *com, const char *val, void *place) cmd_string (const char *com _GL_UNUSED, const char *val, void *place)
{ {
char **pstring = (char **)place; char **pstring = (char **)place;
@ -970,7 +971,7 @@ cmd_string (const char *com, const char *val, void *place)
/* Like cmd_string but ensure the string is upper case. */ /* Like cmd_string but ensure the string is upper case. */
static bool static bool
cmd_string_uppercase (const char *com, const char *val, void *place) cmd_string_uppercase (const char *com _GL_UNUSED, const char *val, void *place)
{ {
char *q, **pstring; char *q, **pstring;
pstring = (char **)place; pstring = (char **)place;
@ -990,7 +991,7 @@ cmd_string_uppercase (const char *com, const char *val, void *place)
`.wgetrc'. In that case, and if VAL begins with `~', the tilde `.wgetrc'. In that case, and if VAL begins with `~', the tilde
gets expanded to the user's home directory. */ gets expanded to the user's home directory. */
static bool static bool
cmd_file (const char *com, const char *val, void *place) cmd_file (const char *com _GL_UNUSED, const char *val, void *place)
{ {
char **pstring = (char **)place; char **pstring = (char **)place;
@ -1037,7 +1038,7 @@ cmd_directory (const char *com, const char *val, void *place)
PLACE vector is cleared instead. */ PLACE vector is cleared instead. */
static bool static bool
cmd_vector (const char *com, const char *val, void *place) cmd_vector (const char *com _GL_UNUSED, const char *val, void *place)
{ {
char ***pvec = (char ***)place; char ***pvec = (char ***)place;
@ -1052,7 +1053,7 @@ cmd_vector (const char *com, const char *val, void *place)
} }
static bool static bool
cmd_directory_vector (const char *com, const char *val, void *place) cmd_directory_vector (const char *com _GL_UNUSED, const char *val, void *place)
{ {
char ***pvec = (char ***)place; char ***pvec = (char ***)place;
@ -1268,7 +1269,7 @@ cmd_cert_type (const char *com, const char *val, void *place)
static bool check_user_specified_header (const char *); static bool check_user_specified_header (const char *);
static bool static bool
cmd_spec_dirstruct (const char *com, const char *val, void *place_ignored) cmd_spec_dirstruct (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
if (!cmd_boolean (com, val, &opt.dirstruct)) if (!cmd_boolean (com, val, &opt.dirstruct))
return false; return false;
@ -1282,7 +1283,7 @@ cmd_spec_dirstruct (const char *com, const char *val, void *place_ignored)
} }
static bool static bool
cmd_spec_header (const char *com, const char *val, void *place_ignored) cmd_spec_header (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
/* Empty value means reset the list of headers. */ /* Empty value means reset the list of headers. */
if (*val == '\0') if (*val == '\0')
@ -1303,7 +1304,7 @@ cmd_spec_header (const char *com, const char *val, void *place_ignored)
} }
static bool static bool
cmd_spec_warc_header (const char *com, const char *val, void *place_ignored) cmd_spec_warc_header (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
/* Empty value means reset the list of headers. */ /* Empty value means reset the list of headers. */
if (*val == '\0') if (*val == '\0')
@ -1324,7 +1325,7 @@ cmd_spec_warc_header (const char *com, const char *val, void *place_ignored)
} }
static bool static bool
cmd_spec_htmlify (const char *com, const char *val, void *place_ignored) cmd_spec_htmlify (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
int flag = cmd_boolean (com, val, &opt.htmlify); int flag = cmd_boolean (com, val, &opt.htmlify);
if (flag && !opt.htmlify) if (flag && !opt.htmlify)
@ -1336,7 +1337,7 @@ cmd_spec_htmlify (const char *com, const char *val, void *place_ignored)
no limit on max. recursion depth, and don't remove listings. */ no limit on max. recursion depth, and don't remove listings. */
static bool static bool
cmd_spec_mirror (const char *com, const char *val, void *place_ignored) cmd_spec_mirror (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
int mirror; int mirror;
@ -1358,7 +1359,7 @@ cmd_spec_mirror (const char *com, const char *val, void *place_ignored)
"IPv4", "IPv6", and "none". */ "IPv4", "IPv6", and "none". */
static bool static bool
cmd_spec_prefer_family (const char *com, const char *val, void *place_ignored) cmd_spec_prefer_family (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
static const struct decode_item choices[] = { static const struct decode_item choices[] = {
{ "IPv4", prefer_ipv4 }, { "IPv4", prefer_ipv4 },
@ -1377,7 +1378,7 @@ cmd_spec_prefer_family (const char *com, const char *val, void *place_ignored)
implementation before that. */ implementation before that. */
static bool static bool
cmd_spec_progress (const char *com, const char *val, void *place_ignored) cmd_spec_progress (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
if (!valid_progress_implementation_p (val)) if (!valid_progress_implementation_p (val))
{ {
@ -1398,7 +1399,7 @@ cmd_spec_progress (const char *com, const char *val, void *place_ignored)
is specified. */ is specified. */
static bool static bool
cmd_spec_recursive (const char *com, const char *val, void *place_ignored) cmd_spec_recursive (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
if (!cmd_boolean (com, val, &opt.recursive)) if (!cmd_boolean (com, val, &opt.recursive))
return false; return false;
@ -1413,7 +1414,7 @@ cmd_spec_recursive (const char *com, const char *val, void *place_ignored)
/* Validate --regex-type and set the choice. */ /* Validate --regex-type and set the choice. */
static bool static bool
cmd_spec_regex_type (const char *com, const char *val, void *place_ignored) cmd_spec_regex_type (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
static const struct decode_item choices[] = { static const struct decode_item choices[] = {
{ "posix", regex_type_posix }, { "posix", regex_type_posix },
@ -1430,7 +1431,7 @@ cmd_spec_regex_type (const char *com, const char *val, void *place_ignored)
} }
static bool static bool
cmd_spec_restrict_file_names (const char *com, const char *val, void *place_ignored) cmd_spec_restrict_file_names (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
int restrict_os = opt.restrict_files_os; int restrict_os = opt.restrict_files_os;
int restrict_ctrl = opt.restrict_files_ctrl; int restrict_ctrl = opt.restrict_files_ctrl;
@ -1484,7 +1485,7 @@ cmd_spec_restrict_file_names (const char *com, const char *val, void *place_igno
} }
static bool static bool
cmd_spec_report_speed (const char *com, const char *val, void *place_ignored) cmd_spec_report_speed (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
opt.report_bps = strcasecmp (val, "bits") == 0; opt.report_bps = strcasecmp (val, "bits") == 0;
if (!opt.report_bps) if (!opt.report_bps)
@ -1513,7 +1514,7 @@ cmd_spec_secure_protocol (const char *com, const char *val, void *place)
/* Set all three timeout values. */ /* Set all three timeout values. */
static bool static bool
cmd_spec_timeout (const char *com, const char *val, void *place_ignored) cmd_spec_timeout (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
double value; double value;
if (!cmd_time (com, val, &value)) if (!cmd_time (com, val, &value))
@ -1525,7 +1526,7 @@ cmd_spec_timeout (const char *com, const char *val, void *place_ignored)
} }
static bool static bool
cmd_spec_useragent (const char *com, const char *val, void *place_ignored) cmd_spec_useragent (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
/* Disallow embedded newlines. */ /* Disallow embedded newlines. */
if (strchr (val, '\n')) if (strchr (val, '\n'))
@ -1544,7 +1545,7 @@ cmd_spec_useragent (const char *com, const char *val, void *place_ignored)
some random hackery for disallowing -q -v). */ some random hackery for disallowing -q -v). */
static bool static bool
cmd_spec_verbose (const char *com, const char *val, void *place_ignored) cmd_spec_verbose (const char *com, const char *val, void *place_ignored _GL_UNUSED)
{ {
bool flag; bool flag;
if (cmd_boolean (com, val, &flag)) if (cmd_boolean (com, val, &flag))
@ -1697,11 +1698,6 @@ decode_string (const char *val, const struct decode_item *items, int itemcount,
return false; return false;
} }
void cleanup_html_url (void);
void spider_cleanup (void);
/* Free the memory allocated by global variables. */ /* Free the memory allocated by global variables. */
void void
cleanup (void) cleanup (void)
@ -1737,14 +1733,11 @@ cleanup (void)
spider_cleanup (); spider_cleanup ();
host_cleanup (); host_cleanup ();
log_cleanup (); log_cleanup ();
netrc_cleanup (netrc_list);
for (i = 0; i < nurl; i++) for (i = 0; i < nurl; i++)
xfree (url[i]); xfree (url[i]);
{
extern acc_t *netrc_list;
free_netrc (netrc_list);
}
xfree_null (opt.choose_config); xfree_null (opt.choose_config);
xfree_null (opt.lfilename); xfree_null (opt.lfilename);
xfree_null (opt.dir_prefix); xfree_null (opt.dir_prefix);
@ -1794,34 +1787,27 @@ cleanup (void)
#ifdef TESTING #ifdef TESTING
const char * const char *
test_commands_sorted() test_commands_sorted(void)
{ {
int prev_idx = 0, next_idx = 1; unsigned i;
int command_count = countof (commands) - 1;
int cmp = 0; for (i = 1; i < countof(commands); ++i)
while (next_idx <= command_count)
{ {
cmp = strcasecmp (commands[prev_idx].name, commands[next_idx].name); if (strcasecmp (commands[i - 1].name, commands[i].name) > 0)
if (cmp > 0)
{ {
mu_assert ("FAILED", false); mu_assert ("FAILED", false);
break; break;
} }
else
{
prev_idx ++;
next_idx ++;
}
} }
return NULL; return NULL;
} }
const char * const char *
test_cmd_spec_restrict_file_names() test_cmd_spec_restrict_file_names(void)
{ {
int i; unsigned i;
struct { static const struct {
char *val; const char *val;
int expected_restrict_files_os; int expected_restrict_files_os;
int expected_restrict_files_ctrl; int expected_restrict_files_ctrl;
int expected_restrict_files_case; int expected_restrict_files_case;
@ -1833,7 +1819,7 @@ test_cmd_spec_restrict_file_names()
{ "unix,nocontrol,lowercase,", restrict_unix, false, restrict_lowercase, true }, { "unix,nocontrol,lowercase,", restrict_unix, false, restrict_lowercase, true },
}; };
for (i = 0; i < sizeof(test_array)/sizeof(test_array[0]); ++i) for (i = 0; i < countof(test_array); ++i)
{ {
bool res; bool res;

View File

@ -256,22 +256,22 @@ idn_decode (char *host)
/* Try to transcode string str from remote encoding to UTF-8. On success, *new /* Try to transcode string str from remote encoding to UTF-8. On success, *new
contains the transcoded string. *new content is unspecified otherwise. */ contains the transcoded string. *new content is unspecified otherwise. */
bool bool
remote_to_utf8 (struct iri *i, const char *str, const char **new) remote_to_utf8 (struct iri *iri, const char *str, const char **new)
{ {
iconv_t cd; iconv_t cd;
bool ret = false; bool ret = false;
if (!i->uri_encoding) if (!iri->uri_encoding)
return false; return false;
/* When `i->uri_encoding' == "UTF-8" there is nothing to convert. But we must /* When `i->uri_encoding' == "UTF-8" there is nothing to convert. But we must
test for non-ASCII symbols for correct hostname processing in `idn_encode' test for non-ASCII symbols for correct hostname processing in `idn_encode'
function. */ function. */
if (!strcmp (i->uri_encoding, "UTF-8")) if (!strcmp (iri->uri_encoding, "UTF-8"))
{ {
int i, len = strlen (str); const char *p = str;
for (i = 0; i < len; i++) for (p = str; *p; p++)
if ((unsigned char) str[i] >= (unsigned char) '\200') if (*p < 0)
{ {
*new = strdup (str); *new = strdup (str);
return true; return true;
@ -279,7 +279,7 @@ remote_to_utf8 (struct iri *i, const char *str, const char **new)
return false; return false;
} }
cd = iconv_open ("UTF-8", i->uri_encoding); cd = iconv_open ("UTF-8", iri->uri_encoding);
if (cd == (iconv_t)(-1)) if (cd == (iconv_t)(-1))
return false; return false;

View File

@ -351,26 +351,26 @@ init_switches (void)
size_t i, o = 0; size_t i, o = 0;
for (i = 0; i < countof (option_data); i++) for (i = 0; i < countof (option_data); i++)
{ {
struct cmdline_option *opt = &option_data[i]; struct cmdline_option *cmdopt = &option_data[i];
struct option *longopt; struct option *longopt;
if (!opt->long_name) if (!cmdopt->long_name)
/* The option is disabled. */ /* The option is disabled. */
continue; continue;
longopt = &long_options[o++]; longopt = &long_options[o++];
longopt->name = opt->long_name; longopt->name = cmdopt->long_name;
longopt->val = i; longopt->val = i;
if (opt->short_name) if (cmdopt->short_name)
{ {
*p++ = opt->short_name; *p++ = cmdopt->short_name;
optmap[opt->short_name - 32] = longopt - long_options; optmap[cmdopt->short_name - 32] = longopt - long_options;
} }
switch (opt->type) switch (cmdopt->type)
{ {
case OPT_VALUE: case OPT_VALUE:
longopt->has_arg = required_argument; longopt->has_arg = required_argument;
if (opt->short_name) if (cmdopt->short_name)
*p++ = ':'; *p++ = ':';
break; break;
case OPT_BOOLEAN: case OPT_BOOLEAN:
@ -384,16 +384,16 @@ init_switches (void)
identical to "--foo", except it has opposite meaning and identical to "--foo", except it has opposite meaning and
it doesn't allow an argument. */ it doesn't allow an argument. */
longopt = &long_options[o++]; longopt = &long_options[o++];
longopt->name = no_prefix (opt->long_name); longopt->name = no_prefix (cmdopt->long_name);
longopt->has_arg = no_argument; longopt->has_arg = no_argument;
/* Mask the value so we'll be able to recognize that we're /* Mask the value so we'll be able to recognize that we're
dealing with the false value. */ dealing with the false value. */
longopt->val = i | BOOLEAN_NEG_MARKER; longopt->val = i | BOOLEAN_NEG_MARKER;
break; break;
default: default:
assert (opt->argtype != -1); assert (cmdopt->argtype != -1);
longopt->has_arg = opt->argtype; longopt->has_arg = cmdopt->argtype;
if (opt->short_name) if (cmdopt->short_name)
{ {
if (longopt->has_arg == required_argument) if (longopt->has_arg == required_argument)
*p++ = ':'; *p++ = ':';
@ -979,7 +979,7 @@ There is NO WARRANTY, to the extent permitted by law.\n"), stdout) < 0)
exit (0); exit (0);
} }
char *program_name; /* Needed by lib/error.c. */ static char *program_name; /* Needed by lib/error.c. */
char *program_argstring; /* Needed by wget_warc.c. */ char *program_argstring; /* Needed by wget_warc.c. */
int int
@ -1093,7 +1093,7 @@ main (int argc, char **argv)
short_options, long_options, &longindex)) != -1) short_options, long_options, &longindex)) != -1)
{ {
int val; int val;
struct cmdline_option *opt; struct cmdline_option *cmdopt;
/* If LONGINDEX is unchanged, it means RET is referring a short /* If LONGINDEX is unchanged, it means RET is referring a short
option. */ option. */
@ -1115,31 +1115,31 @@ main (int argc, char **argv)
/* Use the retrieved value to locate the option in the /* Use the retrieved value to locate the option in the
option_data array, and to see if we're dealing with the option_data array, and to see if we're dealing with the
negated "--no-FOO" variant of the boolean option "--foo". */ negated "--no-FOO" variant of the boolean option "--foo". */
opt = &option_data[val & ~BOOLEAN_NEG_MARKER]; cmdopt = &option_data[val & ~BOOLEAN_NEG_MARKER];
switch (opt->type) switch (cmdopt->type)
{ {
case OPT_VALUE: case OPT_VALUE:
setoptval (opt->data, optarg, opt->long_name); setoptval (cmdopt->data, optarg, cmdopt->long_name);
break; break;
case OPT_BOOLEAN: case OPT_BOOLEAN:
if (optarg) if (optarg)
/* The user has specified a value -- use it. */ /* The user has specified a value -- use it. */
setoptval (opt->data, optarg, opt->long_name); setoptval (cmdopt->data, optarg, cmdopt->long_name);
else else
{ {
/* NEG is true for `--no-FOO' style boolean options. */ /* NEG is true for `--no-FOO' style boolean options. */
bool neg = !!(val & BOOLEAN_NEG_MARKER); bool neg = !!(val & BOOLEAN_NEG_MARKER);
setoptval (opt->data, neg ? "0" : "1", opt->long_name); setoptval (cmdopt->data, neg ? "0" : "1", cmdopt->long_name);
} }
break; break;
case OPT_FUNCALL: case OPT_FUNCALL:
{ {
void (*func) (void) = (void (*) (void)) opt->data; void (*func) (void) = (void (*) (void)) cmdopt->data;
func (); func ();
} }
break; break;
case OPT__APPEND_OUTPUT: case OPT__APPEND_OUTPUT:
setoptval ("logfile", optarg, opt->long_name); setoptval ("logfile", optarg, cmdopt->long_name);
append_to_log = true; append_to_log = true;
break; break;
case OPT__EXECUTE: case OPT__EXECUTE:
@ -1150,24 +1150,23 @@ main (int argc, char **argv)
/* We support real --no-FOO flags now, but keep these /* We support real --no-FOO flags now, but keep these
short options for convenience and backward short options for convenience and backward
compatibility. */ compatibility. */
char *p;
for (p = optarg; p && *p; p++) for (p = optarg; p && *p; p++)
switch (*p) switch (*p)
{ {
case 'v': case 'v':
setoptval ("verbose", "0", opt->long_name); setoptval ("verbose", "0", cmdopt->long_name);
break; break;
case 'H': case 'H':
setoptval ("addhostdir", "0", opt->long_name); setoptval ("addhostdir", "0", cmdopt->long_name);
break; break;
case 'd': case 'd':
setoptval ("dirstruct", "0", opt->long_name); setoptval ("dirstruct", "0", cmdopt->long_name);
break; break;
case 'c': case 'c':
setoptval ("noclobber", "1", opt->long_name); setoptval ("noclobber", "1", cmdopt->long_name);
break; break;
case 'p': case 'p':
setoptval ("noparent", "1", opt->long_name); setoptval ("noparent", "1", cmdopt->long_name);
break; break;
default: default:
fprintf (stderr, _("%s: illegal option -- `-n%c'\n"), fprintf (stderr, _("%s: illegal option -- `-n%c'\n"),
@ -1191,12 +1190,12 @@ main (int argc, char **argv)
flag = (*optarg == '1' || c_tolower (*optarg) == 'y' flag = (*optarg == '1' || c_tolower (*optarg) == 'y'
|| (c_tolower (optarg[0]) == 'o' || (c_tolower (optarg[0]) == 'o'
&& c_tolower (optarg[1]) == 'n')); && c_tolower (optarg[1]) == 'n'));
setoptval (opt->type == OPT__PARENT ? "noparent" : "noclobber", setoptval (cmdopt->type == OPT__PARENT ? "noparent" : "noclobber",
flag ? "0" : "1", opt->long_name); flag ? "0" : "1", cmdopt->long_name);
break; break;
} }
case OPT__DONT_REMOVE_LISTING: case OPT__DONT_REMOVE_LISTING:
setoptval ("removelisting", "0", opt->long_name); setoptval ("removelisting", "0", cmdopt->long_name);
break; break;
} }

View File

@ -44,10 +44,16 @@ as that of the covered work. */
#define NETRC_FILE_NAME ".netrc" #define NETRC_FILE_NAME ".netrc"
acc_t *netrc_list; static acc_t *netrc_list;
static acc_t *parse_netrc (const char *); static acc_t *parse_netrc (const char *);
void
netrc_cleanup(void)
{
free_netrc (netrc_list);
}
/* Return the correct user and password, given the host, user (as /* Return the correct user and password, given the host, user (as
given in the URL), and password (as given in the URL). May return given in the URL), and password (as given in the URL). May return
NULL. NULL.

View File

@ -42,5 +42,6 @@ typedef struct _acc_t
void search_netrc (const char *, const char **, const char **, int); void search_netrc (const char *, const char **, const char **, int);
void free_netrc (acc_t *l); void free_netrc (acc_t *l);
void netrc_cleanup(void);
#endif /* NETRC_H */ #endif /* NETRC_H */

View File

@ -305,7 +305,7 @@ openssl_read (int fd, char *buf, int bufsize, void *arg)
} }
static int static int
openssl_write (int fd, char *buf, int bufsize, void *arg) openssl_write (int fd _GL_UNUSED, char *buf, int bufsize, void *arg)
{ {
int ret = 0; int ret = 0;
struct openssl_transport_context *ctx = arg; struct openssl_transport_context *ctx = arg;
@ -347,7 +347,7 @@ openssl_peek (int fd, char *buf, int bufsize, void *arg)
} }
static const char * static const char *
openssl_errstr (int fd, void *arg) openssl_errstr (int fd _GL_UNUSED, void *arg)
{ {
struct openssl_transport_context *ctx = arg; struct openssl_transport_context *ctx = arg;
unsigned long errcode; unsigned long errcode;
@ -689,7 +689,7 @@ ssl_check_certificate (int fd, const char *host)
/* Compare and check for NULL attack in ASN1_STRING */ /* Compare and check for NULL attack in ASN1_STRING */
if (pattern_match ((char *)name_in_utf8, host) && if (pattern_match ((char *)name_in_utf8, host) &&
(strlen ((char *)name_in_utf8) == (strlen ((char *)name_in_utf8) ==
ASN1_STRING_length (name->d.dNSName))) (size_t) ASN1_STRING_length (name->d.dNSName)))
{ {
OPENSSL_free (name_in_utf8); OPENSSL_free (name_in_utf8);
break; break;
@ -753,7 +753,7 @@ ssl_check_certificate (int fd, const char *host)
xentry = X509_NAME_get_entry(xname,i); xentry = X509_NAME_get_entry(xname,i);
sdata = X509_NAME_ENTRY_get_data(xentry); sdata = X509_NAME_ENTRY_get_data(xentry);
if (strlen (common_name) != ASN1_STRING_length (sdata)) if (strlen (common_name) != (size_t) ASN1_STRING_length (sdata))
{ {
logprintf (LOG_NOTQUIET, _("\ logprintf (LOG_NOTQUIET, _("\
%s: certificate common name is invalid (contains a NUL character).\n\ %s: certificate common name is invalid (contains a NUL character).\n\

View File

@ -69,8 +69,8 @@ struct options
char **accepts; /* List of patterns to accept. */ char **accepts; /* List of patterns to accept. */
char **rejects; /* List of patterns to reject. */ char **rejects; /* List of patterns to reject. */
char **excludes; /* List of excluded FTP directories. */ const char **excludes; /* List of excluded FTP directories. */
char **includes; /* List of FTP directories to const char **includes; /* List of FTP directories to
follow. */ follow. */
bool ignore_case; /* Whether to ignore case when bool ignore_case; /* Whether to ignore case when
matching dirs and files */ matching dirs and files */

View File

@ -173,7 +173,7 @@ progress_create (const char *f_download, wgint initial, wgint total)
and current update. */ and current update. */
bool bool
progress_interactive_p (void *progress) progress_interactive_p (void *progress _GL_UNUSED)
{ {
return current_impl->interactive; return current_impl->interactive;
} }
@ -1162,7 +1162,7 @@ bar_set_params (const char *params)
#ifdef SIGWINCH #ifdef SIGWINCH
void void
progress_handle_sigwinch (int sig) progress_handle_sigwinch (int sig _GL_UNUSED)
{ {
received_sigwinch = 1; received_sigwinch = 1;
signal (SIGWINCH, progress_handle_sigwinch); signal (SIGWINCH, progress_handle_sigwinch);

View File

@ -615,11 +615,11 @@ res_cleanup (void)
#ifdef TESTING #ifdef TESTING
const char * const char *
test_is_robots_txt_url() test_is_robots_txt_url(void)
{ {
int i; unsigned i;
struct { static const struct {
char *url; const char *url;
bool expected_result; bool expected_result;
} test_array[] = { } test_array[] = {
{ "http://www.yoyodyne.com/robots.txt", true }, { "http://www.yoyodyne.com/robots.txt", true },
@ -627,7 +627,7 @@ test_is_robots_txt_url()
{ "http://www.yoyodyne.com/somepath/robots.txt", false }, { "http://www.yoyodyne.com/somepath/robots.txt", false },
}; };
for (i = 0; i < sizeof(test_array)/sizeof(test_array[0]); ++i) for (i = 0; i < countof(test_array); ++i)
{ {
mu_assert ("test_is_robots_txt_url: wrong result", mu_assert ("test_is_robots_txt_url: wrong result",
is_robots_txt_url (test_array[i].url) == test_array[i].expected_result); is_robots_txt_url (test_array[i].url) == test_array[i].expected_result);

View File

@ -588,7 +588,7 @@ fd_read_hunk (int fd, hunk_terminator_t terminator, long sizehint, long maxsize)
} }
static const char * static const char *
line_terminator (const char *start, const char *peeked, int peeklen) line_terminator (const char *start _GL_UNUSED, const char *peeked, int peeklen)
{ {
const char *p = memchr (peeked, '\n', peeklen); const char *p = memchr (peeked, '\n', peeklen);
if (p) if (p)
@ -1005,7 +1005,6 @@ retrieve_from_file (const char *file, bool html, int *count)
if (url_valid_scheme (url)) if (url_valid_scheme (url))
{ {
int dt,url_err; int dt,url_err;
uerr_t status;
struct url *url_parsed = url_parse (url, &url_err, iri, true); struct url *url_parsed = url_parse (url, &url_err, iri, true);
if (!url_parsed) if (!url_parsed)
{ {

View File

@ -34,5 +34,6 @@ as that of the covered work. */
#define visited_url(a,b) #define visited_url(a,b)
void nonexisting_url (const char *); void nonexisting_url (const char *);
void print_broken_links (void); void print_broken_links (void);
void spider_cleanup (void);
#endif /* SPIDER_H */ #endif /* SPIDER_H */

View File

@ -71,7 +71,7 @@ all_tests()
char *program_name; /* Needed by lib/error.c. */ char *program_name; /* Needed by lib/error.c. */
int int
main (int argc, char *argv[]) main (int argc _GL_UNUSED, char *argv[])
{ {
const char *result; const char *result;

View File

@ -45,6 +45,16 @@ do { \
extern int tests_run; extern int tests_run;
const char *test_parse_content_disposition(void);
const char *test_commands_sorted(void);
const char *test_cmd_spec_restrict_file_names(void);
const char *test_is_robots_txt_url(void);
const char *test_path_simplify (void);
const char *test_append_uri_pathel(void);
const char *test_are_urls_equal(void);
const char *test_subdir_p(void);
const char *test_dir_matches_p(void);
#endif /* TEST_H */ #endif /* TEST_H */
/* /*

View File

@ -2036,7 +2036,7 @@ url_string (const struct url *url, enum url_auth_mode auth_mode)
if (url->passwd) if (url->passwd)
{ {
if (auth_mode == URL_AUTH_HIDE_PASSWD) if (auth_mode == URL_AUTH_HIDE_PASSWD)
quoted_passwd = HIDDEN_PASSWORD; quoted_passwd = (char *) HIDDEN_PASSWORD;
else else
quoted_passwd = url_escape_allow_passthrough (url->passwd); quoted_passwd = url_escape_allow_passthrough (url->passwd);
} }
@ -2205,7 +2205,7 @@ ps (char *path)
#endif #endif
static const char * static const char *
run_test (char *test, char *expected_result, enum url_scheme scheme, run_test (const char *test, const char *expected_result, enum url_scheme scheme,
bool expected_change) bool expected_change)
{ {
char *test_copy = xstrdup (test); char *test_copy = xstrdup (test);
@ -2234,8 +2234,8 @@ run_test (char *test, char *expected_result, enum url_scheme scheme,
const char * const char *
test_path_simplify (void) test_path_simplify (void)
{ {
static struct { static const struct {
char *test, *result; const char *test, *result;
enum url_scheme scheme; enum url_scheme scheme;
bool should_modify; bool should_modify;
} tests[] = { } tests[] = {
@ -2267,15 +2267,16 @@ test_path_simplify (void)
{ "a/b/../../c", "c", SCHEME_HTTP, true }, { "a/b/../../c", "c", SCHEME_HTTP, true },
{ "./a/../b", "b", SCHEME_HTTP, true } { "./a/../b", "b", SCHEME_HTTP, true }
}; };
int i; unsigned i;
for (i = 0; i < countof (tests); i++) for (i = 0; i < countof (tests); i++)
{ {
const char *message; const char *message;
char *test = tests[i].test; const char *test = tests[i].test;
char *expected_result = tests[i].result; const char *expected_result = tests[i].result;
enum url_scheme scheme = tests[i].scheme; enum url_scheme scheme = tests[i].scheme;
bool expected_change = tests[i].should_modify; bool expected_change = tests[i].should_modify;
message = run_test (test, expected_result, scheme, expected_change); message = run_test (test, expected_result, scheme, expected_change);
if (message) return message; if (message) return message;
} }
@ -2283,19 +2284,19 @@ test_path_simplify (void)
} }
const char * const char *
test_append_uri_pathel() test_append_uri_pathel(void)
{ {
int i; unsigned i;
struct { static const struct {
char *original_url; const char *original_url;
char *input; const char *input;
bool escaped; bool escaped;
char *expected_result; const char *expected_result;
} test_array[] = { } test_array[] = {
{ "http://www.yoyodyne.com/path/", "somepage.html", false, "http://www.yoyodyne.com/path/somepage.html" }, { "http://www.yoyodyne.com/path/", "somepage.html", false, "http://www.yoyodyne.com/path/somepage.html" },
}; };
for (i = 0; i < sizeof(test_array)/sizeof(test_array[0]); ++i) for (i = 0; i < countof(test_array); ++i)
{ {
struct growable dest; struct growable dest;
const char *p = test_array[i].input; const char *p = test_array[i].input;
@ -2312,13 +2313,13 @@ test_append_uri_pathel()
return NULL; return NULL;
} }
const char* const char *
test_are_urls_equal() test_are_urls_equal(void)
{ {
int i; unsigned i;
struct { static const struct {
char *url1; const char *url1;
char *url2; const char *url2;
bool expected_result; bool expected_result;
} test_array[] = { } test_array[] = {
{ "http://www.adomain.com/apath/", "http://www.adomain.com/apath/", true }, { "http://www.adomain.com/apath/", "http://www.adomain.com/apath/", true },
@ -2329,7 +2330,7 @@ test_are_urls_equal()
{ "http://www.adomain.com/path%2f", "http://www.adomain.com/path/", false }, { "http://www.adomain.com/path%2f", "http://www.adomain.com/path/", false },
}; };
for (i = 0; i < sizeof(test_array)/sizeof(test_array[0]); ++i) for (i = 0; i < countof(test_array); ++i)
{ {
mu_assert ("test_are_urls_equal: wrong result", mu_assert ("test_are_urls_equal: wrong result",
are_urls_equal (test_array[i].url1, test_array[i].url2) == test_array[i].expected_result); are_urls_equal (test_array[i].url1, test_array[i].url2) == test_array[i].expected_result);

View File

@ -484,9 +484,12 @@ fork_to_background (void)
/* child: give up the privileges and keep running. */ /* child: give up the privileges and keep running. */
setsid (); setsid ();
freopen ("/dev/null", "r", stdin); if (freopen ("/dev/null", "r", stdin) == NULL)
freopen ("/dev/null", "w", stdout); DEBUGP (("Failed to redirect stdin to /dev/null.\n"));
freopen ("/dev/null", "w", stderr); if (freopen ("/dev/null", "w", stdout) == NULL)
DEBUGP (("Failed to redirect stdout to /dev/null.\n"));
if (freopen ("/dev/null", "w", stderr) == NULL)
DEBUGP (("Failed to redirect stderr to /dev/null.\n"));
} }
#endif /* !WINDOWS && !MSDOS */ #endif /* !WINDOWS && !MSDOS */
@ -957,16 +960,16 @@ subdir_p (const char *d1, const char *d2)
first element that matches DIR, through wildcards or front comparison (as first element that matches DIR, through wildcards or front comparison (as
appropriate). */ appropriate). */
static bool static bool
dir_matches_p (char **dirlist, const char *dir) dir_matches_p (const char **dirlist, const char *dir)
{ {
char **x; const char **x;
int (*matcher) (const char *, const char *, int) int (*matcher) (const char *, const char *, int)
= opt.ignore_case ? fnmatch_nocase : fnmatch; = opt.ignore_case ? fnmatch_nocase : fnmatch;
for (x = dirlist; *x; x++) for (x = dirlist; *x; x++)
{ {
/* Remove leading '/' */ /* Remove leading '/' */
char *p = *x + (**x == '/'); const char *p = *x + (**x == '/');
if (has_wildcards_p (p)) if (has_wildcards_p (p))
{ {
if (matcher (p, dir, FNM_PATHNAME) == 0) if (matcher (p, dir, FNM_PATHNAME) == 0)
@ -2102,8 +2105,8 @@ xsleep (double seconds)
This implementation does not emit newlines after 76 characters of This implementation does not emit newlines after 76 characters of
base64 data. */ base64 data. */
int size_t
base64_encode (const void *data, int length, char *dest) base64_encode (const void *data, size_t length, char *dest)
{ {
/* Conversion table. */ /* Conversion table. */
static const char tbl[64] = { static const char tbl[64] = {
@ -2170,7 +2173,7 @@ base64_encode (const void *data, int length, char *dest)
This function originates from Free Recode. */ This function originates from Free Recode. */
int ssize_t
base64_decode (const char *base64, void *dest) base64_decode (const char *base64, void *dest)
{ {
/* Table of base64 values for first 128 characters. Note that this /* Table of base64 values for first 128 characters. Note that this
@ -2283,7 +2286,7 @@ compile_posix_regex (const char *str)
int errcode = regcomp ((regex_t *) regex, str, REG_EXTENDED | REG_NOSUB); int errcode = regcomp ((regex_t *) regex, str, REG_EXTENDED | REG_NOSUB);
if (errcode != 0) if (errcode != 0)
{ {
int errbuf_size = regerror (errcode, (regex_t *) regex, NULL, 0); size_t errbuf_size = regerror (errcode, (regex_t *) regex, NULL, 0);
char *errbuf = xmalloc (errbuf_size); char *errbuf = xmalloc (errbuf_size);
regerror (errcode, (regex_t *) regex, errbuf, errbuf_size); regerror (errcode, (regex_t *) regex, errbuf, errbuf_size);
fprintf (stderr, _("Invalid regular expression %s, %s\n"), fprintf (stderr, _("Invalid regular expression %s, %s\n"),
@ -2301,10 +2304,10 @@ compile_posix_regex (const char *str)
bool bool
match_pcre_regex (const void *regex, const char *str) match_pcre_regex (const void *regex, const char *str)
{ {
int l = strlen (str); size_t l = strlen (str);
int ovector[OVECCOUNT]; int ovector[OVECCOUNT];
int rc = pcre_exec ((pcre *) regex, 0, str, l, 0, 0, ovector, OVECCOUNT); int rc = pcre_exec ((pcre *) regex, 0, str, (int) l, 0, 0, ovector, OVECCOUNT);
if (rc == PCRE_ERROR_NOMATCH) if (rc == PCRE_ERROR_NOMATCH)
return false; return false;
else if (rc < 0) else if (rc < 0)
@ -2330,7 +2333,7 @@ match_posix_regex (const void *regex, const char *str)
return true; return true;
else else
{ {
int errbuf_size = regerror (rc, opt.acceptregex, NULL, 0); size_t errbuf_size = regerror (rc, opt.acceptregex, NULL, 0);
char *errbuf = xmalloc (errbuf_size); char *errbuf = xmalloc (errbuf_size);
regerror (rc, opt.acceptregex, errbuf, errbuf_size); regerror (rc, opt.acceptregex, errbuf, errbuf_size);
logprintf (LOG_VERBOSE, _("Error while matching %s: %d\n"), logprintf (LOG_VERBOSE, _("Error while matching %s: %d\n"),
@ -2426,7 +2429,7 @@ print_decimal (double number)
/* Get the maximum name length for the given path. */ /* Get the maximum name length for the given path. */
/* Return 0 if length is unknown. */ /* Return 0 if length is unknown. */
size_t long
get_max_length (const char *path, int length, int name) get_max_length (const char *path, int length, int name)
{ {
long ret; long ret;
@ -2481,9 +2484,9 @@ get_max_length (const char *path, int length, int name)
#ifdef TESTING #ifdef TESTING
const char * const char *
test_subdir_p() test_subdir_p(void)
{ {
static struct { static const struct {
const char *d1; const char *d1;
const char *d2; const char *d2;
bool result; bool result;
@ -2506,10 +2509,10 @@ test_subdir_p()
} }
const char * const char *
test_dir_matches_p() test_dir_matches_p(void)
{ {
static struct { static struct {
char *dirlist[3]; const char *dirlist[3];
const char *dir; const char *dir;
bool result; bool result;
} test_array[] = { } test_array[] = {

View File

@ -139,8 +139,8 @@ void xsleep (double);
/* How many bytes it will take to store LEN bytes in base64. */ /* How many bytes it will take to store LEN bytes in base64. */
#define BASE64_LENGTH(len) (4 * (((len) + 2) / 3)) #define BASE64_LENGTH(len) (4 * (((len) + 2) / 3))
int base64_encode (const void *, int, char *); size_t base64_encode (const void *, size_t, char *);
int base64_decode (const char *, void *); ssize_t base64_decode (const char *, void *);
#ifdef HAVE_LIBPCRE #ifdef HAVE_LIBPCRE
void *compile_pcre_regex (const char *); void *compile_pcre_regex (const char *);
@ -154,7 +154,7 @@ void stable_sort (void *, size_t, size_t, int (*) (const void *, const void *));
const char *print_decimal (double); const char *print_decimal (double);
size_t get_max_length (const char *path, int length, int name); long get_max_length (const char *path, int length, int name);
extern unsigned char char_prop[]; extern unsigned char char_prop[];

View File

@ -108,7 +108,7 @@ static char *warc_current_filename;
static int warc_current_file_number; static int warc_current_file_number;
/* The table of CDX records, if deduplication is enabled. */ /* The table of CDX records, if deduplication is enabled. */
struct hash_table * warc_cdx_dedup_table; static struct hash_table * warc_cdx_dedup_table;
static bool warc_start_new_file (bool meta); static bool warc_start_new_file (bool meta);
@ -1231,7 +1231,7 @@ static bool
warc_write_cdx_record (const char *url, const char *timestamp_str, warc_write_cdx_record (const char *url, const char *timestamp_str,
const char *mime_type, int response_code, const char *mime_type, int response_code,
const char *payload_digest, const char *redirect_location, const char *payload_digest, const char *redirect_location,
off_t offset, const char *warc_filename, off_t offset, const char *warc_filename _GL_UNUSED,
const char *response_uuid) const char *response_uuid)
{ {
/* Transform the timestamp. */ /* Transform the timestamp. */