From 56fbcb676602fb5b13104cb9d9439be22c2e2e0d Mon Sep 17 00:00:00 2001 From: Jan Schmidt Date: Mon, 12 Mar 2007 17:24:23 +0000 Subject: [PATCH] gst/id3demux/gstid3demux.c: Fix handling of -1 values for start and stop values when seeking, and SEEK_CUR+SEEK_END. Original commit message from CVS: * gst/id3demux/gstid3demux.c: (gst_id3demux_srcpad_event): Fix handling of -1 values for start and stop values when seeking, and SEEK_CUR+SEEK_END. --- ChangeLog | 6 ++++++ gst/id3demux/gstid3demux.c | 17 ++++++++++++++--- 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6dfd21a51d..3e66d66162 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2007-03-12 Jan Schmidt + + * gst/id3demux/gstid3demux.c: (gst_id3demux_srcpad_event): + Fix handling of -1 values for start and stop values when seeking, + and SEEK_CUR+SEEK_END. + 2007-03-12 Tim-Philipp Müller * gst/id3demux/id3v2frames.c: (parse_picture_frame): diff --git a/gst/id3demux/gstid3demux.c b/gst/id3demux/gstid3demux.c index 886264f6e0..6fec9dbdbc 100644 --- a/gst/id3demux/gstid3demux.c +++ b/gst/id3demux/gstid3demux.c @@ -672,12 +672,17 @@ gst_id3demux_srcpad_event (GstPad * pad, GstEvent * event) switch (cur_type) { case GST_SEEK_TYPE_SET: + if (cur == -1) + cur = 0; cur += id3demux->strip_start; break; case GST_SEEK_TYPE_CUR: break; case GST_SEEK_TYPE_END: - cur += id3demux->strip_end; + /* Adjust the seek to be relative to the start of any ID3v1 tag */ + if (cur > 0) + cur = 0; + cur -= id3demux->strip_end; break; default: g_assert_not_reached (); @@ -685,12 +690,18 @@ gst_id3demux_srcpad_event (GstPad * pad, GstEvent * event) } switch (stop_type) { case GST_SEEK_TYPE_SET: - stop += id3demux->strip_start; + if (stop != -1) { + /* -1 means the end of the file, pass it upstream intact */ + stop += id3demux->strip_start; + } break; case GST_SEEK_TYPE_CUR: break; case GST_SEEK_TYPE_END: - stop += id3demux->strip_end; + /* Adjust the seek to be relative to the start of any ID3v1 tag */ + if (stop > 0) + stop = 0; + stop -= id3demux->strip_end; break; default: break;