complete -c curl -n 'string match -qr "^@" -- (commandline -ct)' -k -xa "(printf '%s\n' -- @(__fish_complete_suffix (commandline -ct | string replace -r '^@' '') ''))" # These based on the autogenerated completions. complete -c curl -l abstract-unix-socket -d '(HTTP) Connect through an abstract Unix domain socket' complete -c curl -l anyauth -d '(HTTP) Use most secure authentication method automatically' complete -c curl -s a -l append -d '(FTP SFTP) Upload: append to the target file' complete -c curl -l basic -d '(HTTP) Use HTTP Basic authentication' complete -c curl -l cacert -d '(TLS) Use the specified certificate file' complete -c curl -l capath -d '(TLS) Use the specified certificate directory' complete -c curl -l cert-status -d '(TLS) Use Certificate Status Request (aka OCSP stapling)' complete -c curl -l cert-type -d '(TLS) Set type of the provided client certificate' -a 'PEM, DER ENG P12' complete -c curl -s E -l cert -d '(TLS) Use this cert' complete -c curl -l ciphers -d '(TLS) Specifies which ciphers to use' complete -c curl -l compressed-ssh -d '(SCP SFTP) Enables built-in SSH compression' complete -c curl -l compressed -d '(HTTP) Request a compressed response' complete -c curl -s K -l config -d 'Specify a text file to read curl arguments from' complete -c curl -l connect-timeout -d 'Maximum time in seconds you allow connection to take' complete -c curl -l connect-to -d 'For a request to the given HOST1:PORT1 pair, connect to HOST2:PORT2 instead' complete -c curl -s C -l continue-at -d 'Continue/Resume a previous file transfer at the given offset' complete -c curl -s c -l cookie-jar -d '(HTTP) Write all cookies to this file' complete -c curl -s b -l cookie -d '(HTTP) Pass the data to the HTTP server in the Cookie header' complete -c curl -l create-dirs -d 'Create dirs for -o/--output' complete -c curl -l crlf -d '(FTP SMTP) Convert LF to CRLF in upload. Useful for MVS (OS/390)' complete -c curl -l crlfile -d '(TLS) Provide a file using PEM format with a Certificate Revocation List' complete -c curl -l data-ascii -d '(HTTP) Alias for -d, --data' complete -c curl -l data-binary -d '(HTTP) Post data exactly as specified with no processing' complete -c curl -l data-raw -d '(HTTP) Post data like --data but without interpeting "@"' complete -c curl -l data-urlencode -d '(HTTP) Post data URL-encoded' complete -c curl -s d -l data -d '(HTTP) Sends the specified data in a POST request to the HTTP server' complete -c curl -l delegation -d '(GSS/kerberos) Tell the server how much it can delegate for user creds' -xa '( printf %s\t%s\n \ none "Don\'t allow any delegation" \ policy "Delegate only if the OK-AS-DELEGATE flag is set in the Kerberos service ticket" \ always "Allow the server to delegate")' complete -c curl -l digest -d '(HTTP) Enables HTTP Digest authentication' complete -c curl -l disable-eprt -d '(FTP) Don\'t use EPRT and LPRT commands in active FTP' complete -c curl -l disable-epsv -d '(FTP) Don\'t use EPSV in passive FTP' complete -c curl -s q -l disable -d 'Disable curlrc' complete -c curl -l disallow-username-in-url -d '(HTTP) Exit if passed a url containing a username' complete -c curl -l dns-interface -d '(DNS) Send outgoing DNS requests through ' complete -c curl -l dns-ipv4-addr -d '(DNS) Bind to when making IPv4 DNS requests' complete -c curl -l dns-ipv6-addr -d '(DNS) Bind to when making IPv6 DNS requests' complete -c curl -l dns-servers -d 'Set the list of DNS servers to use' complete -c curl -l doh-url -d '(all) Specify which DNS-over-HTTPS (DOH) server to use to resolve hostnames' complete -c curl -s D -l dump-header -d '(HTTP FTP) Write the received protocol headers to the specified file' complete -c curl -l egd-file -d '(TLS) Specify the path name to the Entropy Gathering Daemon socket' complete -c curl -l engine -d '(TLS) Select the OpenSSL crypto engine to use for cipher operations' complete -c curl -l expect100-timeout -d '(HTTP) Maximum time in seconds to wait for a 100-continue' complete -c curl -l fail-early -d 'Fail and exit on the first detected transfer error' complete -c curl -s f -l fail -d '(HTTP) Fail silently (no output at all) on server errors' complete -c curl -l false-start -d '(TLS) Use false start during the TLS handshake' complete -c curl -l form-string -d '(HTTP SMTP IMAP) Like --form except using value string literally' complete -c curl -s F -l form -d '(HTTP SMTP IMAP) Emulate pressing submit on filled-in form' complete -c curl -l ftp-account -d '(FTP) Data for the ACCT command' complete -c curl -l ftp-alternative-to-user -d '(FTP) If USER and PASS commands fail, send this command' complete -c curl -l ftp-create-dirs -d '(FTP SFTP) Create missing dirs with ftp' complete -c curl -l ftp-method -d '(FTP) Control what method curl should use to reach a file on an FTP(S) server' complete -c curl -l ftp-pasv -d '(FTP) Use passive mode for the data connection' complete -c curl -s P -l ftp-port -d '(FTP) Reverses the default initiator/listener roles when connecting with FTP' complete -c curl -l ftp-pret -d '(FTP) Tell curl to send a PRET command before PASV (and EPSV)' complete -c curl -l ftp-skip-pasv-ip -d '(FTP) Use same IP instead of IP the server suggests in response to PASV' complete -c curl -l ftp-ssl-ccc-mode -d '(FTP) Sets the CCC mode' complete -c curl -l ftp-ssl-ccc -d '(FTP) Use CCC (Clear Command Channel) Shuts down the SSL/TLS layer after auth' complete -c curl -l ftp-ssl-control -d '(FTP) Require SSL/TLS for the FTP login, clear for transfer' complete -c curl -s G -l get -d 'Use GET instead of POST' complete -c curl -s g -l globoff -d 'This option switches off the "URL globbing parser"' complete -c curl -l happy-eyeballs-timeout-ms -d 'Attempt to connect to both IPv4 and IPv6 in parallel' complete -c curl -l haproxy-protocol -d '(HTTP) Use HAProxy PROXY protocol' complete -c curl -s I -l head -d '(HTTP FTP FILE) Fetch the headers only' complete -c curl -s H -l header -d '(HTTP) Extra header to include in the request when sending HTTP to a server' complete -c curl -s h -l help -d 'Usage help' complete -c curl -l hostpubmd5 -d '(SFTP SCP) Pass a string containing 32 hexadecimal digits' complete -c curl -l 'http0.9' -d '(HTTP) Accept HTTP version 0.9 response' complete -c curl -s 0 -l 'http1.0' -d '(HTTP) Use HTTP version 1' complete -c curl -l 'http1.1' -d '(HTTP) Use HTTP version 1.1' complete -c curl -l http2-prior-knowledge -d '(HTTP) Use HTTP/2 immediately (without trying HTTP1)' complete -c curl -l http2 -d '(HTTP) Use HTTP version 2' complete -c curl -l ignore-content-length -d '(FTP HTTP) Ignore the Content-Length header' complete -c curl -s i -l include -d 'Include the HTTP response headers in the output' complete -c curl -s k -l insecure -d '(TLS) Allow insecure connections' complete -c curl -l interface -d 'Perform an operation using a specified interface' complete -c curl -s 4 -l ipv4 -d 'Use IPv4 only' complete -c curl -s 6 -l ipv6 -d 'Use IPv6 only' complete -c curl -s j -l junk-session-cookies -d '(HTTP) Discard all session cookies' complete -c curl -l keepalive-time -d 'Specify idle time before keepalive is sent' complete -c curl -l key-type -d '(TLS) Private key file type' -xa 'DER PEM ENG' complete -c curl -l key -d '(TLS SSH) Private key file name' complete -c curl -l krb -d '(FTP) Enable Kerberos authentication and use' complete -c curl -l libcurl -d 'Write C-code equivalent to the invocation to the given file' complete -c curl -l limit-rate -d 'Limit bandwidth (Examples: 200K, 3m and 1G)' complete -c curl -s l -l list-only -d '(FTP POP3) (FTP) Use name-only view when listing' complete -c curl -l local-port -d 'Set a preferred single number or range (FROM-TO) of local ports to use' complete -c curl -l location-trusted -d '(HTTP) Like -L, --location, but allow sending the name + password' complete -c curl -s L -l location -d '(HTTP) Follow redirects' complete -c curl -l login-options -d '(IMAP POP3 SMTP) Specify the login options' complete -c curl -l mail-auth -d '(SMTP) Specify a single address' complete -c curl -l mail-from -d '(SMTP) Specify a single address that the given mail should get sent from' complete -c curl -l mail-rcpt -d '(SMTP) Specify a single address, user name or mailing list name' complete -c curl -s M -l manual -d 'Manual. Display the huge help text' complete -c curl -l max-filesize -d 'Specify the maximum size (in bytes) of a file to download' complete -c curl -l max-redirs -d '(HTTP) Set maximum number of redirection-followings allowed' complete -c curl -s m -l max-time -d 'Maximum time in seconds that you allow the whole operation to take' complete -c curl -l metalink -d 'Process URI as Metalink file' complete -c curl -l negotiate -d '(HTTP) Enables Negotiate (SPNEGO) authentication' complete -c curl -l netrc-file -d 'Use this netrc file' complete -c curl -l netrc-optional -d 'Make netrc optional' complete -c curl -s n -l netrc -d 'Use ~/.netrc' complete -c curl -l next -d 'Use a separate operation for the following URL' complete -c curl -l no-alpn -d '(HTTPS) Disable the ALPN TLS extension' complete -c curl -s N -l no-buffer -d 'Disable the buffering of the output stream' complete -c curl -l no-keepalive -d 'Disable use of keepalive messages on the TCP connection' complete -c curl -l no-npn -d '(HTTPS) Disable NPN TLS extension' complete -c curl -l no-sessionid -d '(TLS) Disable use of SSL session-ID caching' complete -c curl -l noproxy -d 'Comma-separated list of hosts which do not use a proxy' complete -c curl -l ntlm-wb -d '(HTTP) Enable NTLM, but hand over auth to separate ntlmauth binary' complete -c curl -l ntlm -d '(HTTP) Enable NTLM authentication' complete -c curl -l oauth2-bearer -d '(IMAP POP3 SMTP) Specify the Bearer Token for OAUTH 2' complete -c curl -s o -l output -d 'Write output to instead of stdout' complete -c curl -l pass -d '(SSH TLS) Passphrase for the private key' complete -c curl -l path-as-is -d 'Do not handle sequences of /../ or /./ in the given URL path' complete -c curl -l pinnedpubkey -d '(TLS) Use the specified public key file (or hashes)' complete -c curl -l post301 -d '(HTTP) Respect RFC 7231/6.4' complete -c curl -l post302 -d '(HTTP) Respect RFC 7231/6.4' complete -c curl -l post303 -d '(HTTP) Violate RFC 7231/6.4' complete -c curl -l preproxy -d 'Use the specified SOCKS proxy before connecting to HTTP(S) proxy' complete -c curl -s '#' -l progress-bar -d 'Display progress as a simple progress bar' complete -c curl -l proto-default -d 'Use this protocol for any URL missing a scheme name' complete -c curl -l proto-redir -d 'Limit what protocols it may use on redirect' # TODO: args complete -c curl -l proto -d 'Limit what protocols it may use in the transfer' complete -c curl -l proxy-anyauth -d 'Like --anyauth but for the proxy' complete -c curl -l proxy-basic -d 'Use HTTP Basic authentication to communicate with proxy' complete -c curl -l proxy-cacert -d 'Same as --cacert but used in HTTPS proxy context' complete -c curl -l proxy-capath -d 'Same as --capath but used in HTTPS proxy context' complete -c curl -l proxy-cert-type -d 'Same as --cert-type but used in HTTPS proxy context' complete -c curl -l proxy-cert -d 'Same as -E, --cert but used in HTTPS proxy context' complete -c curl -l proxy-ciphers -d 'Same as --ciphers but used in HTTPS proxy context' complete -c curl -l proxy-crlfile -d 'Same as --crlfile but used in HTTPS proxy context' complete -c curl -l proxy-digest -d 'Use HTTP Digest authentication to communicate with proxy' complete -c curl -l proxy-header -d '(HTTP) Extra header to include in the request when sending HTTP to a proxy' complete -c curl -l proxy-insecure -d 'Same as -k, --insecure but used in HTTPS proxy context' complete -c curl -l proxy-key-type -d 'Same as --key-type but used in HTTPS proxy context' complete -c curl -l proxy-key -d 'Same as --key but used in HTTPS proxy context' complete -c curl -l proxy-negotiate -d 'Use HTTP Negotiate authentication to communicate with proxy' complete -c curl -l proxy-ntlm -d 'Use HTTP NTLM authentication when to communicate with proxy' complete -c curl -l proxy-pass -d 'Same as --pass but used in HTTPS proxy context' complete -c curl -l proxy-pinnedpubkey -d '(TLS) Use specified public key file or hashes to verify proxy' complete -c curl -l proxy-service-name -d 'This option allows you to change the service name for proxy negotiation' complete -c curl -l proxy-ssl-allow-beast -d 'Same as --ssl-allow-beast but used in HTTPS proxy context' complete -c curl -l proxy-tls13-ciphers -d '(TLS) Specify cipher suites for TLS 1.3 proxy connection' complete -c curl -l proxy-tlsauthtype -d 'Same as --tlsauthtype but used in HTTPS proxy context' complete -c curl -l proxy-tlspassword -d 'Same as --tlspassword but used in HTTPS proxy context' complete -c curl -l proxy-tlsuser -d 'Same as --tlsuser but used in HTTPS proxy context' complete -c curl -l proxy-tlsv1 -d 'Same as -1, --tlsv1 but used in HTTPS proxy context' complete -c curl -s U -l proxy-user -d 'Specify the user name and password to use for proxy authentication' complete -c curl -s x -l proxy -d 'Use the specified proxy' complete -c curl -l 'proxy1.0' -d 'Use the specified HTTP 1.0 proxy' complete -c curl -s p -l proxytunnel -d 'If HTTP proxy is used, make curl tunnel through it' complete -c curl -l pubkey -d '(SFTP SCP) Public key file name' complete -c curl -s Q -l quote -d '(FTP SFTP) Send an arbitrary command to the remote FTP or SFTP server' complete -c curl -l random-file -d 'Specify file containing random data' complete -c curl -s r -l range -d '(HTTP FTP SFTP FILE) Retrieve a byte range' complete -c curl -o 500 -d 'specifies the last 500 bytes' complete -c curl -s 1 -d 'specifies the first and last byte only(*)(HTTP)' complete -c curl -l raw -d '(HTTP) Pass raw data (no HTTP decoding or transfer encoding)' complete -c curl -s e -l referer -d '(HTTP) Sends the "Referrer Page" information to the HTTP server' complete -c curl -s J -l remote-header-name -d '(HTTP) Save output to filename from Content-Disposition' complete -c curl -l remote-name-all -d 'For every URL write output to local file by default' complete -c curl -s O -l remote-name -d 'Write output to a local file named like the remote file we get' complete -c curl -s R -l remote-time -d 'Use timestamp of remote file on output' complete -c curl -l request-target -d '(HTTP) Use an alternative request target' complete -c curl -s X -l request -d '(HTTP) Specifies a custom HTTP method' complete -c curl -l resolve -d 'Provide a custom address for a specific host and port pair' complete -c curl -l retry-connrefused -d 'Consider ECONNREFUSED a transient error' complete -c curl -l retry-delay -d 'Time to wait between transfer retries' complete -c curl -l retry-max-time -d 'The retry timer is reset before the first transfer attempt' complete -c curl -l retry -d 'Number of retries when transient error occurs' complete -c curl -l sasl-ir -d 'Enable initial response in SASL authentication' complete -c curl -l service-name -d 'This option allows you to change the service name for SPNEGO' complete -c curl -s S -l show-error -d 'When used with -s, --silent, it makes curl show an error message if it fails' complete -c curl -s s -l silent -d 'Silent or quiet mode. Don\'t show progress meter or error messages' complete -c curl -l socks4 -d 'Use the specified SOCKS4 proxy' complete -c curl -l socks4a -d 'Use the specified SOCKS4a proxy' complete -c curl -l socks5-basic -d 'Use username/password authentication to connect to SOCKS5 proxy' complete -c curl -l socks5-gssapi-nec -d 'As part of the GSS-API negotiation a protection mode is negotiated' complete -c curl -l socks5-gssapi-service -d 'The default service name for a socks server is rcmd/server-fqdn' complete -c curl -l socks5-gssapi -d 'Tells curl to use GSS-API authentication when connecting to a SOCKS5 proxy' complete -c curl -l socks5-hostname -d 'Use the specified SOCKS5 proxy (and let the proxy resolve the host name)' complete -c curl -l socks5 -d 'Use the specified SOCKS5 proxy - but resolve the host name locally' complete -c curl -s Y -l speed-limit -d 'Abort download if it\'s slower than given speed (Bps) for speed-time' complete -c curl -s y -l speed-time -d 'Abort download if it\'s slower than speed for given speed-time (s)' complete -c curl -l ssl-allow-beast -d 'Don\'t work around BEAST security flaw in SSL3 and TLS1.0' complete -c curl -l ssl-no-revoke -d '(Schannel) This option tells curl to disable certificate revocation checks' complete -c curl -l ssl-reqd -d '(FTP IMAP POP3 SMTP) Require SSL/TLS for the connection' complete -c curl -l ssl -d '(FTP IMAP POP3 SMTP) Try to use SSL/TLS for the connection' complete -c curl -s 2 -l sslv2 -d '(SSL) Use SSL version 2' complete -c curl -s 3 -l sslv3 -d '(SSL) Use SSL version 3' complete -c curl -l stderr -d 'Redirect all writes to stderr to the specified file instead' complete -c curl -l styled-output -d 'Use bold font styles when writing HTTP headers to terminal' complete -c curl -l suppress-connect-headers -d 'Don\'t print response headers for CONNECT request if -p is set' complete -c curl -l tcp-fastopen -d 'Enable use of TCP Fast Open' complete -c curl -l tcp-nodelay -d 'Turn on the TCP_NODELAY option' complete -c curl -s t -l telnet-option -d 'Pass options to the telnet protocol' complete -c curl -l tftp-blksize -d '(TFTP) Set TFTP BLKSIZE option (must be >512)' complete -c curl -l tftp-no-options -d '(TFTP) Tells curl not to send TFTP options requests' complete -c curl -s z -l time-cond -d '(HTTP FTP) Request file modified before or later than given time' complete -c curl -l tls-max -d '(SSL) VERSION defines maximum supported TLS version' complete -c curl -l tls13-ciphers -d '(TLS) Specifies cipher suites to use for TLS 1.3' complete -c curl -l tlsauthtype -d 'Set TLS authentication type' complete -c curl -l tlspassword -d 'Set password for use with the TLS authentication method' complete -c curl -l tlsuser -d 'Set username for use with the TLS authentication method' complete -c curl -l 'tlsv1.0' -d '(TLS) Forces curl to use TLS version 1.0' complete -c curl -l 'tlsv1.1' -d '(TLS) Forces curl to use TLS version 1.1' complete -c curl -l 'tlsv1.2' -d '(TLS) Forces curl to use TLS version 1.2' complete -c curl -l 'tlsv1.3' -d '(TLS) Forces curl to use TLS version 1.3' complete -c curl -l tlsv1 -d '(SSL) Tells curl to use at least TLS version 1' complete -c curl -l tr-encoding -d '(HTTP) Request compressed Transfer-Encoding, uncompress on receive' complete -c curl -l trace-ascii -d 'Enables a full trace dump of all incoming and outgoing data' complete -c curl -l trace-time -d 'Prepends a time stamp to each trace or verbose line that curl displays' complete -c curl -l trace -d 'Enables a full trace dump of all incoming and outgoing data' complete -c curl -l unix-socket -d '(HTTP) Connect through this Unix domain socket, instead of using the network' complete -c curl -s T -l upload-file -d 'This transfers the specified local file to the remote URL' complete -c curl -l url -d 'Specify a URL to fetch' complete -c curl -s B -l use-ascii -d '(FTP LDAP) Enable ASCII transfer' complete -c curl -s A -l user-agent -d '(HTTP) Specify the User-Agent string to send to the HTTP server' complete -c curl -s u -l user -d 'Specify the user name and password to use for server authentication' complete -c curl -s v -l verbose -d 'Makes curl verbose during the operation' complete -c curl -s V -l version -d 'Displays information about curl and the libcurl version it uses' complete -c curl -s w -l write-out -d 'Make curl display information on stdout after a completed transfer' complete -c curl -l eprt -l no-eprt -d 'for --disable-eprt' complete -c curl -l epsv -l no-epsv -d 'for --disable-epsv' complete -c curl -l max-redir -d 'Set maximum number of redirects' complete -c curl -l xattr -d 'Store metadata in xattrs (like origin URL)'