summaryrefslogtreecommitdiffstats
path: root/sub
diff options
context:
space:
mode:
authorwm4 <wm4@nowhere>2015-12-15 21:03:42 +0100
committerwm4 <wm4@nowhere>2015-12-15 21:05:48 +0100
commitc7985fe5f705523fe2fd150b1c50de9185e512e6 (patch)
tree8a47a38a18c4534aa2498ca2bcb728d16e4021f0 /sub
parent29226e6a994e829c637f04cfd7f3574f0699885c (diff)
downloadmpv-c7985fe5f705523fe2fd150b1c50de9185e512e6.tar.bz2
mpv-c7985fe5f705523fe2fd150b1c50de9185e512e6.tar.xz
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.
Diffstat (limited to 'sub')
-rw-r--r--sub/dec_sub.c2
-rw-r--r--sub/sd_lavf_srt.c94
2 files changed, 0 insertions, 96 deletions
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 <http://www.gnu.org/licenses/>.
- */
-
-#include <stdlib.h>
-#include <inttypes.h>
-#include <assert.h>
-
-#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,
-};