summaryrefslogtreecommitdiff
path: root/libavformat/srtdec.c
diff options
context:
space:
mode:
authorPhilip Langdale <philipl@overt.org>2012-06-02 16:15:38 -0700
committerPhilip Langdale <philipl@overt.org>2012-08-04 12:01:24 -0700
commit7b24be557fda34a1dc7e67d6c9f835cc4103e07e (patch)
treef5bfaca26767a7946c7e834addfb453ffa95a714 /libavformat/srtdec.c
parent18175ca9b2d9dc3b66e63b3cc461dfde788943a0 (diff)
avformat/srtdec: Write duration into packet from srt demuxer.
The current demuxer does not bother to write packet durations, which makes it impossible to remux into a new format. Signed-off-by: Philip Langdale <philipl@overt.org>
Diffstat (limited to 'libavformat/srtdec.c')
-rw-r--r--libavformat/srtdec.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/libavformat/srtdec.c b/libavformat/srtdec.c
index 8eba5abf9a..28b18b4b99 100644
--- a/libavformat/srtdec.c
+++ b/libavformat/srtdec.c
@@ -51,16 +51,23 @@ static int srt_read_header(AVFormatContext *s)
return 0;
}
-static int64_t get_pts(const char *buf)
+static int64_t get_pts(const char *buf, int *duration)
{
- int i, v, hour, min, sec, hsec;
+ int i, hour, min, sec, hsec;
+ int he, me, se, mse;
for (i=0; i<2; i++) {
- if (sscanf(buf, "%d:%2d:%2d%*1[,.]%3d --> %*d:%*2d:%*2d%*1[,.]%3d",
- &hour, &min, &sec, &hsec, &v) == 5) {
+ int64_t start, end;
+ if (sscanf(buf, "%d:%2d:%2d%*1[,.]%3d --> %d:%2d:%2d%*1[,.]%3d",
+ &hour, &min, &sec, &hsec, &he, &me, &se, &mse) == 8) {
min += 60*hour;
sec += 60*min;
- return sec*1000+hsec;
+ start = sec*1000+hsec;
+ me += 60*he;
+ se += 60*me;
+ end = se*1000+mse;
+ *duration = end - start;
+ return start;
}
buf += strcspn(buf, "\n") + 1;
}
@@ -87,7 +94,7 @@ static int srt_read_packet(AVFormatContext *s, AVPacket *pkt)
memcpy(pkt->data, buffer, pkt->size);
pkt->flags |= AV_PKT_FLAG_KEY;
pkt->pos = pos;
- pkt->pts = pkt->dts = get_pts(pkt->data);
+ pkt->pts = pkt->dts = get_pts(pkt->data, &(pkt->duration));
}
return res;
}