Mercurial > public > mercurial-scm > evolve
view docs/test2rst.py @ 5656:60ce376919c5 stable
test2rst: make one_file() useful
The issue here was that this function is used when test2rst.py is called with
an argument that is not a directory, and in such case we didn't write the
result anywhere.
author | Anton Shestakov <av6@dwimlabs.net> |
---|---|
date | Mon, 09 Nov 2020 22:58:37 +0800 |
parents | 16c1398b0063 |
children | 6e37ce7be367 |
line wrap: on
line source
#!/usr/bin/env python import os import re import sys INDEX = ''' Mercurial tests =============== .. toctree:: :maxdepth: 1 ''' ignored_patterns = [ re.compile(r'^#if'), re.compile(r'^#else'), re.compile(r'^#endif'), re.compile(r'#rest-ignore$'), ] def rstify(orig): newlines = [] code_block_mode = False sphinx_directive_mode = False for line in orig.splitlines(): # Emtpy 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(base): if os.path.isdir(base): one_dir(base) else: one_file(base) def one_dir(base): index = INDEX # doc = lambda x: op.join(op.dirname(__file__), 'docs', x) for fn in sorted(os.listdir(base)): if not fn.endswith('.t'): continue name = os.path.splitext(fn)[0] one_file(os.path.join(base, fn)) index += '\n ' + name # with file(doc('index.rst'), 'w') as f: # f.write(index) def one_file(path): with open(path) as f: content = f.read() rst = rstify(content) target = os.path.splitext(path)[0] + '.rst' with open(target, 'w') as f: f.write(rst) if __name__ == '__main__': if len(sys.argv) != 2: print('Please supply a path to tests dir as parameter') sys.exit() main(sys.argv[1])