Annotation of embedaddon/curl/src/tool_help.c, revision 1.1.1.1

1.1       misho       1: /***************************************************************************
                      2:  *                                  _   _ ____  _
                      3:  *  Project                     ___| | | |  _ \| |
                      4:  *                             / __| | | | |_) | |
                      5:  *                            | (__| |_| |  _ <| |___
                      6:  *                             \___|\___/|_| \_\_____|
                      7:  *
                      8:  * Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.
                      9:  *
                     10:  * This software is licensed as described in the file COPYING, which
                     11:  * you should have received as part of this distribution. The terms
                     12:  * are also available at https://curl.haxx.se/docs/copyright.html.
                     13:  *
                     14:  * You may opt to use, copy, modify, merge, publish, distribute and/or sell
                     15:  * copies of the Software, and permit persons to whom the Software is
                     16:  * furnished to do so, under the terms of the COPYING file.
                     17:  *
                     18:  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
                     19:  * KIND, either express or implied.
                     20:  *
                     21:  ***************************************************************************/
                     22: #include "tool_setup.h"
                     23: #if defined(HAVE_STRCASECMP) && defined(HAVE_STRINGS_H)
                     24: #include <strings.h>
                     25: #endif
                     26: 
                     27: #include "tool_panykey.h"
                     28: #include "tool_help.h"
                     29: #include "tool_libinfo.h"
                     30: #include "tool_version.h"
                     31: 
                     32: #include "memdebug.h" /* keep this as LAST include */
                     33: 
                     34: #ifdef MSDOS
                     35: #  define USE_WATT32
                     36: #endif
                     37: 
                     38: /*
                     39:  * The help output is generated with the following command
                     40:  ---------------------------------------------------------
                     41: 
                     42:   cd $srcroot/docs/cmdline-opts
                     43:   ./gen.pl listhelp *.d
                     44:  */
                     45: 
                     46: struct helptxt {
                     47:   const char *opt;
                     48:   const char *desc;
                     49: };
                     50: 
                     51: static const struct helptxt helptext[] = {
                     52:   {"    --abstract-unix-socket <path>",
                     53:    "Connect via abstract Unix domain socket"},
                     54:   {"    --alt-svc <file name>",
                     55:    "Enable alt-svc with this cache file"},
                     56:   {"    --anyauth",
                     57:    "Pick any authentication method"},
                     58:   {"-a, --append",
                     59:    "Append to target file when uploading"},
                     60:   {"    --basic",
                     61:    "Use HTTP Basic Authentication"},
                     62:   {"    --cacert <file>",
                     63:    "CA certificate to verify peer against"},
                     64:   {"    --capath <dir>",
                     65:    "CA directory to verify peer against"},
                     66:   {"-E, --cert <certificate[:password]>",
                     67:    "Client certificate file and password"},
                     68:   {"    --cert-status",
                     69:    "Verify the status of the server certificate"},
                     70:   {"    --cert-type <type>",
                     71:    "Certificate file type (DER/PEM/ENG)"},
                     72:   {"    --ciphers <list of ciphers>",
                     73:    "SSL ciphers to use"},
                     74:   {"    --compressed",
                     75:    "Request compressed response"},
                     76:   {"    --compressed-ssh",
                     77:    "Enable SSH compression"},
                     78:   {"-K, --config <file>",
                     79:    "Read config from a file"},
                     80:   {"    --connect-timeout <seconds>",
                     81:    "Maximum time allowed for connection"},
                     82:   {"    --connect-to <HOST1:PORT1:HOST2:PORT2>",
                     83:    "Connect to host"},
                     84:   {"-C, --continue-at <offset>",
                     85:    "Resumed transfer offset"},
                     86:   {"-b, --cookie <data|filename>",
                     87:    "Send cookies from string/file"},
                     88:   {"-c, --cookie-jar <filename>",
                     89:    "Write cookies to <filename> after operation"},
                     90:   {"    --create-dirs",
                     91:    "Create necessary local directory hierarchy"},
                     92:   {"    --crlf",
                     93:    "Convert LF to CRLF in upload"},
                     94:   {"    --crlfile <file>",
                     95:    "Get a CRL list in PEM format from the given file"},
                     96:   {"-d, --data <data>",
                     97:    "HTTP POST data"},
                     98:   {"    --data-ascii <data>",
                     99:    "HTTP POST ASCII data"},
                    100:   {"    --data-binary <data>",
                    101:    "HTTP POST binary data"},
                    102:   {"    --data-raw <data>",
                    103:    "HTTP POST data, '@' allowed"},
                    104:   {"    --data-urlencode <data>",
                    105:    "HTTP POST data url encoded"},
                    106:   {"    --delegation <LEVEL>",
                    107:    "GSS-API delegation permission"},
                    108:   {"    --digest",
                    109:    "Use HTTP Digest Authentication"},
                    110:   {"-q, --disable",
                    111:    "Disable .curlrc"},
                    112:   {"    --disable-eprt",
                    113:    "Inhibit using EPRT or LPRT"},
                    114:   {"    --disable-epsv",
                    115:    "Inhibit using EPSV"},
                    116:   {"    --disallow-username-in-url",
                    117:    "Disallow username in url"},
                    118:   {"    --dns-interface <interface>",
                    119:    "Interface to use for DNS requests"},
                    120:   {"    --dns-ipv4-addr <address>",
                    121:    "IPv4 address to use for DNS requests"},
                    122:   {"    --dns-ipv6-addr <address>",
                    123:    "IPv6 address to use for DNS requests"},
                    124:   {"    --dns-servers <addresses>",
                    125:    "DNS server addrs to use"},
                    126:   {"    --doh-url <URL>",
                    127:    "Resolve host names over DOH"},
                    128:   {"-D, --dump-header <filename>",
                    129:    "Write the received headers to <filename>"},
                    130:   {"    --egd-file <file>",
                    131:    "EGD socket path for random data"},
                    132:   {"    --engine <name>",
                    133:    "Crypto engine to use"},
                    134:   {"    --etag-save <file>",
                    135:    "Get an ETag from response header and save it to a FILE"},
                    136:   {"    --etag-compare <file>",
                    137:    "Get an ETag from a file and send a conditional request"},
                    138:   {"    --expect100-timeout <seconds>",
                    139:    "How long to wait for 100-continue"},
                    140:   {"-f, --fail",
                    141:    "Fail silently (no output at all) on HTTP errors"},
                    142:   {"    --fail-early",
                    143:    "Fail on first transfer error, do not continue"},
                    144:   {"    --false-start",
                    145:    "Enable TLS False Start"},
                    146:   {"-F, --form <name=content>",
                    147:    "Specify multipart MIME data"},
                    148:   {"    --form-string <name=string>",
                    149:    "Specify multipart MIME data"},
                    150:   {"    --ftp-account <data>",
                    151:    "Account data string"},
                    152:   {"    --ftp-alternative-to-user <command>",
                    153:    "String to replace USER [name]"},
                    154:   {"    --ftp-create-dirs",
                    155:    "Create the remote dirs if not present"},
                    156:   {"    --ftp-method <method>",
                    157:    "Control CWD usage"},
                    158:   {"    --ftp-pasv",
                    159:    "Use PASV/EPSV instead of PORT"},
                    160:   {"-P, --ftp-port <address>",
                    161:    "Use PORT instead of PASV"},
                    162:   {"    --ftp-pret",
                    163:    "Send PRET before PASV"},
                    164:   {"    --ftp-skip-pasv-ip",
                    165:    "Skip the IP address for PASV"},
                    166:   {"    --ftp-ssl-ccc",
                    167:    "Send CCC after authenticating"},
                    168:   {"    --ftp-ssl-ccc-mode <active/passive>",
                    169:    "Set CCC mode"},
                    170:   {"    --ftp-ssl-control",
                    171:    "Require SSL/TLS for FTP login, clear for transfer"},
                    172:   {"-G, --get",
                    173:    "Put the post data in the URL and use GET"},
                    174:   {"-g, --globoff",
                    175:    "Disable URL sequences and ranges using {} and []"},
                    176:   {"    --happy-eyeballs-timeout-ms <milliseconds>",
                    177:    "How long to wait in milliseconds for IPv6 before trying IPv4"},
                    178:   {"    --haproxy-protocol",
                    179:    "Send HAProxy PROXY protocol v1 header"},
                    180:   {"-I, --head",
                    181:    "Show document info only"},
                    182:   {"-H, --header <header/@file>",
                    183:    "Pass custom header(s) to server"},
                    184:   {"-h, --help",
                    185:    "This help text"},
                    186:   {"    --hostpubmd5 <md5>",
                    187:    "Acceptable MD5 hash of the host public key"},
                    188:   {"    --http0.9",
                    189:    "Allow HTTP 0.9 responses"},
                    190:   {"-0, --http1.0",
                    191:    "Use HTTP 1.0"},
                    192:   {"    --http1.1",
                    193:    "Use HTTP 1.1"},
                    194:   {"    --http2",
                    195:    "Use HTTP 2"},
                    196:   {"    --http2-prior-knowledge",
                    197:    "Use HTTP 2 without HTTP/1.1 Upgrade"},
                    198:   {"    --http3",
                    199:    "Use HTTP v3"},
                    200:   {"    --ignore-content-length",
                    201:    "Ignore the size of the remote resource"},
                    202:   {"-i, --include",
                    203:    "Include protocol response headers in the output"},
                    204:   {"-k, --insecure",
                    205:    "Allow insecure server connections when using SSL"},
                    206:   {"    --interface <name>",
                    207:    "Use network INTERFACE (or address)"},
                    208:   {"-4, --ipv4",
                    209:    "Resolve names to IPv4 addresses"},
                    210:   {"-6, --ipv6",
                    211:    "Resolve names to IPv6 addresses"},
                    212:   {"-j, --junk-session-cookies",
                    213:    "Ignore session cookies read from file"},
                    214:   {"    --keepalive-time <seconds>",
                    215:    "Interval time for keepalive probes"},
                    216:   {"    --key <key>",
                    217:    "Private key file name"},
                    218:   {"    --key-type <type>",
                    219:    "Private key file type (DER/PEM/ENG)"},
                    220:   {"    --krb <level>",
                    221:    "Enable Kerberos with security <level>"},
                    222:   {"    --libcurl <file>",
                    223:    "Dump libcurl equivalent code of this command line"},
                    224:   {"    --limit-rate <speed>",
                    225:    "Limit transfer speed to RATE"},
                    226:   {"-l, --list-only",
                    227:    "List only mode"},
                    228:   {"    --local-port <num/range>",
                    229:    "Force use of RANGE for local port numbers"},
                    230:   {"-L, --location",
                    231:    "Follow redirects"},
                    232:   {"    --location-trusted",
                    233:    "Like --location, and send auth to other hosts"},
                    234:   {"    --login-options <options>",
                    235:    "Server login options"},
                    236:   {"    --mail-auth <address>",
                    237:    "Originator address of the original email"},
                    238:   {"    --mail-from <address>",
                    239:    "Mail from this address"},
                    240:   {"    --mail-rcpt <address>",
                    241:    "Mail to this address"},
                    242:   {"    --mail-rcpt-allowfails",
                    243:    "Allow RCPT TO command to fail for some recipients"},
                    244:   {"-M, --manual",
                    245:    "Display the full manual"},
                    246:   {"    --max-filesize <bytes>",
                    247:    "Maximum file size to download"},
                    248:   {"    --max-redirs <num>",
                    249:    "Maximum number of redirects allowed"},
                    250:   {"-m, --max-time <seconds>",
                    251:    "Maximum time allowed for the transfer"},
                    252:   {"    --metalink",
                    253:    "Process given URLs as metalink XML file"},
                    254:   {"    --negotiate",
                    255:    "Use HTTP Negotiate (SPNEGO) authentication"},
                    256:   {"-n, --netrc",
                    257:    "Must read .netrc for user name and password"},
                    258:   {"    --netrc-file <filename>",
                    259:    "Specify FILE for netrc"},
                    260:   {"    --netrc-optional",
                    261:    "Use either .netrc or URL"},
                    262:   {"-:, --next",
                    263:    "Make next URL use its separate set of options"},
                    264:   {"    --no-alpn",
                    265:    "Disable the ALPN TLS extension"},
                    266:   {"-N, --no-buffer",
                    267:    "Disable buffering of the output stream"},
                    268:   {"    --no-keepalive",
                    269:    "Disable TCP keepalive on the connection"},
                    270:   {"    --no-npn",
                    271:    "Disable the NPN TLS extension"},
                    272:   {"    --no-progress-meter",
                    273:    "Do not show the progress meter"},
                    274:   {"    --no-sessionid",
                    275:    "Disable SSL session-ID reusing"},
                    276:   {"    --noproxy <no-proxy-list>",
                    277:    "List of hosts which do not use proxy"},
                    278:   {"    --ntlm",
                    279:    "Use HTTP NTLM authentication"},
                    280:   {"    --ntlm-wb",
                    281:    "Use HTTP NTLM authentication with winbind"},
                    282:   {"    --oauth2-bearer <token>",
                    283:    "OAuth 2 Bearer Token"},
                    284:   {"-o, --output <file>",
                    285:    "Write to file instead of stdout"},
                    286:   {"-Z, --parallel",
                    287:    "Perform transfers in parallel"},
                    288:   {"    --parallel-immediate",
                    289:    "Do not wait for multiplexing (with --parallel)"},
                    290:   {"    --parallel-max",
                    291:    "Maximum concurrency for parallel transfers"},
                    292:   {"    --pass <phrase>",
                    293:    "Pass phrase for the private key"},
                    294:   {"    --path-as-is",
                    295:    "Do not squash .. sequences in URL path"},
                    296:   {"    --pinnedpubkey <hashes>",
                    297:    "FILE/HASHES Public key to verify peer against"},
                    298:   {"    --post301",
                    299:    "Do not switch to GET after following a 301"},
                    300:   {"    --post302",
                    301:    "Do not switch to GET after following a 302"},
                    302:   {"    --post303",
                    303:    "Do not switch to GET after following a 303"},
                    304:   {"    --preproxy [protocol://]host[:port]",
                    305:    "Use this proxy first"},
                    306:   {"-#, --progress-bar",
                    307:    "Display transfer progress as a bar"},
                    308:   {"    --proto <protocols>",
                    309:    "Enable/disable PROTOCOLS"},
                    310:   {"    --proto-default <protocol>",
                    311:    "Use PROTOCOL for any URL missing a scheme"},
                    312:   {"    --proto-redir <protocols>",
                    313:    "Enable/disable PROTOCOLS on redirect"},
                    314:   {"-x, --proxy [protocol://]host[:port]",
                    315:    "Use this proxy"},
                    316:   {"    --proxy-anyauth",
                    317:    "Pick any proxy authentication method"},
                    318:   {"    --proxy-basic",
                    319:    "Use Basic authentication on the proxy"},
                    320:   {"    --proxy-cacert <file>",
                    321:    "CA certificate to verify peer against for proxy"},
                    322:   {"    --proxy-capath <dir>",
                    323:    "CA directory to verify peer against for proxy"},
                    324:   {"    --proxy-cert <cert[:passwd]>",
                    325:    "Set client certificate for proxy"},
                    326:   {"    --proxy-cert-type <type>",
                    327:    "Client certificate type for HTTPS proxy"},
                    328:   {"    --proxy-ciphers <list>",
                    329:    "SSL ciphers to use for proxy"},
                    330:   {"    --proxy-crlfile <file>",
                    331:    "Set a CRL list for proxy"},
                    332:   {"    --proxy-digest",
                    333:    "Use Digest authentication on the proxy"},
                    334:   {"    --proxy-header <header/@file>",
                    335:    "Pass custom header(s) to proxy"},
                    336:   {"    --proxy-insecure",
                    337:    "Do HTTPS proxy connections without verifying the proxy"},
                    338:   {"    --proxy-key <key>",
                    339:    "Private key for HTTPS proxy"},
                    340:   {"    --proxy-key-type <type>",
                    341:    "Private key file type for proxy"},
                    342:   {"    --proxy-negotiate",
                    343:    "Use HTTP Negotiate (SPNEGO) authentication on the proxy"},
                    344:   {"    --proxy-ntlm",
                    345:    "Use NTLM authentication on the proxy"},
                    346:   {"    --proxy-pass <phrase>",
                    347:    "Pass phrase for the private key for HTTPS proxy"},
                    348:   {"    --proxy-pinnedpubkey <hashes>",
                    349:    "FILE/HASHES public key to verify proxy with"},
                    350:   {"    --proxy-service-name <name>",
                    351:    "SPNEGO proxy service name"},
                    352:   {"    --proxy-ssl-allow-beast",
                    353:    "Allow security flaw for interop for HTTPS proxy"},
                    354:   {"    --proxy-tls13-ciphers <list>",
                    355:    "TLS 1.3 ciphersuites for proxy (OpenSSL)"},
                    356:   {"    --proxy-tlsauthtype <type>",
                    357:    "TLS authentication type for HTTPS proxy"},
                    358:   {"    --proxy-tlspassword <string>",
                    359:    "TLS password for HTTPS proxy"},
                    360:   {"    --proxy-tlsuser <name>",
                    361:    "TLS username for HTTPS proxy"},
                    362:   {"    --proxy-tlsv1",
                    363:    "Use TLSv1 for HTTPS proxy"},
                    364:   {"-U, --proxy-user <user:password>",
                    365:    "Proxy user and password"},
                    366:   {"    --proxy1.0 <host[:port]>",
                    367:    "Use HTTP/1.0 proxy on given port"},
                    368:   {"-p, --proxytunnel",
                    369:    "Operate through an HTTP proxy tunnel (using CONNECT)"},
                    370:   {"    --pubkey <key>",
                    371:    "SSH Public key file name"},
                    372:   {"-Q, --quote",
                    373:    "Send command(s) to server before transfer"},
                    374:   {"    --random-file <file>",
                    375:    "File for reading random data from"},
                    376:   {"-r, --range <range>",
                    377:    "Retrieve only the bytes within RANGE"},
                    378:   {"    --raw",
                    379:    "Do HTTP \"raw\"; no transfer decoding"},
                    380:   {"-e, --referer <URL>",
                    381:    "Referrer URL"},
                    382:   {"-J, --remote-header-name",
                    383:    "Use the header-provided filename"},
                    384:   {"-O, --remote-name",
                    385:    "Write output to a file named as the remote file"},
                    386:   {"    --remote-name-all",
                    387:    "Use the remote file name for all URLs"},
                    388:   {"-R, --remote-time",
                    389:    "Set the remote file's time on the local output"},
                    390:   {"-X, --request <command>",
                    391:    "Specify request command to use"},
                    392:   {"    --request-target",
                    393:    "Specify the target for this request"},
                    394:   {"    --resolve <host:port:address[,address]...>",
                    395:    "Resolve the host+port to this address"},
                    396:   {"    --retry <num>",
                    397:    "Retry request if transient problems occur"},
                    398:   {"    --retry-connrefused",
                    399:    "Retry on connection refused (use with --retry)"},
                    400:   {"    --retry-delay <seconds>",
                    401:    "Wait time between retries"},
                    402:   {"    --retry-max-time <seconds>",
                    403:    "Retry only within this period"},
                    404:   {"    --sasl-authzid <identity> ",
                    405:    "Use this identity to act as during SASL PLAIN authentication"},
                    406:   {"    --sasl-ir",
                    407:    "Enable initial response in SASL authentication"},
                    408:   {"    --service-name <name>",
                    409:    "SPNEGO service name"},
                    410:   {"-S, --show-error",
                    411:    "Show error even when -s is used"},
                    412:   {"-s, --silent",
                    413:    "Silent mode"},
                    414:   {"    --socks4 <host[:port]>",
                    415:    "SOCKS4 proxy on given host + port"},
                    416:   {"    --socks4a <host[:port]>",
                    417:    "SOCKS4a proxy on given host + port"},
                    418:   {"    --socks5 <host[:port]>",
                    419:    "SOCKS5 proxy on given host + port"},
                    420:   {"    --socks5-basic",
                    421:    "Enable username/password auth for SOCKS5 proxies"},
                    422:   {"    --socks5-gssapi",
                    423:    "Enable GSS-API auth for SOCKS5 proxies"},
                    424:   {"    --socks5-gssapi-nec",
                    425:    "Compatibility with NEC SOCKS5 server"},
                    426:   {"    --socks5-gssapi-service <name>",
                    427:    "SOCKS5 proxy service name for GSS-API"},
                    428:   {"    --socks5-hostname <host[:port]>",
                    429:    "SOCKS5 proxy, pass host name to proxy"},
                    430:   {"-Y, --speed-limit <speed>",
                    431:    "Stop transfers slower than this"},
                    432:   {"-y, --speed-time <seconds>",
                    433:    "Trigger 'speed-limit' abort after this time"},
                    434:   {"    --ssl",
                    435:    "Try SSL/TLS"},
                    436:   {"    --ssl-allow-beast",
                    437:    "Allow security flaw to improve interop"},
                    438:   {"    --ssl-no-revoke",
                    439:    "Disable cert revocation checks (Schannel)"},
                    440:   {"    --ssl-revoke-best-effort",
                    441:    "Ignore revocation offline or missing revocation list errors (Schannel)"},
                    442:   {"    --ssl-reqd",
                    443:    "Require SSL/TLS"},
                    444:   {"-2, --sslv2",
                    445:    "Use SSLv2"},
                    446:   {"-3, --sslv3",
                    447:    "Use SSLv3"},
                    448:   {"    --stderr",
                    449:    "Where to redirect stderr"},
                    450:   {"    --styled-output",
                    451:    "Enable styled output for HTTP headers"},
                    452:   {"    --suppress-connect-headers",
                    453:    "Suppress proxy CONNECT response headers"},
                    454:   {"    --tcp-fastopen",
                    455:    "Use TCP Fast Open"},
                    456:   {"    --tcp-nodelay",
                    457:    "Use the TCP_NODELAY option"},
                    458:   {"-t, --telnet-option <opt=val>",
                    459:    "Set telnet option"},
                    460:   {"    --tftp-blksize <value>",
                    461:    "Set TFTP BLKSIZE option"},
                    462:   {"    --tftp-no-options",
                    463:    "Do not send any TFTP options"},
                    464:   {"-z, --time-cond <time>",
                    465:    "Transfer based on a time condition"},
                    466:   {"    --tls-max <VERSION>",
                    467:    "Set maximum allowed TLS version"},
                    468:   {"    --tls13-ciphers <list>",
                    469:    "TLS 1.3 ciphersuites (OpenSSL)"},
                    470:   {"    --tlsauthtype <type>",
                    471:    "TLS authentication type"},
                    472:   {"    --tlspassword",
                    473:    "TLS password"},
                    474:   {"    --tlsuser <name>",
                    475:    "TLS user name"},
                    476:   {"-1, --tlsv1",
                    477:    "Use TLSv1.0 or greater"},
                    478:   {"    --tlsv1.0",
                    479:    "Use TLSv1.0 or greater"},
                    480:   {"    --tlsv1.1",
                    481:    "Use TLSv1.1 or greater"},
                    482:   {"    --tlsv1.2",
                    483:    "Use TLSv1.2 or greater"},
                    484:   {"    --tlsv1.3",
                    485:    "Use TLSv1.3 or greater"},
                    486:   {"    --tr-encoding",
                    487:    "Request compressed transfer encoding"},
                    488:   {"    --trace <file>",
                    489:    "Write a debug trace to FILE"},
                    490:   {"    --trace-ascii <file>",
                    491:    "Like --trace, but without hex output"},
                    492:   {"    --trace-time",
                    493:    "Add time stamps to trace/verbose output"},
                    494:   {"    --unix-socket <path>",
                    495:    "Connect through this Unix domain socket"},
                    496:   {"-T, --upload-file <file>",
                    497:    "Transfer local FILE to destination"},
                    498:   {"    --url <url>",
                    499:    "URL to work with"},
                    500:   {"-B, --use-ascii",
                    501:    "Use ASCII/text transfer"},
                    502:   {"-u, --user <user:password>",
                    503:    "Server user and password"},
                    504:   {"-A, --user-agent <name>",
                    505:    "Send User-Agent <name> to server"},
                    506:   {"-v, --verbose",
                    507:    "Make the operation more talkative"},
                    508:   {"-V, --version",
                    509:    "Show version number and quit"},
                    510:   {"-w, --write-out <format>",
                    511:    "Use output FORMAT after completion"},
                    512:   {"    --xattr",
                    513:    "Store metadata in extended file attributes"},
                    514:   { NULL, NULL }
                    515: };
                    516: 
                    517: #ifdef NETWARE
                    518: #  define PRINT_LINES_PAUSE 23
                    519: #endif
                    520: 
                    521: #ifdef __SYMBIAN32__
                    522: #  define PRINT_LINES_PAUSE 16
                    523: #endif
                    524: 
                    525: struct feat {
                    526:   const char *name;
                    527:   int bitmask;
                    528: };
                    529: 
                    530: static const struct feat feats[] = {
                    531:   {"AsynchDNS",      CURL_VERSION_ASYNCHDNS},
                    532:   {"Debug",          CURL_VERSION_DEBUG},
                    533:   {"TrackMemory",    CURL_VERSION_CURLDEBUG},
                    534:   {"IDN",            CURL_VERSION_IDN},
                    535:   {"IPv6",           CURL_VERSION_IPV6},
                    536:   {"Largefile",      CURL_VERSION_LARGEFILE},
                    537:   {"SSPI",           CURL_VERSION_SSPI},
                    538:   {"GSS-API",        CURL_VERSION_GSSAPI},
                    539:   {"Kerberos",       CURL_VERSION_KERBEROS5},
                    540:   {"SPNEGO",         CURL_VERSION_SPNEGO},
                    541:   {"NTLM",           CURL_VERSION_NTLM},
                    542:   {"NTLM_WB",        CURL_VERSION_NTLM_WB},
                    543:   {"SSL",            CURL_VERSION_SSL},
                    544:   {"libz",           CURL_VERSION_LIBZ},
                    545:   {"brotli",         CURL_VERSION_BROTLI},
                    546:   {"CharConv",       CURL_VERSION_CONV},
                    547:   {"TLS-SRP",        CURL_VERSION_TLSAUTH_SRP},
                    548:   {"HTTP2",          CURL_VERSION_HTTP2},
                    549:   {"HTTP3",          CURL_VERSION_HTTP3},
                    550:   {"UnixSockets",    CURL_VERSION_UNIX_SOCKETS},
                    551:   {"HTTPS-proxy",    CURL_VERSION_HTTPS_PROXY},
                    552:   {"MultiSSL",       CURL_VERSION_MULTI_SSL},
                    553:   {"PSL",            CURL_VERSION_PSL},
                    554:   {"alt-svc",        CURL_VERSION_ALTSVC},
                    555: };
                    556: 
                    557: void tool_help(void)
                    558: {
                    559:   int i;
                    560:   puts("Usage: curl [options...] <url>");
                    561:   for(i = 0; helptext[i].opt; i++) {
                    562:     printf(" %-19s %s\n", helptext[i].opt, helptext[i].desc);
                    563: #ifdef PRINT_LINES_PAUSE
                    564:     if(i && ((i % PRINT_LINES_PAUSE) == 0))
                    565:       tool_pressanykey();
                    566: #endif
                    567:   }
                    568: }
                    569: 
                    570: static int
                    571: featcomp(const void *p1, const void *p2)
                    572: {
                    573:   /* The arguments to this function are "pointers to pointers to char", but
                    574:      the comparison arguments are "pointers to char", hence the following cast
                    575:      plus dereference */
                    576: #ifdef HAVE_STRCASECMP
                    577:   return strcasecmp(* (char * const *) p1, * (char * const *) p2);
                    578: #elif defined(HAVE_STRCMPI)
                    579:   return strcmpi(* (char * const *) p1, * (char * const *) p2);
                    580: #else
                    581:   return strcmp(* (char * const *) p1, * (char * const *) p2);
                    582: #endif
                    583: }
                    584: 
                    585: void tool_version_info(void)
                    586: {
                    587:   const char *const *proto;
                    588: 
                    589:   printf(CURL_ID "%s\n", curl_version());
                    590: #ifdef CURL_PATCHSTAMP
                    591:   printf("Release-Date: %s, security patched: %s\n",
                    592:          LIBCURL_TIMESTAMP, CURL_PATCHSTAMP);
                    593: #else
                    594:   printf("Release-Date: %s\n", LIBCURL_TIMESTAMP);
                    595: #endif
                    596:   if(curlinfo->protocols) {
                    597:     printf("Protocols: ");
                    598:     for(proto = curlinfo->protocols; *proto; ++proto) {
                    599:       printf("%s ", *proto);
                    600:     }
                    601:     puts(""); /* newline */
                    602:   }
                    603:   if(curlinfo->features) {
                    604:     char *featp[ sizeof(feats) / sizeof(feats[0]) + 1];
                    605:     size_t numfeat = 0;
                    606:     unsigned int i;
                    607:     printf("Features:");
                    608:     for(i = 0; i < sizeof(feats)/sizeof(feats[0]); i++) {
                    609:       if(curlinfo->features & feats[i].bitmask)
                    610:         featp[numfeat++] = (char *)feats[i].name;
                    611:     }
                    612: #ifdef USE_METALINK
                    613:     featp[numfeat++] = (char *)"Metalink";
                    614: #endif
                    615:     qsort(&featp[0], numfeat, sizeof(char *), featcomp);
                    616:     for(i = 0; i< numfeat; i++)
                    617:       printf(" %s", featp[i]);
                    618:     puts(""); /* newline */
                    619:   }
                    620:   if(strcmp(CURL_VERSION, curlinfo->version)) {
                    621:     printf("WARNING: curl and libcurl versions do not match. "
                    622:            "Functionality may be affected.\n");
                    623:   }
                    624: }
                    625: 
                    626: void tool_list_engines(void)
                    627: {
                    628:   CURL *curl = curl_easy_init();
                    629:   struct curl_slist *engines = NULL;
                    630: 
                    631:   /* Get the list of engines */
                    632:   curl_easy_getinfo(curl, CURLINFO_SSL_ENGINES, &engines);
                    633: 
                    634:   puts("Build-time engines:");
                    635:   if(engines) {
                    636:     for(; engines; engines = engines->next)
                    637:       printf("  %s\n", engines->data);
                    638:   }
                    639:   else {
                    640:     puts("  <none>");
                    641:   }
                    642: 
                    643:   /* Cleanup the list of engines */
                    644:   curl_slist_free_all(engines);
                    645:   curl_easy_cleanup(curl);
                    646: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>