+2004-02-15 Julien MOUTTE <julien@moutte.net>
+
+ * examples/gstplay/player.c: (got_eos), (main): Adding some
+ output for debugging.
+ * gst-libs/gst/play/play.c: (gst_play_state_change): Stop our
+ timeouts if we go to any state different from PLAYING.
+ * gst-libs/gst/riff/riff-read.c: (gst_riff_read_seek): Fix some
+ more EOS bugs in riff lib.
+
2004-02-14 Julien MOUTTE <julien@moutte.net>
* gst-libs/gst/play/play.c: (gst_play_connect_visualization): Disable
static void
got_eos (GstPlay *play)
{
+ g_print ("End Of Stream\n");
g_main_loop_quit (loop);
}
g_main_loop_run (loop);
+ g_print ("setting pipeline to ready\n");
+
gst_element_set_state (GST_ELEMENT (play), GST_STATE_READY);
- /* unref */
- gst_object_unref (GST_OBJECT (play));
+ /* unref
+ gst_object_unref (GST_OBJECT (play)); */
exit (0);
}
(GSourceFunc) gst_play_get_length_callback,
play);
}
+ else {
+ if (play->priv->tick_id) {
+ g_source_remove (play->priv->tick_id);
+ play->priv->tick_id = 0;
+ }
+ if (play->priv->length_id) {
+ g_source_remove (play->priv->length_id);
+ play->priv->length_id = 0;
+ }
+ }
if (GST_ELEMENT_CLASS (parent_class)->state_change)
GST_ELEMENT_CLASS (parent_class)->state_change (element, old, state);
break;
} else if (GST_EVENT_TYPE (event) != GST_EVENT_DISCONTINUOUS) {
gst_pad_event_default (riff->sinkpad, event);
+ if (GST_EVENT_TYPE (event) == GST_EVENT_EOS)
+ return NULL;
event = NULL;
}
}
static void
got_eos (GstPlay *play)
{
+ g_print ("End Of Stream\n");
g_main_loop_quit (loop);
}
g_main_loop_run (loop);
+ g_print ("setting pipeline to ready\n");
+
gst_element_set_state (GST_ELEMENT (play), GST_STATE_READY);
- /* unref */
- gst_object_unref (GST_OBJECT (play));
+ /* unref
+ gst_object_unref (GST_OBJECT (play)); */
exit (0);
}