X-Git-Url: http://git.openwrt.org/?p=project%2Fuclient.git;a=blobdiff_plain;f=uclient-fetch.c;fp=uclient-fetch.c;h=f65fab21f1cb46a30fe10f8a48637f3b95cf1320;hp=851994f47b841668ca066a294e9268afff07a123;hb=f50a654323bbfeb0de53aa2178755b282bcc9d22;hpb=caa8052ac55218a687593f3dcf30229016e48b0d diff --git a/uclient-fetch.c b/uclient-fetch.c index 851994f..f65fab2 100644 --- a/uclient-fetch.c +++ b/uclient-fetch.c @@ -18,6 +18,7 @@ #define _GNU_SOURCE #include +#include #include #include #include @@ -439,6 +440,8 @@ static int usage(const char *progname) fprintf(stderr, "Usage: %s [options] \n" "Options:\n" + " -4: Use IPv4 only\n" + " -6: Use IPv6 only\n" " -q: Turn off status messages\n" " -O : Redirect output to file (use \"-\" for stdout)\n" " -P : Set directory for output files\n" @@ -530,11 +533,12 @@ int main(int argc, char **argv) bool has_cert = false; int i, ch; int rc; + int af = -1; signal(SIGPIPE, SIG_IGN); init_ustream_ssl(); - while ((ch = getopt_long(argc, argv, "cO:P:qsT:U:Y:", longopts, &longopt_idx)) != -1) { + while ((ch = getopt_long(argc, argv, "46cO:P:qsT:U:Y:", longopts, &longopt_idx)) != -1) { switch(ch) { case 0: switch (longopt_idx) { @@ -584,6 +588,12 @@ int main(int argc, char **argv) return usage(progname); } break; + case '4': + af = AF_INET; + break; + case '6': + af = AF_INET6; + break; case 'c': resume = true; break; @@ -652,7 +662,8 @@ int main(int argc, char **argv) proxy_url = get_proxy_url(argv[0]); if (proxy_url) { cl = uclient_new(proxy_url, auth_str, &cb); - uclient_set_proxy_url(cl, argv[0], NULL); + if (cl) + uclient_set_proxy_url(cl, argv[0], NULL); } else { cl = uclient_new(argv[0], auth_str, &cb); } @@ -660,6 +671,8 @@ int main(int argc, char **argv) fprintf(stderr, "Failed to allocate uclient context\n"); return 1; } + if (af >= 0) + uclient_http_set_address_family(cl, af); if (ssl_ctx && default_certs) init_ca_cert();