cq: Format with black and isort

This commit is contained in:
Philipp Hörist
2025-01-25 19:15:37 +01:00
parent e6e71d82bf
commit 841b1fb25e
44 changed files with 1641 additions and 1660 deletions

View File

@@ -5,25 +5,24 @@ import re
import subprocess
from pathlib import Path
REPO_DIR = Path(__file__).parent.parent
TRANS_DIR = REPO_DIR / 'po'
TRANS_TEMPLATE = TRANS_DIR / 'gajim_plugins.pot'
BUILD_DIR = REPO_DIR / 'plugins_translations'
TRANS_DIR = REPO_DIR / "po"
TRANS_TEMPLATE = TRANS_DIR / "gajim_plugins.pot"
BUILD_DIR = REPO_DIR / "plugins_translations"
TRANSLATABLE_FILES = [
'*.py',
'*.ui',
"*.py",
"*.ui",
]
def template_is_equal(old_template_path: Path, new_template: str) -> bool:
with open(old_template_path, 'r') as f:
with open(old_template_path, "r") as f:
old_template = f.read()
pattern = r'"POT-Creation-Date: .*\n"'
old_template = re.sub(pattern, '', old_template, count=1)
new_template = re.sub(pattern, '', new_template, count=1)
old_template = re.sub(pattern, "", old_template, count=1)
new_template = re.sub(pattern, "", new_template, count=1)
return old_template == new_template
@@ -34,86 +33,77 @@ def update_translation_template() -> bool:
paths += list(REPO_DIR.rglob(file_path))
cmd = [
'xgettext',
'-o', '-',
'-c#',
'--from-code=utf-8',
'--keyword=Q_',
'--no-location',
'--sort-output',
'--package-name=Gajim Plugins'
"xgettext",
"-o",
"-",
"-c#",
"--from-code=utf-8",
"--keyword=Q_",
"--no-location",
"--sort-output",
"--package-name=Gajim Plugins",
]
for path in paths:
cmd.append(str(path))
result = subprocess.run(cmd,
cwd=REPO_DIR,
text=True,
check=True,
capture_output=True)
result = subprocess.run(
cmd, cwd=REPO_DIR, text=True, check=True, capture_output=True
)
template = result.stdout
if (TRANS_TEMPLATE.exists() and
template_is_equal(TRANS_TEMPLATE, template)):
if TRANS_TEMPLATE.exists() and template_is_equal(TRANS_TEMPLATE, template):
# No new strings were discovered
return False
with open(TRANS_TEMPLATE, 'w') as f:
with open(TRANS_TEMPLATE, "w") as f:
f.write(template)
return True
def update_translation_files() -> None:
for file in TRANS_DIR.glob('*.po'):
subprocess.run(['msgmerge',
'-U',
'--sort-output',
str(file),
TRANS_TEMPLATE],
cwd=REPO_DIR,
check=True)
for file in TRANS_DIR.glob("*.po"):
subprocess.run(
["msgmerge", "-U", "--sort-output", str(file), TRANS_TEMPLATE],
cwd=REPO_DIR,
check=True,
)
def build_translations() -> None:
for po_file in TRANS_DIR.glob('*.po'):
for po_file in TRANS_DIR.glob("*.po"):
lang = po_file.stem
po_file = TRANS_DIR / f'{lang}.po'
mo_file = BUILD_DIR / f'{po_file.stem}.mo'
po_file = TRANS_DIR / f"{lang}.po"
mo_file = BUILD_DIR / f"{po_file.stem}.mo"
subprocess.run(['msgfmt',
str(po_file),
'-o',
str(mo_file)],
cwd=REPO_DIR,
check=True)
subprocess.run(
["msgfmt", str(po_file), "-o", str(mo_file)], cwd=REPO_DIR, check=True
)
def cleanup_translations() -> None:
for po_file in TRANS_DIR.glob('*.po'):
subprocess.run(['msgattrib',
'--output-file',
str(po_file),
'--no-obsolete',
str(po_file)],
cwd=REPO_DIR,
check=True)
for po_file in TRANS_DIR.glob("*.po"):
subprocess.run(
["msgattrib", "--output-file", str(po_file), "--no-obsolete", str(po_file)],
cwd=REPO_DIR,
check=True,
)
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Update Translations')
parser.add_argument('command', choices=['update', 'build', 'cleanup'])
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Update Translations")
parser.add_argument("command", choices=["update", "build", "cleanup"])
args = parser.parse_args()
if args.command == 'cleanup':
if args.command == "cleanup":
cleanup_translations()
elif args.command == 'update':
elif args.command == "update":
update_translation_template()
update_translation_files()
elif args.command == 'build':
elif args.command == "build":
update_translation_template()
update_translation_files()
build_translations()