1
0
Fork 0
mirror of https://github.com/morpheus65535/bazarr synced 2025-01-21 06:18:36 +00:00
bazarr/custom_libs/subzero/modification/mods/__init__.py

112 lines
3.5 KiB
Python
Raw Normal View History

2018-10-31 16:08:29 +00:00
# coding=utf-8
2019-09-17 02:04:27 +00:00
from __future__ import absolute_import
2018-10-31 16:08:29 +00:00
import re
import logging
from subzero.modification.processors.re_processor import ReProcessor, NReProcessor
2019-09-17 02:04:27 +00:00
import six
2018-10-31 16:08:29 +00:00
logger = logging.getLogger(__name__)
class SubtitleModification(object):
identifier = None
description = None
long_description = None
exclusive = False
advanced = False # has parameters
args_mergeable = False
order = None
modifies_whole_file = False # operates on the whole file, not individual entries
apply_last = False
only_uppercase = False
pre_processors = []
processors = []
post_processors = []
last_processors = []
2018-10-31 16:08:29 +00:00
languages = []
def __init__(self, parent):
return
def _process(self, content, processors, debug=False, parent=None, index=None, **kwargs):
if not content:
return
# processors may be a list or a callable
#if callable(processors):
# _processors = processors()
#else:
# _processors = processors
_processors = processors
new_content = content
for processor in _processors:
if not processor.supported(parent):
if debug and processor.enabled:
logger.debug("Processor not supported, skipping: %s", processor.name)
processor.enabled = False
continue
old_content = new_content
new_content = processor.process(new_content, debug=debug, **kwargs)
if not new_content:
if debug:
logger.debug("Processor returned empty line: %s", processor.name)
break
if debug:
if old_content == new_content:
continue
logger.debug("%d: %s: %s -> %s", index, processor.name, repr(old_content), repr(new_content))
return new_content
def pre_process(self, content, debug=False, parent=None, **kwargs):
return self._process(content, self.pre_processors, debug=debug, parent=parent, **kwargs)
def process(self, content, debug=False, parent=None, **kwargs):
return self._process(content, self.processors, debug=debug, parent=parent, **kwargs)
def post_process(self, content, debug=False, parent=None, **kwargs):
return self._process(content, self.post_processors, debug=debug, parent=parent, **kwargs)
def modify(self, content, debug=False, parent=None, procs=None, **kwargs):
2018-10-31 16:08:29 +00:00
if not content:
return
new_content = content
for method in procs or ("pre_process", "process", "post_process"):
2018-10-31 16:08:29 +00:00
if not new_content:
return
new_content = self._process(new_content, getattr(self, "%sors" % method),
debug=debug, parent=parent, **kwargs)
2018-10-31 16:08:29 +00:00
return new_content
@classmethod
def get_signature(cls, **kwargs):
2019-09-17 02:04:27 +00:00
string_args = ",".join(["%s=%s" % (key, value) for key, value in six.iteritems(kwargs)])
2018-10-31 16:08:29 +00:00
return "%s(%s)" % (cls.identifier, string_args)
@classmethod
def merge_args(cls, args1, args2):
raise NotImplementedError
class SubtitleTextModification(SubtitleModification):
pass
2019-09-13 19:12:26 +00:00
TAG = r"(?:\s*{\\[iusb][0-1]}\s*)*"
2018-10-31 16:08:29 +00:00
EMPTY_TAG_PROCESSOR = ReProcessor(re.compile(r'({\\\w1})[\s.,-_!?]*({\\\w0})'), "", name="empty_tag")
empty_line_post_processors = [
# empty tag
EMPTY_TAG_PROCESSOR,
# empty line (needed?)
NReProcessor(re.compile(r'^[\s-]+$'), "", name="empty_line"),
]