File: update_error_prefixes.py

package info (click to toggle)
psycopg3 3.3.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,836 kB
  • sloc: python: 46,657; sh: 403; ansic: 149; makefile: 73
file content (100 lines) | stat: -rwxr-xr-x 2,683 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/usr/bin/env python
"""Find the error prefixes in various l10n used for precise prefix stripping."""

import re
import logging
from pathlib import Path
from argparse import ArgumentParser, Namespace
from collections import defaultdict

import polib

HERE = Path(__file__).parent

logger = logging.getLogger()
logging.basicConfig(level=logging.INFO, format="%(asctime)s %(message)s")


def main() -> None:
    args = parse_cmdline()
    regexp = make_regexp(args.pgroot)
    update_file(args.dest, regexp)


def make_regexp(pgroot: Path) -> str:
    logger.info("looking for translations in %s", pgroot)
    msgids = "DEBUG INFO NOTICE WARNING ERROR LOG FATAL PANIC".split()
    bylang = defaultdict[str, list[str]](list)
    bylang["en"].extend(msgids)
    for fn in (pgroot / "src/backend/po").glob("*.po"):
        lang = fn.name.rsplit(".")[0]
        pofile = polib.pofile(str(fn))
        for msgid in msgids:
            if not (entry := pofile.find(msgid)):
                continue
            bylang[lang].append(entry.msgstr)

    pattern = "\n    | ".join(
        "%s  # %s" % (" | ".join(re.escape(msg) for msg in msgs), lang)
        for lang, msgs in sorted(bylang.items())
    )
    return rf'''    r"""
    ^ (?:
      {pattern}
    ) : \s+
    """,  # noqa: E501'''


def update_file(fn: Path, content: str) -> None:
    logger.info("updating %s", fn)

    with open(fn) as f:
        lines = f.read().splitlines()

    istart, iend = (
        i
        for i, line in enumerate(lines)
        if re.match(r"\s*(#|\.\.)\s*autogenerated:\s+(start|end)", line)
    )

    lines[istart + 1 : iend] = [content]

    with open(fn, "w") as f:
        for line in lines:
            f.write(line + "\n")


def parse_cmdline() -> Namespace:
    for default_pgroot in (
        HERE / "../../fs/postgres",  # it happens to be my laptop
        HERE / "../../postgres",  # the last entry is the default if none found
    ):
        if default_pgroot.exists():
            break

    default_pgroot = default_pgroot.resolve()
    default_dest = (HERE / "../psycopg/psycopg/pq/misc.py").resolve()

    parser = ArgumentParser(description=__doc__)
    parser.add_argument(
        "--pgroot",
        metavar="DIR",
        default=default_pgroot,
        type=Path,
        help="root PostgreSQL source directory [default: %(default)s]",
    )
    parser.add_argument(
        "--dest",
        default=default_dest,
        type=Path,
        help="the file to change [default: %(default)s]",
    )

    if not (opt := parser.parse_args()).pgroot.is_dir():
        parser.error("not a valid directory: {opt.pgroot}")

    return opt


if __name__ == "__main__":
    main()