From 42a1924934a16d4bb2386e6de66615d3cbad4a11 Mon Sep 17 00:00:00 2001 From: Moritz Bunkus Date: Thu, 19 Jul 2007 11:20:45 +0000 Subject: [PATCH] Fixed SSA/ASS detection for files produced by Aegis Sub which does not include a line with "[script info]" in the file. --- ChangeLog | 6 ++++++ src/input/r_ssa.cpp | 24 +++++++++++------------- 2 files changed, 17 insertions(+), 13 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6c384eb5a..79aa8406b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2007-07-19 Moritz Bunkus + + * mkvmerge: enhancement: Fixed SSA/ASS detection for files + produced by Aegis Sub which doesn't include a line with '[script + info]' in the file. + 2007-07-07 Moritz Bunkus * mmg: enhancement: Added another option how mmg choses the diff --git a/src/input/r_ssa.cpp b/src/input/r_ssa.cpp index 200c2dfa9..401c8f93c 100644 --- a/src/input/r_ssa.cpp +++ b/src/input/r_ssa.cpp @@ -38,7 +38,12 @@ ssa_reader_c::probe_file(mm_text_io_c *io, int64_t size) { string line; int line_number; + + pcrecpp::RE_Options opt_caseless; + opt_caseless.set_caseless(true); pcrecpp::RE comment_re("^\\s*;"); + pcrecpp::RE script_info_re("^\\s*\\[script\\s+info\\]", opt_caseless); + pcrecpp::RE styles_re("^\\s*\\[V4\\+?\\s+Styles\\]", opt_caseless); try { line_number = 0; @@ -46,26 +51,19 @@ ssa_reader_c::probe_file(mm_text_io_c *io, while (io->getline2(line)) { ++line_number; - strip(line, true); + // Read at most 100 lines. + if (100 < line_number) + return 0; + // This is the line mkvmerge is looking for: positive match. - if (!strcasecmp(line.c_str(), "[script info]")) { + if (script_info_re.PartialMatch(line) || styles_re.PartialMatch(line)) { io->setFilePointer(0, seek_beginning); return 1; } - - // Read at most 500 lines. - if (line_number > 500) - return 0; - - // Allow for empty lines and comments. - if (comment_re.PartialMatch(line) || (line == "")) - continue; - - // It's something else: negative match. - return 0; } } catch (...) { } + return 0; }