basesrc: Fix seamless segment function

The 3rd parameter of gst_base_src_new_seamless_segment in
0.10 is the time associated with the start of the new segment,
not the position in the new segment. Fix the name of the parameter,
the docs, and the implementation to match the needs of the only
extant consumer: DVD playback.
This commit is contained in:
Jan Schmidt 2012-09-30 04:05:36 +10:00
parent 507fc9cea7
commit 906738ab49

View file

@ -781,7 +781,7 @@ gst_base_src_get_do_timestamp (GstBaseSrc * src)
* @src: The source * @src: The source
* @start: The new start value for the segment * @start: The new start value for the segment
* @stop: Stop value for the new segment * @stop: Stop value for the new segment
* @position: The position value for the new segent * @time: The new time value for the start of the new segent
* *
* Prepare a new seamless segment for emission downstream. This function must * Prepare a new seamless segment for emission downstream. This function must
* only be called by derived sub-classes, and only from the create() function, * only be called by derived sub-classes, and only from the create() function,
@ -794,25 +794,27 @@ gst_base_src_get_do_timestamp (GstBaseSrc * src)
*/ */
gboolean gboolean
gst_base_src_new_seamless_segment (GstBaseSrc * src, gint64 start, gint64 stop, gst_base_src_new_seamless_segment (GstBaseSrc * src, gint64 start, gint64 stop,
gint64 position) gint64 time)
{ {
gboolean res = TRUE; gboolean res = TRUE;
GST_DEBUG_OBJECT (src,
"Starting new seamless segment. Start %" GST_TIME_FORMAT " stop %"
GST_TIME_FORMAT " position %" GST_TIME_FORMAT, GST_TIME_ARGS (start),
GST_TIME_ARGS (stop), GST_TIME_ARGS (position));
GST_OBJECT_LOCK (src); GST_OBJECT_LOCK (src);
src->segment.base = gst_segment_to_running_time (&src->segment, src->segment.base = gst_segment_to_running_time (&src->segment,
src->segment.format, src->segment.position); src->segment.format, src->segment.position);
src->segment.start = start; src->segment.position = src->segment.start = start;
src->segment.stop = stop; src->segment.stop = stop;
src->segment.position = position; src->segment.time = time;
/* forward, we send data from position to stop */ /* Mark pending segment. Will be sent before next data */
src->priv->segment_pending = TRUE; src->priv->segment_pending = TRUE;
GST_DEBUG_OBJECT (src,
"Starting new seamless segment. Start %" GST_TIME_FORMAT " stop %"
GST_TIME_FORMAT " time %" GST_TIME_FORMAT " base %" GST_TIME_FORMAT,
GST_TIME_ARGS (start), GST_TIME_ARGS (stop), GST_TIME_ARGS (time),
GST_TIME_ARGS (src->segment.base));
GST_OBJECT_UNLOCK (src); GST_OBJECT_UNLOCK (src);
src->priv->discont = TRUE; src->priv->discont = TRUE;