diff src/gtk/dnd.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 51725086634d
children df4c91bf4adf
line wrap: on
line diff
--- a/src/gtk/dnd.c	Thu Oct 30 22:26:40 2003 +0000
+++ b/src/gtk/dnd.c	Mon Nov 03 02:14:05 2003 +0000
@@ -118,7 +118,7 @@
 	      gpointer data)
 {
   GList * templist, * filelist;
-  char *tempstr, *str, *pos;
+  char *tempstr, *str, *df;
   gftp_window_data * wdata;
   size_t totlen, oldlen;
   gftp_file * tempfle;
@@ -142,40 +142,32 @@
         continue;
 
       oldlen = totlen;
+      df = gftp_build_path (wdata->request->directory, tempfle->file, NULL);
+
       if (wdata->request->hostname == NULL || 
           wdata->request->protonum == GFTP_LOCAL_NUM)
         {
-          tempstr = g_strdup_printf ("%s://%s/%s ", 
-                                 wdata->request->url_prefix,
-                                 wdata->request->directory, 
-                                 tempfle->file);
+          tempstr = g_strdup_printf ("%s://%s ", 
+                                 wdata->request->url_prefix, df);
         }
-      else if (wdata->request->username == NULL 
-               || *wdata->request->username == '\0')
+      else if (wdata->request->username == NULL || 
+               *wdata->request->username == '\0')
         {
-          tempstr = g_strdup_printf ("%s://%s:%d%s/%s ", 
+          tempstr = g_strdup_printf ("%s://%s:%d%s ", 
                                  wdata->request->url_prefix,
                                  wdata->request->hostname,
-                                 wdata->request->port,
-                                 wdata->request->directory, 
-                                 tempfle->file);
+                                 wdata->request->port, df);
         }
       else
         {
-          tempstr = g_strdup_printf ("%s://%s@%s:%d%s/%s ", 
+          tempstr = g_strdup_printf ("%s://%s@%s:%d%s ", 
                                  wdata->request->url_prefix,
                                  wdata->request->username, 
                                  wdata->request->hostname,
-                                 wdata->request->port,
-                                 wdata->request->directory, 
-                                 tempfle->file);
+                                 wdata->request->port, df);
         }
 
-      if ((pos = strchr (tempstr, ':')) != NULL)
-        pos += 3;
-      else
-        pos = tempstr;
-      remove_double_slashes (pos);
+      g_free (df);
 
       /* Note, I am allocating memory for this byte above. Note the extra space
          at the end of the g_strdup_printf() format argument */