[FFmpeg-devel] [PATCH 1/2] lavf/microdvd: fix muxing.
Clément Bœsch
ubitux at gmail.com
Thu Feb 21 00:45:46 CET 2013
On Thu, Feb 21, 2013 at 12:33:25AM +0100, Michael Niedermayer wrote:
> On Wed, Feb 20, 2013 at 11:50:39PM +0100, Clément Bœsch wrote:
> > This was broken since 1f265f52.
> > ---
> > libavformat/Makefile | 2 +-
> > libavformat/microdvdenc.c | 22 ++++++++++++++++++++--
> > 2 files changed, 21 insertions(+), 3 deletions(-)
> >
> > diff --git a/libavformat/Makefile b/libavformat/Makefile
> > index ad70c12..0f2e5df 100644
> > --- a/libavformat/Makefile
> > +++ b/libavformat/Makefile
> > @@ -196,7 +196,7 @@ OBJS-$(CONFIG_MATROSKA_MUXER) += matroskaenc.o matroska.o \
> > OBJS-$(CONFIG_MD5_MUXER) += md5enc.o
> > OBJS-$(CONFIG_MGSTS_DEMUXER) += mgsts.o
> > OBJS-$(CONFIG_MICRODVD_DEMUXER) += microdvddec.o
> > -OBJS-$(CONFIG_MICRODVD_MUXER) += microdvdenc.o rawenc.o
> > +OBJS-$(CONFIG_MICRODVD_MUXER) += microdvdenc.o
> > OBJS-$(CONFIG_MJPEG_DEMUXER) += rawdec.o
> > OBJS-$(CONFIG_MJPEG_MUXER) += rawenc.o
> > OBJS-$(CONFIG_MLP_DEMUXER) += rawdec.o
> > diff --git a/libavformat/microdvdenc.c b/libavformat/microdvdenc.c
> > index ba97444..db1024e 100644
> > --- a/libavformat/microdvdenc.c
> > +++ b/libavformat/microdvdenc.c
> > @@ -19,8 +19,8 @@
> > * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
> > */
> >
> > +#include <inttypes.h>
> > #include "avformat.h"
> > -#include "rawenc.h"
> >
> > static int microdvd_write_header(struct AVFormatContext *s)
> > {
> > @@ -39,13 +39,31 @@ static int microdvd_write_header(struct AVFormatContext *s)
> > return 0;
> > }
> >
> > +static int microdvd_write_packet(AVFormatContext *avf, AVPacket *pkt)
> > +{
> > + AVRational tb = avf->streams[0]->time_base;
> > + AVRational tbc = avf->streams[0]->codec->time_base;
> > +
> > + avio_printf(avf->pb, "{%"PRId64"}", av_rescale_q(pkt->pts, tb, tbc));
>
> a set_pts_info() in write_header() should avoid the rescale unless i
> misunderstand the intent
>
I didn't know you could do that. That simplifies things indeed, thanks.
New patch attached.
--
Clément B.
-------------- next part --------------
From 342ef0f79f872b5208090a317ae05e9968ff7e9f Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Cl=C3=A9ment=20B=C5=93sch?= <ubitux at gmail.com>
Date: Wed, 20 Feb 2013 23:43:25 +0100
Subject: [PATCH 1/2] lavf/microdvd: fix muxing.
This was broken since 1f265f52.
---
libavformat/Makefile | 2 +-
libavformat/microdvdenc.c | 21 +++++++++++++++++++--
2 files changed, 20 insertions(+), 3 deletions(-)
diff --git a/libavformat/Makefile b/libavformat/Makefile
index ad70c12..0f2e5df 100644
--- a/libavformat/Makefile
+++ b/libavformat/Makefile
@@ -196,7 +196,7 @@ OBJS-$(CONFIG_MATROSKA_MUXER) += matroskaenc.o matroska.o \
OBJS-$(CONFIG_MD5_MUXER) += md5enc.o
OBJS-$(CONFIG_MGSTS_DEMUXER) += mgsts.o
OBJS-$(CONFIG_MICRODVD_DEMUXER) += microdvddec.o
-OBJS-$(CONFIG_MICRODVD_MUXER) += microdvdenc.o rawenc.o
+OBJS-$(CONFIG_MICRODVD_MUXER) += microdvdenc.o
OBJS-$(CONFIG_MJPEG_DEMUXER) += rawdec.o
OBJS-$(CONFIG_MJPEG_MUXER) += rawenc.o
OBJS-$(CONFIG_MLP_DEMUXER) += rawdec.o
diff --git a/libavformat/microdvdenc.c b/libavformat/microdvdenc.c
index ba97444..30fd0ea 100644
--- a/libavformat/microdvdenc.c
+++ b/libavformat/microdvdenc.c
@@ -19,12 +19,14 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
+#include <inttypes.h>
#include "avformat.h"
-#include "rawenc.h"
+#include "internal.h"
static int microdvd_write_header(struct AVFormatContext *s)
{
AVCodecContext *avctx = s->streams[0]->codec;
+ AVRational tb = avctx->time_base;
if (s->nb_streams != 1 || avctx->codec_id != AV_CODEC_ID_MICRODVD) {
av_log(s, AV_LOG_ERROR, "Exactly one MicroDVD stream is needed.\n");
@@ -36,6 +38,21 @@ static int microdvd_write_header(struct AVFormatContext *s)
avio_write(s->pb, avctx->extradata, avctx->extradata_size);
avio_flush(s->pb);
}
+
+ avpriv_set_pts_info(s->streams[0], 64, tb.num, tb.den);
+ return 0;
+}
+
+static int microdvd_write_packet(AVFormatContext *avf, AVPacket *pkt)
+{
+ avio_printf(avf->pb, "{%"PRId64"}", pkt->pts);
+ if (pkt->duration < 0)
+ avio_write(avf->pb, "{}", 2);
+ else
+ avio_printf(avf->pb, "{%"PRId64"}", pkt->pts + pkt->duration);
+ avio_write(avf->pb, pkt->data, pkt->size);
+ avio_write(avf->pb, "\n", 1);
+ avio_flush(avf->pb);
return 0;
}
@@ -45,7 +62,7 @@ AVOutputFormat ff_microdvd_muxer = {
.mime_type = "text/x-microdvd",
.extensions = "sub",
.write_header = microdvd_write_header,
- .write_packet = ff_raw_write_packet,
+ .write_packet = microdvd_write_packet,
.flags = AVFMT_NOTIMESTAMPS,
.subtitle_codec = AV_CODEC_ID_MICRODVD,
};
--
1.8.1.4
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 490 bytes
Desc: not available
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20130221/2d699a4c/attachment.asc>
More information about the ffmpeg-devel
mailing list