summaryrefslogtreecommitdiff
path: root/daemon/gvfsbackendftp.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@gnome.org>2009-05-26 13:22:10 +0200
committerBenjamin Otte <otte@gnome.org>2009-05-26 13:25:11 +0200
commit7a86c013a21741d61154969872bf8e1cfd1165e6 (patch)
treea28a39195d74380c280b4dea303cbc65c929e89a /daemon/gvfsbackendftp.c
parent4b9af0f85c49d243febddff1f2bdf2409bed9cec (diff)
downloadgvfs-7a86c013a21741d61154969872bf8e1cfd1165e6.tar.gz
[FTP] rework creating the root file info
There is no need to make the root file info backend specific, as it just returns a bunch of default values anyway. Also, we want to use the host display name in there.
Diffstat (limited to 'daemon/gvfsbackendftp.c')
-rw-r--r--daemon/gvfsbackendftp.c57
1 files changed, 27 insertions, 30 deletions
diff --git a/daemon/gvfsbackendftp.c b/daemon/gvfsbackendftp.c
index 18ee5783..63922ee7 100644
--- a/daemon/gvfsbackendftp.c
+++ b/daemon/gvfsbackendftp.c
@@ -90,7 +90,6 @@ typedef struct FtpDirReader FtpDirReader;
struct FtpDirReader {
void (* init_data) (FtpConnection *conn,
const FtpFile *dir);
- GFileInfo * (* get_root) (FtpConnection *conn);
gpointer (* iter_new) (FtpConnection *conn);
GFileInfo * (* iter_process)(gpointer iter,
FtpConnection *conn,
@@ -1114,33 +1113,6 @@ dir_default_init_data (FtpConnection *conn, const FtpFile *dir)
(conn->system == FTP_SYSTEM_UNIX) ? "LIST -a" : "LIST");
}
-static GFileInfo *
-dir_default_get_root (FtpConnection *conn)
-{
- GFileInfo *info;
- GIcon *icon;
- char *display_name;
-
- info = g_file_info_new ();
- g_file_info_set_file_type (info, G_FILE_TYPE_DIRECTORY);
-
- g_file_info_set_name (info, "/");
- display_name = g_strdup_printf (_("/ on %s"),
- soup_address_get_name (soup_socket_get_remote_address (conn->commands)));
- g_file_info_set_display_name (info, display_name);
- g_free (display_name);
- g_file_info_set_edit_name (info, "/");
-
- g_file_info_set_content_type (info, "inode/directory");
- g_file_info_set_attribute_string (info, G_FILE_ATTRIBUTE_STANDARD_FAST_CONTENT_TYPE, "inode/directory");
-
- icon = g_themed_icon_new ("folder-remote");
- g_file_info_set_icon (info, icon);
- g_object_unref (icon);
-
- return info;
-}
-
static gpointer
dir_default_iter_new (FtpConnection *conn)
{
@@ -1283,7 +1255,6 @@ dir_default_iter_free (gpointer iter)
static const FtpDirReader dir_default = {
dir_default_init_data,
- dir_default_get_root,
dir_default_iter_new,
dir_default_iter_process,
dir_default_iter_free
@@ -2050,6 +2021,32 @@ do_write (GVfsBackend *backend,
ftp_connection_pop_job (conn);
}
+static GFileInfo *
+create_file_info_for_root (GVfsBackendFtp *ftp)
+{
+ GFileInfo *info;
+ GIcon *icon;
+ char *display_name;
+
+ info = g_file_info_new ();
+ g_file_info_set_file_type (info, G_FILE_TYPE_DIRECTORY);
+
+ g_file_info_set_name (info, "/");
+ display_name = g_strdup_printf (_("/ on %s"), ftp->host_display_name);
+ g_file_info_set_display_name (info, display_name);
+ g_free (display_name);
+ g_file_info_set_edit_name (info, "/");
+
+ g_file_info_set_content_type (info, "inode/directory");
+ g_file_info_set_attribute_string (info, G_FILE_ATTRIBUTE_STANDARD_FAST_CONTENT_TYPE, "inode/directory");
+
+ icon = g_themed_icon_new ("folder-remote");
+ g_file_info_set_icon (info, icon);
+ g_object_unref (icon);
+
+ return info;
+}
+
static FtpDirEntry *
do_enumerate_directory (FtpConnection *conn)
{
@@ -2249,7 +2246,7 @@ create_file_info (GVfsBackendFtp *ftp, FtpConnection *conn, const char *filename
*symlink = NULL;
if (g_str_equal (filename, "/"))
- return ftp->dir_ops->get_root (conn);
+ return create_file_info_for_root (ftp);
dirname = g_path_get_dirname (filename);
dir = ftp_filename_from_gvfs_path (conn, dirname);