File: doctools.py

package info (click to toggle)
pdb-tools 2.5.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,636 kB
  • sloc: python: 9,220; makefile: 13
file content (57 lines) | stat: -rw-r--r-- 1,872 bytes parent folder | download | duplicates (3)
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
#!/usr/bin/env python

"""
Scrapes tool headers for documentation.
"""

import importlib
from pathlib import Path

with open('index.md', 'w') as handle:

    with open('index.md.template') as template:
        print(template.read(), file=handle)

    import pdbtools
    modfile = Path(pdbtools.__file__)
    for f in sorted(list(modfile.parent.iterdir())):
        # ignore __init__.py and others.
        if f.stem.startswith('_') or f.suffix != '.py':
            continue

        # Dynamically import tool to get __doc__
        name = f.stem
        try:
            tool = importlib.import_module(f'pdbtools.{name}')
        except ModuleNotFoundError:
            print(f'Could not import module: {name}')
            continue

        # Parse documentation from docstrings
        # Preserve white-space as best as possible.
        # First non-empty line is always short description.
        # Last lines are always licensing disclaimer
        summary = None
        long_description = []

        doctext = tool.__doc__.replace('<', '&lt;').replace('>', '&gt;')
        for line in doctext.split('\n'):
            if summary is None and not line.strip():
                continue
            if line.startswith('This program is part of the'):
                break
            elif summary is None:
                summary = line
            else:
                long_description.append(line)

        long_description = '\n'.join(long_description)
        print('<div style="margin-bottom: 1em;">', file=handle)
        print('<details>', file=handle)
        print(f"<summary><b>{name}</b><p>{summary}</p></summary>", file=handle)
        print(
            f'<span style="font-family: monospace; white-space: pre;">{long_description}</span>',
            file=handle
        )
        print('</details>', file=handle)
        print('</div>', file=handle)