dbus_message_append_args_valist - abandon container
authorScott James Remnant <scott@ubuntu.com>
Thu, 9 Jul 2009 15:35:13 +0000 (16:35 +0100)
committerColin Walters <walters@verbum.org>
Tue, 14 Jul 2009 19:39:19 +0000 (15:39 -0400)
In case of OOM when constructing an array, we should abandon the
container to free the resources.

Signed-off-by: Scott James Remnant <scott@ubuntu.com>
(cherry picked from commit 3f070088232f82fafce97c4fb3015da098fe00bf)

dbus/dbus-message.c

index 30b5d6c0b436bf23843f1e49b6f7a4e3a540b539..98c284ed111d12332962a80a5474447ff1c09e55 100644 (file)
@@ -1567,8 +1567,10 @@ dbus_message_append_args_valist (DBusMessage *message,
               if (!dbus_message_iter_append_fixed_array (&array,
                                                          element_type,
                                                          value,
-                                                         n_elements))
+                                                         n_elements)) {
+                dbus_message_iter_abandon_container (&iter, &array);
                 goto failed;
+              }
             }
           else if (element_type == DBUS_TYPE_STRING ||
                    element_type == DBUS_TYPE_SIGNATURE ||
@@ -1589,8 +1591,10 @@ dbus_message_append_args_valist (DBusMessage *message,
                 {
                   if (!dbus_message_iter_append_basic (&array,
                                                        element_type,
-                                                       &value[i]))
+                                                       &value[i])) {
+                    dbus_message_iter_abandon_container (&iter, &array);
                     goto failed;
+                  }
                   ++i;
                 }
             }