From c7985fe5f705523fe2fd150b1c50de9185e512e6 Mon Sep 17 00:00:00 2001 From: wm4 Date: Tue, 15 Dec 2015 21:03:42 +0100 Subject: sub: remove sd_lavf_srt.c This restored timestamps when demuxing srt subtitles in Libav, which was important for avoiding slightly overlapping subtitles. Since the way this works was changed, there is no real reason to maintain proper timestamps anymore on this level - this can be dropped without issues. --- sub/dec_sub.c | 2 -- sub/sd_lavf_srt.c | 94 ------------------------------------------------------- 2 files changed, 96 deletions(-) delete mode 100644 sub/sd_lavf_srt.c (limited to 'sub') diff --git a/sub/dec_sub.c b/sub/dec_sub.c index dffec03983..3a2136f302 100644 --- a/sub/dec_sub.c +++ b/sub/dec_sub.c @@ -36,7 +36,6 @@ extern const struct sd_functions sd_ass; extern const struct sd_functions sd_lavc; extern const struct sd_functions sd_srt; extern const struct sd_functions sd_microdvd; -extern const struct sd_functions sd_lavf_srt; extern const struct sd_functions sd_lavc_conv; static const struct sd_functions *const sd_list[] = { @@ -45,7 +44,6 @@ static const struct sd_functions *const sd_list[] = { #endif &sd_lavc, &sd_srt, - &sd_lavf_srt, &sd_microdvd, &sd_lavc_conv, NULL diff --git a/sub/sd_lavf_srt.c b/sub/sd_lavf_srt.c deleted file mode 100644 index 8f1f7de78b..0000000000 --- a/sub/sd_lavf_srt.c +++ /dev/null @@ -1,94 +0,0 @@ -/* - * This file is part of mpv. - * - * SRT timestamp parsing code lifted from FFmpeg srtdec.c (LGPL). - * - * mpv is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * mpv 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 General Public License for more details. - * - * You should have received a copy of the GNU General Public License along - * with mpv. If not, see . - */ - -#include -#include -#include - -#include "misc/bstr.h" -#include "sd.h" - -/* - * Background: - * - * Libav's .srt demuxer outputs packets that contain parts of the subtitle - * event header. Also, the packet duration is not set (they don't parse it - * on the demuxer side). As a result, the srt demuxer is useless. - * - * However, we can fix it by parsing the header, which spares us from writing - * a full SRT demuxer. - * - * Newer versions of FFmpeg do not have this problem. To avoid compatibility - * problems, they changed the codec name from "srt" to "subrip". - * - * Summary: this is a hack for broken SRT stuff in Libav. - * - */ - -static bool supports_format(const char *format) -{ - return format && strcmp(format, "srt") == 0; -} - -static int init(struct sd *sd) -{ - sd->output_codec = "subrip"; - return 0; -} - -static bool parse_pts(bstr header, double *duration) -{ - char buf[200]; - snprintf(buf, sizeof(buf), "%.*s", BSTR_P(header)); - int hh1, mm1, ss1, ms1; - int hh2, mm2, ss2, ms2; - if (sscanf(buf, "%d:%2d:%2d%*1[,.]%3d --> %d:%2d:%2d%*1[,.]%3d", - &hh1, &mm1, &ss1, &ms1, &hh2, &mm2, &ss2, &ms2) >= 8) - { - int64_t start = (hh1*3600LL + mm1*60LL + ss1) * 1000LL + ms1; - int64_t end = (hh2*3600LL + mm2*60LL + ss2) * 1000LL + ms2; - *duration = (end - start) / 1000.0; - return true; - } - return false; -} - -static void decode(struct sd *sd, struct demux_packet *packet) -{ - bstr data = {packet->buffer, packet->len}; - // Remove the broken header. It's usually on the second or first line. - bstr left = data; - while (left.len) { - bstr line = bstr_getline(left, &left); - if (parse_pts(line, &packet->duration)) { - data = left; - break; - } - } - sd_conv_add_packet(sd, data.start, data.len, packet->pts, packet->duration); -} - -const struct sd_functions sd_lavf_srt = { - .name = "lavf_srt", - .supports_format = supports_format, - .init = init, - .decode = decode, - .get_converted = sd_conv_def_get_converted, - .reset = sd_conv_def_reset, -}; -- cgit v1.2.3