pending = GST_STATE_PENDING (element);
transition = GST_STATE_TRANSITION (element);
- GST_INFO_ELEMENT (GST_CAT_STATES, element, "changing childrens' state from %s to %s",
- gst_element_state_get_name (old_state), gst_element_state_get_name (pending));
+ GST_INFO_ELEMENT (GST_CAT_STATES, element,
+ "changing childrens' state from %s to %s",
+ gst_element_state_get_name (old_state),
+ gst_element_state_get_name (pending));
if (pending == GST_STATE_VOID_PENDING)
return GST_STATE_SUCCESS;
+ if (old_state == pending)
+ {
+ GST_INFO_ELEMENT (GST_CAT_STATES, element,
+ "old and pending state are both %s, returning",
+ gst_element_state_get_name (pending));
+ return GST_STATE_SUCCESS;
+ }
+
children = bin->children;
while (children) {
if (GST_ELEMENT_SCHED (child) == GST_ELEMENT_SCHED (element)) {
/* try to reset it to what is was */
GST_STATE_PENDING (element) = old_state;
- gst_bin_change_state (element);
return GST_STATE_FAILURE;
}
/* start with the current state */
curpending = GST_STATE(element);
+ if (state == curpending)
+ {
+ GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
+ "element is already in requested state %s",
+ gst_element_state_get_name (state));
+ return (GST_STATE_SUCCESS);
+ }
+
GST_DEBUG_ELEMENT (GST_CAT_STATES, element, "setting state from %s to %s",
gst_element_state_get_name (curpending),
gst_element_state_get_name (state));
GstRealPad *peer;
GstData *data = GST_DATA(buf);
+ g_assert (GST_IS_PAD (pad));
GST_DEBUG_ENTER ("(%s:%s)", GST_DEBUG_PAD_NAME (pad));
g_return_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SRC);