gstobject: Replace recursive gst_object_has_ancestor() with an iterative version

This is slightly more efficient because the compiler can't do tail
recursion here and has to keep all stack frames.

Not that efficiency is that important here but I already had
the iterative version somewhere else and both are easy to read.
This commit is contained in:
Sebastian Dröge 2009-10-14 08:30:07 +02:00
parent 4917bb4fc2
commit b8454d623d

View file

@ -883,21 +883,24 @@ gst_object_unparent (GstObject * object)
gboolean gboolean
gst_object_has_ancestor (GstObject * object, GstObject * ancestor) gst_object_has_ancestor (GstObject * object, GstObject * ancestor)
{ {
GstObject *parent; GstObject *parent, *tmp;
gboolean result = FALSE;
if (object == NULL) if (!ancestor || !object)
return FALSE; return FALSE;
if (object == ancestor) parent = gst_object_ref (object);
return TRUE; do {
if (parent == ancestor) {
parent = gst_object_get_parent (object);
result = gst_object_has_ancestor (parent, ancestor);
if (parent)
gst_object_unref (parent); gst_object_unref (parent);
return TRUE;
}
return result; tmp = gst_object_get_parent (parent);
gst_object_unref (parent);
parent = tmp;
} while (parent);
return FALSE;
} }
/** /**