aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-05-04 22:54:35 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-05-05 00:00:40 +0200
commitb18c9f1eb024abd239c16636f1ef3a9a02d6f262 (patch)
tree62ccfc72f335c7280cabda83110dce4b5b4659fc
parentfe5c5bccce4afa5d70306151c3d9e76f68157b66 (diff)
downloadffmpeg-b18c9f1eb024abd239c16636f1ef3a9a02d6f262.tar.gz
oggtheora: Port changes from oggvorbis timestamp handling.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavformat/oggparsetheora.c29
1 files changed, 12 insertions, 17 deletions
diff --git a/libavformat/oggparsetheora.c b/libavformat/oggparsetheora.c
index 3b7e853bb4..d646efcbfc 100644
--- a/libavformat/oggparsetheora.c
+++ b/libavformat/oggparsetheora.c
@@ -162,26 +162,21 @@ static int theora_packet(AVFormatContext *s, int idx)
the total duration to the page granule to find the encoder delay and
set the first timestamp */
- if (!os->lastpts) {
+ if ((!os->lastpts || os->lastpts == AV_NOPTS_VALUE) && !(os->flags & OGG_FLAG_EOS)) {
int seg;
- uint8_t *last_pkt = os->buf + os->pstart;
- uint8_t *next_pkt = last_pkt;
- int first_duration = 0;
-
- duration = 0;
- for (seg = 0; seg < os->nsegs; seg++) {
- if (os->segments[seg] < 255) {
- if (!duration)
- first_duration = 1;
- duration++;
- last_pkt = next_pkt + os->segments[seg];
- }
- next_pkt += os->segments[seg];
+
+ duration = 1;
+ for (seg = os->segp; seg < os->nsegs; seg++) {
+ if (os->segments[seg] < 255)
+ duration ++;
}
+
os->lastpts = os->lastdts = theora_gptopts(s, idx, os->granule, NULL) - duration;
- s->streams[idx]->start_time = os->lastpts + first_duration;
- if (s->streams[idx]->duration)
- s->streams[idx]->duration -= s->streams[idx]->start_time;
+ if(s->streams[idx]->start_time == AV_NOPTS_VALUE) {
+ s->streams[idx]->start_time = os->lastpts;
+ if (s->streams[idx]->duration)
+ s->streams[idx]->duration -= s->streams[idx]->start_time;
+ }
}
/* parse packet duration */