File: //proc/2/cwd/usr/share/zsh/site-functions/_curl
#compdef curl
# curl zsh completion
local curcontext="$curcontext" state state_descr line
typeset -A opt_args
local rc=1
_arguments -C -S \
  --happy-eyeballs-timeout-ms'[How long to wait in milliseconds for IPv6 before trying IPv4]':'<milliseconds>' \
  {-c,--cookie-jar}'[Write cookies to <filename> after operation]':'<filename>':_files \
  {-D,--dump-header}'[Write the received headers to <filename>]':'<filename>':_files \
  {-y,--speed-time}'[Trigger '\''speed-limit'\'' abort after this time]':'<seconds>' \
  --proxy-cacert'[CA certificate to verify peer against for proxy]':'<file>':_files \
  --tls13-ciphers'[of TLS 1.3 ciphersuites> TLS 1.3 cipher suites to use]':'<list' \
  {-E,--cert}'[Client certificate file and password]':'<certificate[:password]>' \
  --libcurl'[Dump libcurl equivalent code of this command line]':'<file>':_files \
  --proxy-capath'[CA directory to verify peer against for proxy]':'<dir>':_files \
  --proxy-negotiate'[HTTP Negotiate (SPNEGO) authentication on the proxy]':'Use' \
  --proxy-pinnedpubkey'[FILE/HASHES public key to verify proxy with]':'<hashes>' \
  --crlfile'[Get a CRL list in PEM format from the given file]':'<file>':_files \
  --proxy-insecure'[HTTPS proxy connections without verifying the proxy]':'Do' \
  --proxy-ssl-allow-beast'[security flaw for interop for HTTPS proxy]':'Allow' \
  --abstract-unix-socket'[Connect via abstract Unix domain socket]':'<path>' \
  --pinnedpubkey'[FILE/HASHES Public key to verify peer against]':'<hashes>' \
  --proxy-pass'[Pass phrase for the private key for HTTPS proxy]':'<phrase>' \
  {-p,--proxytunnel}'[Operate through an HTTP proxy tunnel (using CONNECT)]' \
  --socks5-hostname'[SOCKS5 proxy, pass host name to proxy]':'<host[:port]>' \
  --proto-default'[Use PROTOCOL for any URL missing a scheme]':'<protocol>' \
  --proxy-tls13-ciphers'[list> TLS 1.3 proxy cipher suites]':'<ciphersuite' \
  --socks5-gssapi-service'[SOCKS5 proxy service name for GSS-API]':'<name>' \
  --ftp-alternative-to-user'[String to replace USER \[name\]]':'<command>' \
  --ftp-ssl-control'[SSL/TLS for FTP login, clear for transfer]':'Require' \
  {-T,--upload-file}'[Transfer local FILE to destination]':'<file>':_files \
  --local-port'[Force use of RANGE for local port numbers]':'<num/range>' \
  --proxy-tlsauthtype'[TLS authentication type for HTTPS proxy]':'<type>' \
  {-R,--remote-time}'[Set the remote file'\''s time on the local output]' \
  --retry-connrefused'[on connection refused (use with --retry)]':'Retry' \
  --suppress-connect-headers'[proxy CONNECT response headers]':'Suppress' \
  {-j,--junk-session-cookies}'[session cookies read from file]':'Ignore' \
  --location-trusted'[--location, and send auth to other hosts]':'Like' \
  --proxy-cert-type'[Client certificate type for HTTPS proxy]':'<type>' \
  {-O,--remote-name}'[Write output to a file named as the remote file]' \
  --trace-ascii'[Like --trace, but without hex output]':'<file>':_files \
  --connect-timeout'[Maximum time allowed for connection]':'<seconds>' \
  --expect100-timeout'[How long to wait for 100-continue]':'<seconds>' \
  {-g,--globoff}'[Disable URL sequences and ranges using {} and \[\]]' \
  {-m,--max-time}'[Maximum time allowed for the transfer]':'<seconds>' \
  --dns-ipv4-addr'[IPv4 address to use for DNS requests]':'<address>' \
  --dns-ipv6-addr'[IPv6 address to use for DNS requests]':'<address>' \
  --ignore-content-length'[the size of the remote resource]':'Ignore' \
  {-k,--insecure}'[Allow insecure server connections when using SSL]' \
  --mail-auth'[Originator address of the original email]':'<address>' \
  --noproxy'[List of hosts which do not use proxy]':'<no-proxy-list>' \
  --proto-redir'[Enable/disable PROTOCOLS on redirect]':'<protocols>' \
  --dns-interface'[Interface to use for DNS requests]':'<interface>' \
  --hostpubmd5'[Acceptable MD5 hash of the host public key]':'<md5>' \
  --keepalive-time'[Interval time for keepalive probes]':'<seconds>' \
  --proxy-cert'[Set client certificate for proxy]':'<cert[:passwd]>' \
  --random-file'[File for reading random data from]':'<file>':_files \
  --socks5-basic'[Enable username/password auth for SOCKS5 proxies]' \
  --cacert'[CA certificate to verify peer against]':'<file>':_files \
  {-H,--header}'[Pass custom header(s) to server]':'<header/@file>' \
  {-i,--include}'[Include protocol response headers in the output]' \
  --proxy-header'[Pass custom header(s) to proxy]':'<header/@file>' \
  --unix-socket'[Connect through this Unix domain socket]':'<path>' \
  {-w,--write-out}'[Use output FORMAT after completion]':'<format>' \
  --http2-prior-knowledge'[HTTP 2 without HTTP/1.1 Upgrade]':'Use' \
  {-o,--output}'[Write to file instead of stdout]':'<file>':_files \
  {-J,--remote-header-name}'[the header-provided filename]':'Use' \
  --socks4a'[SOCKS4a proxy on given host + port]':'<host[:port]>' \
  {-Y,--speed-limit}'[Stop transfers slower than this]':'<speed>' \
  {-z,--time-cond}'[Transfer based on a time condition]':'<time>' \
  --capath'[CA directory to verify peer against]':'<dir>':_files \
  {-f,--fail}'[Fail silently (no output at all) on HTTP errors]' \
  --proxy-tlspassword'[TLS password for HTTPS proxy]':'<string>' \
  {-U,--proxy-user}'[Proxy user and password]':'<user:password>' \
  --proxy1.0'[Use HTTP/1.0 proxy on given port]':'<host[:port]>' \
  {-r,--range}'[Retrieve only the bytes within RANGE]':'<range>' \
  {-A,--user-agent}'[Send User-Agent <name> to server]':'<name>' \
  --egd-file'[EGD socket path for random data]':'<file>':_files \
  --fail-early'[Fail on first transfer error, do not continue]' \
  --haproxy-protocol'[HAProxy PROXY protocol v1 header]':'Send' \
  --preproxy'[Use this proxy first]':'[protocol://]host[:port]' \
  --retry-max-time'[Retry only within this period]':'<seconds>' \
  --socks4'[SOCKS4 proxy on given host + port]':'<host[:port]>' \
  --socks5'[SOCKS5 proxy on given host + port]':'<host[:port]>' \
  --socks5-gssapi-nec'[with NEC SOCKS5 server]':'Compatibility' \
  --ssl-allow-beast'[security flaw to improve interop]':'Allow' \
  --cert-status'[Verify the status of the server certificate]' \
  --ftp-create-dirs'[the remote dirs if not present]':'Create' \
  {-:,--next}'[Make next URL use its separate set of options]' \
  --proxy-key-type'[Private key file type for proxy]':'<type>' \
  --remote-name-all'[the remote file name for all URLs]':'Use' \
  {-X,--request}'[Specify request command to use]':'<command>' \
  --retry'[Retry request if transient problems occur]':'<num>' \
  --ssl-no-revoke'[cert revocation checks (WinSSL)]':'Disable' \
  --cert-type'[Certificate file type (DER/PEM/ENG)]':'<type>' \
  --connect-to'[Connect to host]':'<HOST1:PORT1:HOST2:PORT2>' \
  --create-dirs'[Create necessary local directory hierarchy]' \
  --max-redirs'[Maximum number of redirects allowed]':'<num>' \
  {-n,--netrc}'[Must read .netrc for user name and password]' \
  --proxy-crlfile'[Set a CRL list for proxy]':'<file>':_files \
  --sasl-ir'[Enable initial response in SASL authentication]' \
  --socks5-gssapi'[GSS-API auth for SOCKS5 proxies]':'Enable' \
  --interface'[Use network INTERFACE (or address)]':'<name>' \
  --key-type'[Private key file type (DER/PEM/ENG)]':'<type>' \
  --netrc-file'[Specify FILE for netrc]':'<filename>':_files \
  {-N,--no-buffer}'[Disable buffering of the output stream]' \
  --proxy-service-name'[SPNEGO proxy service name]':'<name>' \
  --styled-output'[styled output for HTTP headers]':'Enable' \
  --max-filesize'[Maximum file size to download]':'<bytes>' \
  --negotiate'[Use HTTP Negotiate (SPNEGO) authentication]' \
  --no-keepalive'[Disable TCP keepalive on the connection]' \
  {-#,--progress-bar}'[Display transfer progress as a bar]' \
  {-x,--proxy}'[Use this proxy]':'[protocol://]host[:port]' \
  --proxy-anyauth'[any proxy authentication method]':'Pick' \
  {-Q,--quote}'[Send command(s) to server before transfer]' \
  --request-target'[the target for this request]':'Specify' \
  {-u,--user}'[Server user and password]':'<user:password>' \
  {-K,--config}'[Read config from a file]':'<file>':_files \
  {-C,--continue-at}'[Resumed transfer offset]':'<offset>' \
  --data-raw'[HTTP POST data, '\''@'\'' allowed]':'<data>' \
  --disallow-username-in-url'[username in url]':'Disallow' \
  --krb'[Enable Kerberos with security <level>]':'<level>' \
  --proxy-ciphers'[SSL ciphers to use for proxy]':'<list>' \
  --proxy-digest'[Use Digest authentication on the proxy]' \
  --proxy-tlsuser'[TLS username for HTTPS proxy]':'<name>' \
  {-b,--cookie}'[Send cookies from string/file]':'<data>' \
  --data-urlencode'[HTTP POST data url encoded]':'<data>' \
  --delegation'[GSS-API delegation permission]':'<LEVEL>' \
  {-P,--ftp-port}'[Use PORT instead of PASV]':'<address>' \
  --post301'[Do not switch to GET after following a 301]' \
  --post302'[Do not switch to GET after following a 302]' \
  --post303'[Do not switch to GET after following a 303]' \
  --trace-time'[Add time stamps to trace/verbose output]' \
  --dns-servers'[DNS server addrs to use]':'<addresses>' \
  {-G,--get}'[Put the post data in the URL and use GET]' \
  --limit-rate'[Limit transfer speed to RATE]':'<speed>' \
  --ntlm-wb'[Use HTTP NTLM authentication with winbind]' \
  --path-as-is'[Do not squash .. sequences in URL path]' \
  --proxy-basic'[Use Basic authentication on the proxy]' \
  --retry-delay'[Wait time between retries]':'<seconds>' \
  --trace'[Write a debug trace to FILE]':'<file>':_files \
  {-a,--append}'[Append to target file when uploading]' \
  --ftp-ssl-ccc-mode'[Set CCC mode]':'<active/passive>' \
  --metalink'[Process given URLs as metalink XML file]' \
  --tr-encoding'[Request compressed transfer encoding]' \
  --xattr'[Store metadata in extended file attributes]' \
  --ftp-skip-pasv-ip'[the IP address for PASV]':'Skip' \
  --pass'[Pass phrase for the private key]':'<phrase>' \
  --proxy-ntlm'[Use NTLM authentication on the proxy]' \
  {-S,--show-error}'[Show error even when -s is used]' \
  --ciphers'[of ciphers> SSL ciphers to use]':'<list' \
  --form-string'[Specify multipart MIME data]':'<name=string>' \
  --login-options'[Server login options]':'<options>' \
  --tftp-blksize'[Set TFTP BLKSIZE option]':'<value>' \
  --tftp-no-options'[not send any TFTP options]':'Do' \
  {-v,--verbose}'[Make the operation more talkative]' \
  --proxy-key'[Private key for HTTPS proxy]':'<key>' \
  {-F,--form}'[Specify multipart MIME data]':'<name=content>' \
  --mail-from'[Mail from this address]':'<address>' \
  --oauth2-bearer'[OAuth 2 Bearer Token]':'<token>' \
  --proto'[Enable/disable PROTOCOLS]':'<protocols>' \
  --tlsauthtype'[TLS authentication type]':'<type>' \
  --no-sessionid'[Disable SSL session-ID reusing]' \
  --data-binary'[HTTP POST binary data]':'<data>' \
  --mail-rcpt'[Mail to this address]':'<address>' \
  {-t,--telnet-option}'[Set telnet option]':'<opt=val>' \
  --tls-max'[Use TLSv1.0 or greater]':'<VERSION>' \
  --ftp-ssl-ccc'[Send CCC after authenticating]' \
  {-4,--ipv4}'[Resolve names to IPv4 addresses]' \
  {-6,--ipv6}'[Resolve names to IPv6 addresses]' \
  --netrc-optional'[either .netrc or URL]':'Use' \
  --service-name'[SPNEGO service name]':'<name>' \
  {-V,--version}'[Show version number and quit]' \
  --data-ascii'[HTTP POST ASCII data]':'<data>' \
  --ftp-account'[Account data string]':'<data>' \
  --compressed-ssh'[SSH compression]':'Enable' \
  --disable-eprt'[Inhibit using EPRT or LPRT]' \
  --ftp-method'[Control CWD usage]':'<method>' \
  --pubkey'[SSH Public key file name]':'<key>' \
  --raw'[Do HTTP "raw"; no transfer decoding]' \
  --anyauth'[Pick any authentication method]' \
  --compressed'[Request compressed response]' \
  --ftp-pasv'[Use PASV/EPSV instead of PORT]' \
  --no-alpn'[Disable the ALPN TLS extension]' \
  --tcp-nodelay'[Use the TCP_NODELAY option]' \
  {-B,--use-ascii}'[Use ASCII/text transfer]' \
  --digest'[Use HTTP Digest Authentication]' \
  --proxy-tlsv1'[Use TLSv1 for HTTPS proxy]' \
  --engine'[Crypto engine to use]':'<name>' \
  --no-npn'[Disable the NPN TLS extension]' \
  --basic'[Use HTTP Basic Authentication]' \
  {-M,--manual}'[Display the full manual]' \
  --false-start'[Enable TLS False Start]' \
  --crlf'[Convert LF to CRLF in upload]' \
  {-d,--data}'[HTTP POST data]':'<data>' \
  {-I,--head}'[Show document info only]' \
  --key'[Private key file name]':'<key>' \
  --ntlm'[Use HTTP NTLM authentication]' \
  {-e,--referer}'[Referrer URL]':'<URL>' \
  {-1,--tlsv1}'[Use TLSv1.0 or greater]' \
  --disable-epsv'[Inhibit using EPSV]' \
  --stderr'[Where to redirect stderr]' \
  --ftp-pret'[Send PRET before PASV]' \
  {-L,--location}'[Follow redirects]' \
  --tcp-fastopen'[Use TCP Fast Open]' \
  --tlsuser'[TLS user name]':'<name>' \
  {-l,--list-only}'[List only mode]' \
  {-q,--disable}'[Disable .curlrc]' \
  --url'[URL to work with]':'<url>' \
  {-0,--http1.0}'[Use HTTP 1.0]' \
  {-h,--help}'[This help text]' \
  --ssl-reqd'[Require SSL/TLS]' \
  --tlspassword'[TLS password]' \
  {-s,--silent}'[Silent mode]' \
  --http1.1'[Use HTTP 1.1]' \
  {-2,--sslv2}'[Use SSLv2]' \
  {-3,--sslv3}'[Use SSLv3]' \
  --tlsv1.0'[Use TLSv1.0]' \
  --tlsv1.1'[Use TLSv1.1]' \
  --tlsv1.2'[Use TLSv1.2]' \
  --tlsv1.3'[Use TLSv1.3]' \
  --http2'[Use HTTP 2]' \
  --ssl'[Try SSL/TLS]' \
  '*:URL:_urls' && rc=0
return rc