]> granicus.if.org Git - curl/commitdiff
Fixed the resumed FTP upload loop to not require that the read callback
authorDaniel Stenberg <daniel@haxx.se>
Thu, 29 Nov 2007 22:14:33 +0000 (22:14 +0000)
committerDaniel Stenberg <daniel@haxx.se>
Thu, 29 Nov 2007 22:14:33 +0000 (22:14 +0000)
returns a full buffer on each invoke.

lib/ftp.c

index fd24ff4dfc0e53f8508b5739700fc468bac619f4..9406f293553e1c65c9ee00da0d789ed484d013c0 100644 (file)
--- a/lib/ftp.c
+++ b/lib/ftp.c
@@ -1570,12 +1570,13 @@ static CURLcode ftp_state_ul_setup(struct connectdata *conn,
                     conn->fread_in);
 
       passed += actuallyread;
-      if(actuallyread != readthisamountnow) {
-        failf(data, "Could only read %" FORMAT_OFF_T
-              " bytes from the input", passed);
+      if((actuallyread <= 0) || (actuallyread > readthisamountnow)) {
+        /* this checks for greater-than only to make sure that the
+           CURL_READFUNC_ABORT return code still aborts */
+        failf(data, "Failed to read data");
         return CURLE_FTP_COULDNT_USE_REST;
       }
-    } while(passed != data->state.resume_from);
+    } while(passed < data->state.resume_from);
 
     /* now, decrease the size of the read */
     if(data->set.infilesize>0) {