Add detectors module
This commit is contained in:
52
i18n_guardian/detectors/python_gettext.py
Normal file
52
i18n_guardian/detectors/python_gettext.py
Normal file
@@ -0,0 +1,52 @@
|
||||
"""Python Gettext detector."""
|
||||
|
||||
from pathlib import Path
|
||||
from typing import Optional
|
||||
|
||||
from i18n_guardectors.base import Detector
|
||||
|
||||
|
||||
class PythonGettextDetector(Detector):
|
||||
"""Detect Python gettext module usage."""
|
||||
|
||||
@property
|
||||
def name(self) -> str:
|
||||
return "python-gettext"
|
||||
|
||||
@property
|
||||
def patterns(self) -> list:
|
||||
return ["*.py"]
|
||||
|
||||
def detect(self, path: Path) -> Optional[str]:
|
||||
"""Check for Python gettext usage."""
|
||||
for py_file in path.rglob("*.py"):
|
||||
try:
|
||||
content = py_file.read_text(encoding="utf-8")
|
||||
if any(
|
||||
pattern in content
|
||||
for pattern in [
|
||||
"import gettext",
|
||||
"from gettext import",
|
||||
"gettext.gettext",
|
||||
"gettext.ngettext",
|
||||
]
|
||||
):
|
||||
return self.name
|
||||
except OSError:
|
||||
continue
|
||||
|
||||
locale_dir = path / "locale"
|
||||
if locale_dir.exists():
|
||||
for _ in locale_dir.rglob("*/LC_MESSAGES/*.mo"):
|
||||
return self.name
|
||||
|
||||
return None
|
||||
|
||||
def get_i18n_functions(self) -> list:
|
||||
"""Get Python gettext function names."""
|
||||
return [
|
||||
"_",
|
||||
"gettext",
|
||||
"ngettext",
|
||||
"pgettext",
|
||||
]
|
||||
Reference in New Issue
Block a user