gtk+ r21839 - in branches/gtk-2-14: . gtk
- From: matthiasc svn gnome org
- To: svn-commits-list gnome org
- Subject: gtk+ r21839 - in branches/gtk-2-14: . gtk
- Date: Mon, 1 Dec 2008 05:44:12 +0000 (UTC)
Author: matthiasc
Date: Mon Dec 1 05:44:12 2008
New Revision: 21839
URL: http://svn.gnome.org/viewvc/gtk+?rev=21839&view=rev
Log:
* gtk/gtkfilesystem.c (get_volumes_list): Filter out shadow mounts.
Patch by David Zeuthen.
Modified:
branches/gtk-2-14/ChangeLog
branches/gtk-2-14/gtk/gtkfilesystem.c
Modified: branches/gtk-2-14/gtk/gtkfilesystem.c
==============================================================================
--- branches/gtk-2-14/gtk/gtkfilesystem.c (original)
+++ branches/gtk-2-14/gtk/gtkfilesystem.c Mon Dec 1 05:44:12 2008
@@ -362,6 +362,39 @@
}
}
+static gboolean
+mount_referenced_by_volume_activation_root (GList *volumes, GMount *mount)
+{
+ GList *l;
+ GFile *mount_root;
+ gboolean ret;
+
+ ret = FALSE;
+
+ mount_root = g_mount_get_root (mount);
+
+ for (l = volumes; l != NULL; l = l->next)
+ {
+ GVolume *volume = G_VOLUME (l->data);
+ GFile *volume_activation_root;
+
+ volume_activation_root = g_volume_get_activation_root (volume);
+ if (volume_activation_root != NULL)
+ {
+ if (g_file_has_prefix (volume_activation_root, mount_root))
+ {
+ ret = TRUE;
+ g_object_unref (volume_activation_root);
+ break;
+ }
+ g_object_unref (volume_activation_root);
+ }
+ }
+
+ g_object_unref (mount_root);
+ return ret;
+}
+
static void
get_volumes_list (GtkFileSystem *file_system)
{
@@ -468,8 +501,6 @@
}
}
- g_list_free (volumes);
-
/* add mounts that has no volume (/etc/mtab mounts, ftp, sftp,...) */
mounts = g_volume_monitor_get_mounts (priv->volume_monitor);
@@ -484,10 +515,20 @@
continue;
}
+ /* if there's exists one or more volumes with an activation root inside the mount,
+ * don't display the mount
+ */
+ if (mount_referenced_by_volume_activation_root (volumes, mount))
+ {
+ continue;
+ }
+
/* show this mount */
priv->volumes = g_slist_prepend (priv->volumes, g_object_ref (mount));
}
+ g_list_free (volumes);
+
g_list_free (mounts);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]