X-Git-Url: http://sjero.net/git/?p=wget;a=blobdiff_plain;f=src%2Foptions.h;h=9358e3023a5a9893b55a7f9a62346258bcdf383b;hp=7010cd414746d148ebf3fea285246c28aa50c9d7;hb=38a7829dcb4eb5dba28dbf0f05c6a80fea9217f8;hpb=0a3697ad652df74ffeec8a97e1d23c343d8ef391 diff --git a/src/options.h b/src/options.h index 7010cd41..9358e302 100644 --- a/src/options.h +++ b/src/options.h @@ -1,11 +1,13 @@ /* struct options. - Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc. + Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, + 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software Foundation, + Inc. This file is part of GNU Wget. GNU Wget is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2 of the License, or +the Free Software Foundation; either version 3 of the License, or (at your option) any later version. GNU Wget is distributed in the hope that it will be useful, @@ -14,182 +16,275 @@ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License -along with Wget; if not, write to the Free Software -Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - -In addition, as a special exception, the Free Software Foundation -gives permission to link the code of its release of Wget with the -OpenSSL project's "OpenSSL" library (or with modified versions of it -that use the same license as the "OpenSSL" library), and distribute -the linked executables. You must obey the GNU General Public License -in all respects for all of the code used other than "OpenSSL". If you -modify this file, you may extend this exception to your version of the -file, but you are not obligated to do so. If you do not wish to do -so, delete this exception statement from your version. */ - -/* Needed for FDP. */ -#include +along with Wget. If not, see . + +Additional permission under GNU GPL version 3 section 7 + +If you modify this program, or any covered work, by linking or +combining it with the OpenSSL project's OpenSSL library (or a +modified version of that library), containing parts covered by the +terms of the OpenSSL or SSLeay licenses, the Free Software Foundation +grants you additional permission to convey the resulting work. +Corresponding Source for a non-source form of such a combination +shall include the source code for the parts of OpenSSL used as well +as that of the covered work. */ struct options { - int verbose; /* Are we verbose? */ - int quiet; /* Are we quiet? */ + int verbose; /* Are we verbose? (First set to -1, + hence not boolean.) */ + bool quiet; /* Are we quiet? */ int ntry; /* Number of tries per URL */ - int retry_connrefused; /* Treat CONNREFUSED as non-fatal. */ - int background; /* Whether we should work in background. */ - int kill_longer; /* Do we reject messages with *more* - data than specified in - content-length? */ - int ignore_length; /* Do we heed content-length at all? */ - int recursive; /* Are we recursive? */ - int spanhost; /* Do we span across hosts in + bool retry_connrefused; /* Treat CONNREFUSED as non-fatal. */ + bool background; /* Whether we should work in background. */ + bool ignore_length; /* Do we heed content-length at all? */ + bool recursive; /* Are we recursive? */ + bool spanhost; /* Do we span across hosts in recursion? */ - int relative_only; /* Follow only relative links. */ - int no_parent; /* Restrict access to the parent + int max_redirect; /* Maximum number of times we'll allow + a page to redirect. */ + bool relative_only; /* Follow only relative links. */ + bool no_parent; /* Restrict access to the parent directory. */ int reclevel; /* Maximum level of recursion */ - int dirstruct; /* Do we build the directory structure + bool dirstruct; /* Do we build the directory structure as we go along? */ - int no_dirstruct; /* Do we hate dirstruct? */ + bool no_dirstruct; /* Do we hate dirstruct? */ int cut_dirs; /* Number of directory components to cut. */ - int add_hostdir; /* Do we add hostname directory? */ - int noclobber; /* Disables clobbering of existing + bool add_hostdir; /* Do we add hostname directory? */ + bool protocol_directories; /* Whether to prepend "http"/"ftp" to dirs. */ + bool noclobber; /* Disables clobbering of existing data. */ + bool unlink; /* remove file before clobbering */ char *dir_prefix; /* The top of directory tree */ char *lfilename; /* Log filename */ char *input_filename; /* Input filename */ - int force_html; /* Is the input file an HTML file? */ + char *choose_config; /* Specified config file */ + bool noconfig; + bool force_html; /* Is the input file an HTML file? */ - int spider; /* Is Wget in spider mode? */ + char *default_page; /* Alternative default page (index file) */ + + bool spider; /* Is Wget in spider mode? */ char **accepts; /* List of patterns to accept. */ char **rejects; /* List of patterns to reject. */ - char **excludes; /* List of excluded FTP directories. */ - char **includes; /* List of FTP directories to + const char **excludes; /* List of excluded FTP directories. */ + const char **includes; /* List of FTP directories to follow. */ + bool ignore_case; /* Whether to ignore case when + matching dirs and files */ + + char *acceptregex_s; /* Patterns to accept (a regex string). */ + char *rejectregex_s; /* Patterns to reject (a regex string). */ + void *acceptregex; /* Patterns to accept (a regex struct). */ + void *rejectregex; /* Patterns to reject (a regex struct). */ + enum { +#ifdef HAVE_LIBPCRE + regex_type_pcre, +#endif + regex_type_posix + } regex_type; /* The regex library. */ + void *(*regex_compile_fun)(const char *); /* Function to compile a regex. */ + bool (*regex_match_fun)(const void *, const char *); /* Function to match a string to a regex. */ char **domains; /* See host.c */ char **exclude_domains; - int dns_cache; /* whether we cache DNS lookups. */ + bool dns_cache; /* whether we cache DNS lookups. */ char **follow_tags; /* List of HTML tags to recursively follow. */ char **ignore_tags; /* List of HTML tags to ignore if recursing. */ - int follow_ftp; /* Are FTP URL-s followed in recursive + bool follow_ftp; /* Are FTP URL-s followed in recursive retrieving? */ - int retr_symlinks; /* Whether we retrieve symlinks in + bool retr_symlinks; /* Whether we retrieve symlinks in FTP. */ char *output_document; /* The output file to which the documents will be printed. */ - int od_known_regular; /* whether output_document is a - regular file we can manipulate, - i.e. not `-' or a device file. */ - FILE *dfp; /* The file pointer to the output - document. */ - - int always_rest; /* Always use REST. */ - char *ftp_acc; /* FTP username */ - char *ftp_pass; /* FTP password */ - int netrc; /* Whether to read .netrc. */ - int ftp_glob; /* FTP globbing */ - int ftp_pasv; /* Passive FTP. */ - - char *http_user; /* HTTP user. */ + char *warc_filename; /* WARC output filename */ + char *warc_tempdir; /* WARC temp dir */ + char *warc_cdx_dedup_filename; /* CDX file to be used for deduplication. */ + wgint warc_maxsize; /* WARC max archive size */ + bool warc_compression_enabled; /* For GZIP compression. */ + bool warc_digests_enabled; /* For SHA1 digests. */ + bool warc_cdx_enabled; /* Create CDX files? */ + bool warc_keep_log; /* Store the log file in a WARC record. */ + char **warc_user_headers; /* User-defined WARC header(s). */ + + char *user; /* Generic username */ + char *passwd; /* Generic password */ + bool ask_passwd; /* Ask for password? */ + + bool always_rest; /* Always use REST. */ + wgint start_pos; /* Start position of a download. */ + char *ftp_user; /* FTP username */ + char *ftp_passwd; /* FTP password */ + bool netrc; /* Whether to read .netrc. */ + bool ftp_glob; /* FTP globbing */ + bool ftp_pasv; /* Passive FTP. */ + + char *http_user; /* HTTP username. */ char *http_passwd; /* HTTP password. */ - char *user_header; /* User-defined header(s). */ - int http_keep_alive; /* whether we use keep-alive */ + char **user_headers; /* User-defined header(s). */ + bool http_keep_alive; /* whether we use keep-alive */ - int use_proxy; /* Do we use proxy? */ - int allow_cache; /* Do we allow server-side caching? */ + bool use_proxy; /* Do we use proxy? */ + bool allow_cache; /* Do we allow server-side caching? */ char *http_proxy, *ftp_proxy, *https_proxy; char **no_proxy; char *base_href; char *progress_type; /* progress indicator type. */ + bool show_progress; /* Show only the progress bar */ char *proxy_user; /*oli*/ char *proxy_passwd; -#ifdef HAVE_SELECT - long timeout; /* The value of read timeout in - seconds. */ -#endif - int random_wait; /* vary from 0 .. wait secs by random()? */ - long wait; /* The wait period between retrievals. */ - long waitretry; /* The wait period between retries. - HEH */ - int use_robots; /* Do we heed robots.txt? */ - long limit_rate; /* Limit the download rate to this + double read_timeout; /* The read/write timeout. */ + double dns_timeout; /* The DNS timeout. */ + double connect_timeout; /* The connect timeout. */ + + bool random_wait; /* vary from 0 .. wait secs by random()? */ + double wait; /* The wait period between retrievals. */ + double waitretry; /* The wait period between retries. - HEH */ + bool use_robots; /* Do we heed robots.txt? */ + + wgint limit_rate; /* Limit the download rate to this many bps. */ - long quota; /* Maximum number of bytes to - retrieve. */ - VERY_LONG_TYPE downloaded; /* How much we downloaded already. */ - int downloaded_overflow; /* Whether the above overflowed. */ - int numurls; /* Number of successfully downloaded - URLs */ - - int server_response; /* Do we print server response? */ - int save_headers; /* Do we save headers together with + SUM_SIZE_INT quota; /* Maximum file size to download and + store. */ + + bool server_response; /* Do we print server response? */ + bool save_headers; /* Do we save headers together with file? */ + bool content_on_error; /* Do we output the content when the HTTP + status code indicates a server error */ + + bool debug; /* Debugging on/off */ -#ifdef DEBUG - int debug; /* Debugging on/off */ -#endif /* DEBUG */ +#ifdef USE_WATT32 + bool wdebug; /* Watt-32 tcp/ip debugging on/off */ +#endif - int timestamping; /* Whether to use time-stamping. */ + bool timestamping; /* Whether to use time-stamping. */ - int backup_converted; /* Do we save pre-converted files as *.orig? */ + bool backup_converted; /* Do we save pre-converted files as *.orig? */ int backups; /* Are numeric backups made? */ - char *useragent; /* Naughty User-Agent, which can be - set to something other than - Wget. */ + char *useragent; /* User-Agent string, which can be set + to something other than Wget. */ char *referer; /* Naughty Referer, which can be set to something other than NULL. */ - int convert_links; /* Will the links be converted + bool convert_links; /* Will the links be converted locally? */ - int remove_listing; /* Do we remove .listing files + bool remove_listing; /* Do we remove .listing files generated by FTP? */ - int htmlify; /* Do we HTML-ify the OS-dependent + bool htmlify; /* Do we HTML-ify the OS-dependent listings? */ char *dot_style; - long dot_bytes; /* How many bytes in a printing + wgint dot_bytes; /* How many bytes in a printing dot. */ int dots_in_line; /* How many dots in one line. */ int dot_spacing; /* How many dots between spacings. */ - int delete_after; /* Whether the files will be deleted + bool delete_after; /* Whether the files will be deleted after download. */ - int html_extension; /* Use ".html" extension on all text/html? */ + bool adjust_extension; /* Use ".html" extension on all text/html? */ - int page_requisites; /* Whether we need to download all files + bool page_requisites; /* Whether we need to download all files necessary to display a page properly. */ char *bind_address; /* What local IP address to bind to. */ + #ifdef HAVE_SSL - char *sslcadir; /* CA directory (hash files) */ - char *sslcafile; /* CA File to use */ - char *sslcertfile; /* external client cert to use. */ - char *sslcertkey; /* the keyfile for this certificate - (if not internal) included in the - certfile. */ - int sslcerttype; /* 0 = PEM / 1=ASN1 (DER) */ - int sslcheckcert; /* 0 do not check / 1 check server cert */ - char *sslegdsock; /* optional socket of the egd daemon */ - int sslprotocol; /* 0 = auto / 1 = v2 / 2 = v3 / 3 = TLSv1 */ + enum { + secure_protocol_auto, + secure_protocol_sslv2, + secure_protocol_sslv3, + secure_protocol_tlsv1, + secure_protocol_pfs + } secure_protocol; /* type of secure protocol to use. */ + bool check_cert; /* whether to validate the server's cert */ + char *cert_file; /* external client certificate to use. */ + char *private_key; /* private key file (if not internal). */ + enum keyfile_type { + keyfile_pem, + keyfile_asn1 + } cert_type; /* type of client certificate file */ + enum keyfile_type + private_key_type; /* type of private key file */ + + char *ca_directory; /* CA directory (hash files) */ + char *ca_cert; /* CA certificate file to use */ + + char *random_file; /* file with random data to seed the PRNG */ + char *egd_file; /* file name of the egd daemon socket */ + bool https_only; /* whether to follow HTTPS only */ #endif /* HAVE_SSL */ - int cookies; - char *cookies_input; - char *cookies_output; + bool cookies; /* whether cookies are used. */ + char *cookies_input; /* file we're loading the cookies from. */ + char *cookies_output; /* file we're saving the cookies to. */ + bool keep_session_cookies; /* whether session cookies should be + saved and loaded. */ char *post_data; /* POST query string */ char *post_file_name; /* File to post */ + char *method; /* HTTP Method to use in Header */ + char *body_data; /* HTTP Method Data String */ + char *body_file; /* HTTP Method File */ enum { - restrict_none, - restrict_shell, + restrict_unix, restrict_windows - } restrict_file_names; /* whether we restrict file name chars. */ + } restrict_files_os; /* file name restriction ruleset. */ + bool restrict_files_ctrl; /* non-zero if control chars in URLs + are restricted from appearing in + generated file names. */ + bool restrict_files_nonascii; /* non-zero if bytes with values greater + than 127 are restricted. */ + enum { + restrict_no_case_restriction, + restrict_lowercase, + restrict_uppercase + } restrict_files_case; /* file name case restriction. */ + + bool strict_comments; /* whether strict SGML comments are + enforced. */ + + bool preserve_perm; /* whether remote permissions are used + or that what is set by umask. */ + +#ifdef ENABLE_IPV6 + bool ipv4_only; /* IPv4 connections have been requested. */ + bool ipv6_only; /* IPv4 connections have been requested. */ +#endif + enum { + prefer_ipv4, + prefer_ipv6, + prefer_none + } prefer_family; /* preferred address family when more + than one type is available */ + + bool content_disposition; /* Honor HTTP Content-Disposition header. */ + bool auth_without_challenge; /* Issue Basic authentication creds without + waiting for a challenge. */ + + bool enable_iri; + char *encoding_remote; + char *locale; + + bool trustservernames; +#ifdef __VMS + int ftp_stmlf; /* Force Stream_LF format for binary FTP. */ +#endif /* def __VMS */ + + bool useservertimestamps; /* Update downloaded files' timestamps to + match those on server? */ + + bool show_all_dns_entries; /* Show all the DNS entries when resolving a + name. */ + bool report_bps; /*Output bandwidth in bits format*/ }; extern struct options opt;