When retrieving a file dont open file until we have to to prevent files of size 0 being created when retrieval fails, bug found by Jeff Angielski
diff --git a/networking/ftpgetput.c b/networking/ftpgetput.c
index a23c64a..44e91c3 100644
--- a/networking/ftpgetput.c
+++ b/networking/ftpgetput.c
@@ -174,16 +174,9 @@
 		filesize = atol(buf + 4);
 	}
 
-	/* only make a local file if we know that one exists on the remote server */
-	if (do_continue) {
-		fd_local = xopen(local_file, O_APPEND | O_WRONLY);
-	} else {
-		fd_local = xopen(local_file, O_CREAT | O_TRUNC | O_WRONLY);
-	}
-
 	if (do_continue) {
 		struct stat sbuf;
-		if (fstat(fd_local, &sbuf) < 0) {
+		if (lstat(local_file, &sbuf) < 0) {
 			perror_msg_and_die("fstat()");
 		}
 		if (sbuf.st_size > 0) {
@@ -206,6 +199,13 @@
 		error_msg_and_die("RETR error: %s", buf + 4);
 	}
 
+	/* only make a local file if we know that one exists on the remote server */
+	if (do_continue) {
+		fd_local = xopen(local_file, O_APPEND | O_WRONLY);
+	} else {
+		fd_local = xopen(local_file, O_CREAT | O_TRUNC | O_WRONLY);
+	}
+
 	/* Copy the file */
 	if (copyfd(fd_data, fd_local, filesize) == -1) {
 		exit(EXIT_FAILURE);