1
0
Fork 0
mirror of https://github.com/morpheus65535/bazarr synced 2025-01-03 05:25:28 +00:00

Subtitle class: get format dinamically (fix #2514)

This commit is contained in:
Vitiko 2024-06-18 17:44:12 -04:00
parent 9a52b3c539
commit 4430ec8f3e
2 changed files with 46 additions and 10 deletions

View file

@ -62,7 +62,7 @@ class Subtitle(Subtitle_):
_guessed_encoding = None _guessed_encoding = None
_is_valid = False _is_valid = False
use_original_format = False use_original_format = False
format = "srt" # default format is srt # format = "srt" # default format is srt
def __init__(self, language, hearing_impaired=False, page_link=None, encoding=None, mods=None, original_format=False): def __init__(self, language, hearing_impaired=False, page_link=None, encoding=None, mods=None, original_format=False):
# set subtitle language to hi if it's hearing_impaired # set subtitle language to hi if it's hearing_impaired
@ -74,6 +74,21 @@ class Subtitle(Subtitle_):
self.mods = mods self.mods = mods
self._is_valid = False self._is_valid = False
self.use_original_format = original_format self.use_original_format = original_format
self._og_format = None
@property
def format(self):
if self.use_original_format and self._og_format is not None:
logger.debug("Original format requested [%s]", self._og_format)
return self._og_format
logger.debug("Will assume srt format")
return "srt"
# Compatibility
@format.setter
def format(self, val):
self._og_format = val
def __repr__(self): def __repr__(self):
r_info = str(self.release_info or "").replace("\n", " | ").strip() r_info = str(self.release_info or "").replace("\n", " | ").strip()
@ -292,11 +307,13 @@ class Subtitle(Subtitle_):
logger.info("Got FPS from MicroDVD subtitle: %s", subs.fps) logger.info("Got FPS from MicroDVD subtitle: %s", subs.fps)
else: else:
logger.info("Got format: %s", subs.format) logger.info("Got format: %s", subs.format)
if self.use_original_format: self._og_format = subs.format
self.format = subs.format self._is_valid = True
self._is_valid = True # if self.use_original_format:
logger.debug("Using original format") # self.format = subs.format
return True # self._is_valid = True
# logger.debug("Using original format")
return True
except pysubs2.UnknownFPSError: except pysubs2.UnknownFPSError:
# if parsing failed, use frame rate from provider # if parsing failed, use frame rate from provider

View file

@ -8,9 +8,9 @@ from fese.exceptions import LanguageNotFound
import pytest import pytest
from subliminal_patch.core import Episode from subliminal_patch.core import Episode
from subliminal_patch.core import Movie from subliminal_patch.core import Movie
from subliminal_patch.providers.embeddedsubtitles import _clean_ass_subtitles
from subliminal_patch.providers.embeddedsubtitles import ( from subliminal_patch.providers.embeddedsubtitles import (
_discard_possible_incomplete_subtitles, _discard_possible_incomplete_subtitles,
_clean_ass_subtitles,
) )
from subliminal_patch.providers.embeddedsubtitles import _get_pretty_release_name from subliminal_patch.providers.embeddedsubtitles import _get_pretty_release_name
from subliminal_patch.providers.embeddedsubtitles import _MemoizedFFprobeVideoContainer from subliminal_patch.providers.embeddedsubtitles import _MemoizedFFprobeVideoContainer
@ -127,7 +127,9 @@ def fake_streams():
@pytest.mark.parametrize("tags_", [{}, {"language": "und", "title": "Unknown"}]) @pytest.mark.parametrize("tags_", [{}, {"language": "und", "title": "Unknown"}])
def test_list_subtitles_unknown_as_fallback(mocker, tags_, video_single_language): def test_list_subtitles_unknown_as_fallback(mocker, tags_, video_single_language):
with EmbeddedSubtitlesProvider(unknown_as_fallback=True, fallback_lang="en") as provider: with EmbeddedSubtitlesProvider(
unknown_as_fallback=True, fallback_lang="en"
) as provider:
fake = FFprobeSubtitleStream( fake = FFprobeSubtitleStream(
{"index": 3, "codec_name": "subrip", "tags": tags_} {"index": 3, "codec_name": "subrip", "tags": tags_}
) )
@ -144,7 +146,9 @@ def test_list_subtitles_unknown_as_fallback(mocker, tags_, video_single_language
def test_list_subtitles_unknown_as_fallback_w_real_english_subtitles( def test_list_subtitles_unknown_as_fallback_w_real_english_subtitles(
video_single_language, mocker video_single_language, mocker
): ):
with EmbeddedSubtitlesProvider(unknown_as_fallback=True, fallback_lang="en") as provider: with EmbeddedSubtitlesProvider(
unknown_as_fallback=True, fallback_lang="en"
) as provider:
fakes = [ fakes = [
FFprobeSubtitleStream( FFprobeSubtitleStream(
{"index": 3, "codec_name": "subrip", "tags": {"language": "und"}} {"index": 3, "codec_name": "subrip", "tags": {"language": "und"}}
@ -165,7 +169,7 @@ def test_list_subtitles_unknown_as_fallback_w_real_english_subtitles(
@pytest.mark.parametrize("tags_", [{}, {"language": "und", "title": "Unknown"}]) @pytest.mark.parametrize("tags_", [{}, {"language": "und", "title": "Unknown"}])
def test_list_subtitles_unknown_as_fallback_disabled(tags_): def test_list_subtitles_unknown_as_fallback_disabled(tags_):
with EmbeddedSubtitlesProvider(unknown_as_fallback=False,fallback_lang="en"): with EmbeddedSubtitlesProvider(unknown_as_fallback=False, fallback_lang="en"):
with pytest.raises(LanguageNotFound): with pytest.raises(LanguageNotFound):
assert FFprobeSubtitleStream( assert FFprobeSubtitleStream(
{"index": 3, "codec_name": "subrip", "tags": tags_} {"index": 3, "codec_name": "subrip", "tags": tags_}
@ -362,6 +366,21 @@ def test_download_subtitle_single(video_single_language):
assert subtitle.is_valid() assert subtitle.is_valid()
def test_download_subtitle_single_is_ass(video_single_language):
with EmbeddedSubtitlesProvider() as provider:
subtitle = provider.list_subtitles(
video_single_language, {Language.fromalpha2("en")}
)[0]
provider.download_subtitle(subtitle)
assert subtitle.is_valid()
assert subtitle.format == "srt"
subtitle.use_original_format = True
assert subtitle.format == "ass"
def test_memoized(video_single_language, mocker): def test_memoized(video_single_language, mocker):
with EmbeddedSubtitlesProvider() as provider: with EmbeddedSubtitlesProvider() as provider:
provider.list_subtitles(video_single_language, {Language.fromalpha2("en")}) provider.list_subtitles(video_single_language, {Language.fromalpha2("en")})