diff src/gtk/transfer.c @ 303:3b9d5797050f

2003-11-2 Brian Masney <masneyb@gftp.org> * lib/rfc2068.c (rfc2068_chunked_read) - more improvements to this function so that it will parse more chunked file transfers correctly. * lib/misc.c lib/gftp.h lib/rfc2068.c src/gtk/bookmarks.c src/gtk/dnd.c - removed remove_double_slashes(). Call gftp_build_path() to build the paths. This now allows Novell directory listings with //server * lib/protocols.c src/gtk/transfer.c lib/gftp.h - added variable conn_error_no_timeout to gftp_transfer structure. If this is enabled, if the remote connection to the server timed out, don't wait and immediately reconnect. So far, the only time this is used is when the user was editing a file and it is to be uploaded back to the server. * src/gtk/gftp-gtk.h src/gtk/transfer.c - add_file_transfer() now returns the struct gftp_transfer that was just added. * src/gtk/misc-gtk.c (update_directory_download_progress) - don't make the window a popup and remove the window decorations * src/text/gftp-text.c - don't populate the transfer_direction variable in struct gftp_transfer. This is only needed by the GTK+ port and will hopefully be taken out soon. * lib/gftp.h - remove gftp_transfer_type enum. It wasn't used anymore.
author masneyb
date Mon, 03 Nov 2003 02:14:05 +0000
parents 6d088dfece0b
children 6d180e6a8ba5
line wrap: on
line diff
--- a/src/gtk/transfer.c	Thu Oct 30 22:26:40 2003 +0000
+++ b/src/gtk/transfer.c	Mon Nov 03 02:14:05 2003 +0000
@@ -772,7 +772,7 @@
 }
 
 
-void
+gftp_transfer *
 add_file_transfer (gftp_request * fromreq, gftp_request * toreq,
                    gftp_window_data * fromwdata, gftp_window_data * towdata, 
                    GList * files, int copy_req)
@@ -795,6 +795,7 @@
   gftp_lookup_request_option (fromreq, "append_transfers", 
                               &append_transfers);
 
+  tdata = NULL;
   if (append_transfers)
     {
       pthread_mutex_lock (&transfer_mutex);
@@ -905,6 +906,8 @@
       if (dialog)
         gftp_gtk_ask_transfer (tdata);
     }
+
+  return (tdata);
 }
 
 
@@ -950,6 +953,7 @@
 static void
 do_upload (gftp_viewedit_data * ve_proc, gftp_dialog_data * ddata)
 {
+  gftp_transfer * tdata;
   gftp_file * tempfle;
   GList * newfile;
 
@@ -961,9 +965,12 @@
   ve_proc->filename = NULL;
   tempfle->done_rm = 1;
   newfile = g_list_append (NULL, tempfle);
-  add_file_transfer (ve_proc->fromwdata->request, ve_proc->torequest,
-                     ve_proc->fromwdata, ve_proc->towdata, newfile, 1);
+  tdata = add_file_transfer (ve_proc->fromwdata->request, ve_proc->torequest,
+                             ve_proc->fromwdata, ve_proc->towdata, newfile, 1);
   free_edit_data (ve_proc);
+
+  if (tdata != NULL)
+    tdata->conn_error_no_timeout = 1;
 }