]> asedeno.scripts.mit.edu Git - PuTTY.git/blobdiff - sftp.c
The xfer mechanism wasn't gracefully terminating when an error was
[PuTTY.git] / sftp.c
diff --git a/sftp.c b/sftp.c
index 66e96b44c3e3a01c76ab64a607f5281c54e9ae67..a55262a7ced228b66bdcc732f848754a60657f95 100644 (file)
--- a/sftp.c
+++ b/sftp.c
@@ -1089,7 +1089,8 @@ int xfer_done(struct fxp_xfer *xfer)
 
 void xfer_download_queue(struct fxp_xfer *xfer)
 {
-    while (xfer->req_totalsize < xfer->req_maxsize && !xfer->eof) {
+    while (xfer->req_totalsize < xfer->req_maxsize &&
+          !xfer->eof && !xfer->err) {
        /*
         * Queue a new read request.
         */
@@ -1155,6 +1156,8 @@ int xfer_download_gotpkt(struct fxp_xfer *xfer, struct sftp_packet *pktin)
 #endif
     } else if (rr->retlen < 0) {
        /* some error other than EOF; signal it back to caller */
+       xfer_set_error(xfer);
+       rr->complete = -1;
        return -1;
     }