summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Vander Stichele <thomas@apestaart.org>2004-02-18 18:41:36 +0000
committerThomas Vander Stichele <thomas@apestaart.org>2004-02-18 18:41:36 +0000
commit46509e13de7b6357251f625a8fc9b7a2dbb701c6 (patch)
tree183172cd37d81abde97da0d5d858398d66de653a
parent5a8505f39a6d9154d00dd3c10b9f862a9e9bbe4a (diff)
break up link function for better error debug
Original commit message from CVS: break up link function for better error debug
-rw-r--r--ChangeLog5
-rw-r--r--gst-libs/gst/play/play.c17
2 files changed, 18 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index a50603a4..8f7e190d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
2004-02-18 Thomas Vander Stichele <thomas at apestaart dot org>
+ * gst-libs/gst/play/play.c: (gst_play_pipeline_setup):
+ break up _link so we can give a better debug message for errors
+
+2004-02-18 Thomas Vander Stichele <thomas at apestaart dot org>
+
* ext/gdk_pixbuf/gstgdkpixbuf.c: (plugin_init):
set up debug category
diff --git a/gst-libs/gst/play/play.c b/gst-libs/gst/play/play.c
index dfa73fd9..e507acb7 100644
--- a/gst-libs/gst/play/play.c
+++ b/gst-libs/gst/play/play.c
@@ -282,10 +282,19 @@ gst_play_pipeline_setup (GstPlay *play, GError **error)
gst_bin_add_many (GST_BIN (video_thread), video_queue, video_switch, video_cs,
video_balance, balance_cs, video_scaler, video_sink, NULL);
- if (!gst_element_link_many (video_queue, video_switch, video_cs,
- video_balance, balance_cs, video_scaler,
- video_sink, NULL))
- GST_PLAY_ERROR_RETURN (error, "Could not link video output thread elements");
+ /* break down linking so we can figure out what might be failing */
+ if (!gst_element_link (video_queue, video_switch))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (queue and switch)");
+ if (!gst_element_link (video_switch, video_cs))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (switch and cs)");
+ if (!gst_element_link (video_cs, video_balance))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (cs and balance)");
+ if (!gst_element_link (video_balance, balance_cs))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (balance and balance_cs)");
+ if (!gst_element_link (balance_cs, video_scaler))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (balance_cs and scaler)");
+ if (!gst_element_link (video_scaler, video_sink))
+ GST_PLAY_ERROR_RETURN (error, "Could not link video output thread (balance_cs and scaler)");
gst_element_add_ghost_pad (video_thread,
gst_element_get_pad (video_queue, "sink"),
"sink");