]> Pileus Git - ~andy/gtk/commitdiff
filechooserentry: Ensure the base folder is always valid
authorBenjamin Otte <otte@redhat.com>
Sat, 5 Nov 2011 01:31:04 +0000 (02:31 +0100)
committerBenjamin Otte <otte@redhat.com>
Fri, 16 Dec 2011 19:09:12 +0000 (20:09 +0100)
If the base folder is set to NULL, then we just assume the home dir.
FIXME: Should we disallow a NULL folder?

gtk/gtkfilechooserentry.c

index 4e0ff8c898917a1a4fa553d023c6c33cfe2dbd91..d603569a9bdd4792c3c265d92dc6760fa3ab5128 100644 (file)
@@ -199,6 +199,7 @@ _gtk_file_chooser_entry_init (GtkFileChooserEntry *chooser_entry)
   GtkCellRenderer *cell;
 
   chooser_entry->local_only = TRUE;
+  chooser_entry->base_folder = g_file_new_for_path (g_get_home_dir ());
 
   g_object_set (chooser_entry, "truncate-multiline", TRUE, NULL);
 
@@ -1647,14 +1648,22 @@ void
 _gtk_file_chooser_entry_set_base_folder (GtkFileChooserEntry *chooser_entry,
                                         GFile               *file)
 {
+  if (file)
+    g_object_ref (file);
+  else
+    file = g_file_new_for_path (g_get_home_dir ());
+
+  if (g_file_equal (chooser_entry->base_folder, file))
+    {
+      g_object_unref (file);
+      return;
+    }
+
   if (chooser_entry->base_folder)
     g_object_unref (chooser_entry->base_folder);
 
   chooser_entry->base_folder = file;
 
-  if (chooser_entry->base_folder)
-    g_object_ref (chooser_entry->base_folder);
-
   clear_completions (chooser_entry);
 }