diff options
author | Daniel Stenberg <daniel@haxx.se> | 2003-02-27 12:50:54 +0000 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2003-02-27 12:50:54 +0000 |
commit | 52ebf506074c6ab2e3653563f589574f6227616d (patch) | |
tree | f6553589021575defdfe95a50e156e7938623dbc | |
parent | d34a4b126e880cf14560ae5f950c094d4614cb2d (diff) |
It appears that there are FTP-servers that return size 0 for files
when SIZE is used on the file while being in BINARY mode. To work
around that (stupid) behavior, we attempt to parse the RETR response
even if the SIZE returned size zero.
Debugging help from Salvatore Sorrentino on February 26, 2003.
-rw-r--r-- | lib/ftp.c | 12 |
1 files changed, 11 insertions, 1 deletions
@@ -1854,9 +1854,19 @@ CURLcode Curl_ftp_nextconnect(struct connectdata *conn) int size=-1; /* default unknown size */ + + /* + * It appears that there are FTP-servers that return size 0 for files + * when SIZE is used on the file while being in BINARY mode. To work + * around that (stupid) behavior, we attempt to parse the RETR response + * even if the SIZE returned size zero. + * + * Debugging help from Salvatore Sorrentino on February 26, 2003. + */ + if(!dirlist && !data->set.ftp_ascii && - (-1 == downloadsize)) { + (downloadsize < 1)) { /* * It seems directory listings either don't show the size or very * often uses size 0 anyway. ASCII transfers may very well turn out |