view docs/test2rst.py @ 6847:f0a052aa924d

ci: run tests-py3 jobs on v2.0 images We can't use v1.0 images because they still have Python 3.7. Let's switch to using pip to install the extensions to avoid a SetuptoolsDeprecationWarning about running setup.py directly. This also avoid the warning about python_requires apparently. The "running as root" warning cannot be simply avoided by using a different CI image. We do have v2.1 images that default to ci-runner user, but no one forbids people from running the test locally as a root user, one way or another. Running pip as root shouldn't matter in this case, since it's not a real system install, so this particular warning is always irrelevant.
author Anton Shestakov <av6@dwimlabs.net>
date Thu, 12 Sep 2024 16:41:22 +0400
parents 1d80cda7fe93
children
line wrap: on
line source

#!/usr/bin/env python3

import argparse
import os
import re


ignored_patterns = [
    re.compile(r'^#if'),
    re.compile(r'^#else'),
    re.compile(r'^#endif'),
    re.compile(r'#rest-ignore$'),
]


def rstify(orig):
    """Take contents of a .t file and produce reStructuredText"""
    newlines = []

    code_block_mode = False
    sphinx_directive_mode = False

    for line in orig.splitlines():

        # Empty lines doesn't change output
        if not line:
            newlines.append(line)
            code_block_mode = False
            sphinx_directive_mode = False
            continue

        ignored = False
        for pattern in ignored_patterns:
            if pattern.search(line):
                ignored = True
                break
        if ignored:
            continue

        # Sphinx directives mode
        if line.startswith('  .. '):

            # Insert a empty line to makes sphinx happy
            newlines.append("")

            # And unindent the directive
            line = line[2:]
            sphinx_directive_mode = True

        # Code mode
        codeline = line.startswith('  ')
        if codeline and not sphinx_directive_mode:
            if code_block_mode is False:
                newlines.extend(['::', ''])

            code_block_mode = True

        newlines.append(line)

    return "\n".join(newlines)


def main():
    ap = argparse.ArgumentParser()
    ap.add_argument('testfile', help='.t file to transform')

    opts = ap.parse_args()

    with open(opts.testfile) as f:
        content = f.read()
    rst = rstify(content)
    target = os.path.splitext(opts.testfile)[0] + '.rst'
    with open(target, 'w') as f:
        f.write(rst)


if __name__ == '__main__':
    main()