|
|
""" |
|
|
国际化上下文管理器 |
|
|
提供更优雅的语言设置方式,避免在函数间传递language参数 |
|
|
""" |
|
|
|
|
|
import contextvars |
|
|
from utils.i18n_types import Language |
|
|
|
|
|
|
|
|
_language_context = contextvars.ContextVar("language", default=Language.ENGLISH) |
|
|
|
|
|
|
|
|
class I18nContext: |
|
|
"""国际化上下文管理器""" |
|
|
|
|
|
@staticmethod |
|
|
def set_language(language: Language) -> None: |
|
|
""" |
|
|
设置当前上下文的语言 |
|
|
|
|
|
Args: |
|
|
language: 语言枚举值 |
|
|
""" |
|
|
_language_context.set(language) |
|
|
|
|
|
@staticmethod |
|
|
def get_language() -> Language: |
|
|
""" |
|
|
获取当前上下文的语言 |
|
|
|
|
|
Returns: |
|
|
当前语言枚举值 |
|
|
""" |
|
|
return _language_context.get() |
|
|
|
|
|
@staticmethod |
|
|
def reset_language() -> None: |
|
|
"""重置语言为默认值""" |
|
|
_language_context.set(Language.ENGLISH) |
|
|
|
|
|
@staticmethod |
|
|
def get_language_value() -> str: |
|
|
""" |
|
|
获取当前语言的字符串值 |
|
|
|
|
|
Returns: |
|
|
语言字符串值 |
|
|
""" |
|
|
return _language_context.get().value |
|
|
|
|
|
|
|
|
class I18nContextManager: |
|
|
"""国际化上下文管理器,支持with语句""" |
|
|
|
|
|
def __init__(self, language: Language): |
|
|
""" |
|
|
初始化上下文管理器 |
|
|
|
|
|
Args: |
|
|
language: 要设置的语言 |
|
|
""" |
|
|
self.language = language |
|
|
self._previous_language = None |
|
|
|
|
|
def __enter__(self): |
|
|
"""进入上下文时保存当前语言并设置新语言""" |
|
|
self._previous_language = I18nContext.get_language() |
|
|
I18nContext.set_language(self.language) |
|
|
return self |
|
|
|
|
|
def __exit__(self, exc_type, exc_val, exc_tb): |
|
|
"""退出上下文时恢复之前的语言""" |
|
|
if self._previous_language is not None: |
|
|
I18nContext.set_language(self._previous_language) |
|
|
|
|
|
|
|
|
|
|
|
def set_language(language: Language) -> None: |
|
|
"""设置当前语言""" |
|
|
I18nContext.set_language(language) |
|
|
|
|
|
|
|
|
def get_language() -> Language: |
|
|
"""获取当前语言""" |
|
|
return I18nContext.get_language() |
|
|
|
|
|
|
|
|
def reset_language() -> None: |
|
|
"""重置语言为默认值""" |
|
|
I18nContext.reset_language() |
|
|
|
|
|
|
|
|
def with_language(language: Language): |
|
|
""" |
|
|
创建语言上下文管理器 |
|
|
|
|
|
Args: |
|
|
language: 要设置的语言 |
|
|
|
|
|
Returns: |
|
|
上下文管理器 |
|
|
""" |
|
|
return I18nContextManager(language) |
|
|
|
|
|
|
|
|
|
|
|
def with_language_decorator(language: Language): |
|
|
""" |
|
|
装饰器,为函数自动设置语言上下文 |
|
|
|
|
|
Args: |
|
|
language: 要设置的语言 |
|
|
|
|
|
Returns: |
|
|
装饰器函数 |
|
|
""" |
|
|
|
|
|
def decorator(func): |
|
|
def wrapper(*args, **kwargs): |
|
|
with I18nContextManager(language): |
|
|
return func(*args, **kwargs) |
|
|
|
|
|
return wrapper |
|
|
|
|
|
return decorator |
|
|
|