mirror of
https://github.com/morpheus65535/bazarr
synced 2024-12-23 08:13:14 +00:00
33 lines
850 B
Python
33 lines
850 B
Python
# -*- coding: utf-8 -*-
|
|
from __future__ import unicode_literals
|
|
|
|
import re
|
|
from logging import NullHandler, getLogger
|
|
|
|
import babelfish
|
|
|
|
from ..rule import Rule
|
|
|
|
logger = getLogger(__name__)
|
|
logger.addHandler(NullHandler())
|
|
|
|
|
|
class LanguageRule(Rule):
|
|
"""Language rules."""
|
|
|
|
name_re = re.compile(r'(?P<name>\w+)\b', re.IGNORECASE)
|
|
|
|
def execute(self, props, pv_props, context):
|
|
"""Language detection using name."""
|
|
if 'language' in props:
|
|
return
|
|
|
|
if 'name' in props:
|
|
name = props.get('name', '')
|
|
match = self.name_re.match(name)
|
|
if match:
|
|
try:
|
|
return babelfish.Language.fromname(match.group('name'))
|
|
except babelfish.Error:
|
|
pass
|
|
logger.info('Invalid %s: %r', self.description, name)
|