cq: Format with black and isort
This commit is contained in:
@@ -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()
|
||||
|
||||
Reference in New Issue
Block a user