g_file_make_directory_with_parents: Fix error propagation
authorOwen W. Taylor <otaylor@fishsoup.net>
Mon, 30 Jul 2012 11:33:05 +0000 (13:33 +0200)
committerOwen W. Taylor <otaylor@fishsoup.net>
Mon, 30 Jul 2012 16:29:26 +0000 (18:29 +0200)
When creating a directory fails for some reason other than
the parent not existing, don't clear the error before we try
to propagate it.

To reproduce, run 'ostadmin init' on /ostree or otherwise try to
run the function on a directory with a parent directory where the
current user is not allowed to write.

https://bugzilla.gnome.org/show_bug.cgi?id=680823

gio/gfile.c

index f664875..3bdae74 100644 (file)
@@ -3395,12 +3395,14 @@ g_file_make_directory_with_parents (GFile         *file,
       work_file = g_object_ref (parent_file);
 
       if (!result && my_error->code == G_IO_ERROR_NOT_FOUND)
-        list = g_list_prepend (list, parent_file);  /* Transfer ownership of ref */
+        {
+          g_clear_error (&my_error);
+          list = g_list_prepend (list, parent_file);  /* Transfer ownership of ref */
+        }
       else
         g_object_unref (parent_file);
     }
 
-  g_clear_error (&my_error);
   for (l = list; result && l; l = l->next)
     {
       result = g_file_make_directory ((GFile *) l->data, cancellable, &my_error);