leak: don't return without calling va_end
authorStefan Kost <ensonic@users.sf.net>
Wed, 4 Feb 2009 13:41:24 +0000 (15:41 +0200)
committerStefan Kost <ensonic@users.sf.net>
Wed, 4 Feb 2009 13:41:24 +0000 (15:41 +0200)
gst/gstutils.c

index 866f77881b342ca9d01176181babd6a197d60d8c..7c02f2ad162534668a08dc268a363b5df47cde16 100644 (file)
@@ -997,13 +997,11 @@ gst_element_get_compatible_pad (GstElement * element, GstPad * pad,
             gst_iterator_free (pads);
 
             return current;
-          }
-          else {
+          } else {
             GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "incompatible pads");
           }
           gst_caps_unref (intersection);
-        }
-        else {
+        } else {
           GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,
               "already linked or cannot be linked (peer = %p)", peer);
         }
@@ -1767,6 +1765,7 @@ gst_element_link (GstElement * src, GstElement * dest)
 gboolean
 gst_element_link_many (GstElement * element_1, GstElement * element_2, ...)
 {
+  gboolean res = TRUE;
   va_list args;
 
   g_return_val_if_fail (GST_IS_ELEMENT (element_1), FALSE);
@@ -1775,8 +1774,10 @@ gst_element_link_many (GstElement * element_1, GstElement * element_2, ...)
   va_start (args, element_2);
 
   while (element_2) {
-    if (!gst_element_link (element_1, element_2))
-      return FALSE;
+    if (!gst_element_link (element_1, element_2)) {
+      res = FALSE;
+      break;
+    }
 
     element_1 = element_2;
     element_2 = va_arg (args, GstElement *);
@@ -1784,7 +1785,7 @@ gst_element_link_many (GstElement * element_1, GstElement * element_2, ...)
 
   va_end (args);
 
-  return TRUE;
+  return res;
 }
 
 /**