diff options
author | Clément Bœsch <ubitux@gmail.com> | 2012-12-27 14:49:33 +0100 |
---|---|---|
committer | Clément Bœsch <ubitux@gmail.com> | 2012-12-30 22:37:25 +0100 |
commit | 5f02844c8d4fc93972932a84f0a5cbb02fe12a00 (patch) | |
tree | ed243e820b345c9591b78db8dbe8a4616371d8c4 /libavcodec | |
parent | 2d3305e4f41f2c3fdf22e729d4ec753fb885a8f1 (diff) | |
download | ffmpeg-5f02844c8d4fc93972932a84f0a5cbb02fe12a00.tar.gz |
Add MPL2 subtitles demuxer and decoder.
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/Makefile | 1 | ||||
-rw-r--r-- | libavcodec/allcodecs.c | 1 | ||||
-rw-r--r-- | libavcodec/avcodec.h | 1 | ||||
-rw-r--r-- | libavcodec/codec_desc.c | 6 | ||||
-rw-r--r-- | libavcodec/mpl2dec.c | 96 | ||||
-rw-r--r-- | libavcodec/version.h | 2 |
6 files changed, 106 insertions, 1 deletions
diff --git a/libavcodec/Makefile b/libavcodec/Makefile index 59d62a82de..00e9f02d8f 100644 --- a/libavcodec/Makefile +++ b/libavcodec/Makefile @@ -292,6 +292,7 @@ OBJS-$(CONFIG_MPEG2VIDEO_DECODER) += mpeg12.o mpeg12data.o OBJS-$(CONFIG_MPEG2VIDEO_ENCODER) += mpeg12enc.o mpeg12.o \ timecode.o OBJS-$(CONFIG_MPEG4_VAAPI_HWACCEL) += vaapi_mpeg4.o +OBJS-$(CONFIG_MPL2_DECODER) += mpl2dec.o ass.o OBJS-$(CONFIG_MSMPEG4V1_DECODER) += msmpeg4.o msmpeg4data.o OBJS-$(CONFIG_MSMPEG4V2_DECODER) += msmpeg4.o msmpeg4data.o h263dec.o \ h263.o ituh263dec.o mpeg4videodec.o diff --git a/libavcodec/allcodecs.c b/libavcodec/allcodecs.c index 15106f3653..1194a744a4 100644 --- a/libavcodec/allcodecs.c +++ b/libavcodec/allcodecs.c @@ -448,6 +448,7 @@ void avcodec_register_all(void) REGISTER_DECODER(JACOSUB, jacosub); REGISTER_DECODER(MICRODVD, microdvd); REGISTER_ENCDEC (MOVTEXT, movtext); + REGISTER_DECODER(MPL2, mpl2); REGISTER_DECODER(PGSSUB, pgssub); REGISTER_DECODER(REALTEXT, realtext); REGISTER_DECODER(SAMI, sami); diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h index b475b27e27..69edcc9b48 100644 --- a/libavcodec/avcodec.h +++ b/libavcodec/avcodec.h @@ -466,6 +466,7 @@ enum AVCodecID { AV_CODEC_ID_SUBVIEWER = MKBETAG('S','u','b','V'), AV_CODEC_ID_SUBRIP = MKBETAG('S','R','i','p'), AV_CODEC_ID_WEBVTT = MKBETAG('W','V','T','T'), + AV_CODEC_ID_MPL2 = MKBETAG('M','P','L','2'), /* other specific kind of codecs (generally used for attachments) */ AV_CODEC_ID_FIRST_UNKNOWN = 0x18000, ///< A dummy ID pointing at the start of various fake codecs. diff --git a/libavcodec/codec_desc.c b/libavcodec/codec_desc.c index 27544f1a04..8de4be107e 100644 --- a/libavcodec/codec_desc.c +++ b/libavcodec/codec_desc.c @@ -2405,6 +2405,12 @@ static const AVCodecDescriptor codec_descriptors[] = { .long_name = NULL_IF_CONFIG_SMALL("MicroDVD subtitle"), }, { + .id = AV_CODEC_ID_MPL2, + .type = AVMEDIA_TYPE_SUBTITLE, + .name = "mpl2", + .long_name = NULL_IF_CONFIG_SMALL("MPL2 subtitle"), + }, + { .id = AV_CODEC_ID_EIA_608, .type = AVMEDIA_TYPE_SUBTITLE, .name = "eia_608", diff --git a/libavcodec/mpl2dec.c b/libavcodec/mpl2dec.c new file mode 100644 index 0000000000..a777c7c616 --- /dev/null +++ b/libavcodec/mpl2dec.c @@ -0,0 +1,96 @@ +/* + * Copyright (c) 2012 Clément Bœsch + * + * This file is part of FFmpeg. + * + * FFmpeg is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * FFmpeg is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with FFmpeg; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +/** + * @file + * MPL2 subtitles decoder + * + * @see http://web.archive.org/web/20090328040233/http://napisy.ussbrowarek.org/mpl2-eng.html + */ + +#include "avcodec.h" +#include "ass.h" +#include "libavutil/bprint.h" + +static int mpl2_event_to_ass(AVBPrint *buf, const char *p) +{ + if (*p == ' ') + p++; + + while (*p) { + int got_style = 0; + + while (*p && strchr("/\\_", *p)) { + if (*p == '/') av_bprintf(buf, "{\\i1}"); + else if (*p == '\\') av_bprintf(buf, "{\\b1}"); + else if (*p == '_') av_bprintf(buf, "{\\u1}"); + got_style = 1; + p++; + } + + while (*p && *p != '|') { + if (*p != '\r' && *p != '\n') + av_bprint_chars(buf, *p, 1); + p++; + } + + if (*p == '|') { + if (got_style) + av_bprintf(buf, "{\\r}"); + av_bprintf(buf, "\\N"); + p++; + } + } + + av_bprintf(buf, "\r\n"); + return 0; +} + +static int mpl2_decode_frame(AVCodecContext *avctx, void *data, + int *got_sub_ptr, AVPacket *avpkt) +{ + AVBPrint buf; + AVSubtitle *sub = data; + const char *ptr = avpkt->data; + const int ts_start = av_rescale_q(avpkt->pts, avctx->time_base, (AVRational){1,100}); + const int ts_duration = avpkt->duration != -1 ? + av_rescale_q(avpkt->duration, avctx->time_base, (AVRational){1,100}) : -1; + + av_bprint_init(&buf, 0, AV_BPRINT_SIZE_UNLIMITED); + if (ptr && avpkt->size > 0 && *ptr && !mpl2_event_to_ass(&buf, ptr)) { + if (!av_bprint_is_complete(&buf)) { + av_bprint_finalize(&buf, NULL); + return AVERROR(ENOMEM); + } + ff_ass_add_rect(sub, buf.str, ts_start, ts_duration, 0); + } + *got_sub_ptr = sub->num_rects > 0; + av_bprint_finalize(&buf, NULL); + return avpkt->size; +} + +AVCodec ff_mpl2_decoder = { + .name = "mpl2", + .long_name = NULL_IF_CONFIG_SMALL("MPL2 subtitle"), + .type = AVMEDIA_TYPE_SUBTITLE, + .id = AV_CODEC_ID_MPL2, + .decode = mpl2_decode_frame, + .init = ff_ass_subtitle_header_default, +}; diff --git a/libavcodec/version.h b/libavcodec/version.h index 74c8360011..32d3650edf 100644 --- a/libavcodec/version.h +++ b/libavcodec/version.h @@ -29,7 +29,7 @@ #include "libavutil/avutil.h" #define LIBAVCODEC_VERSION_MAJOR 54 -#define LIBAVCODEC_VERSION_MINOR 81 +#define LIBAVCODEC_VERSION_MINOR 82 #define LIBAVCODEC_VERSION_MICRO 100 #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ |