2021-04-11 22:55:06 +00:00
|
|
|
#!/usr/bin/env python3
|
2022-12-12 02:58:02 +00:00
|
|
|
# pylint: disable=C0112,C0114,C0115,C0116,C0209,C0301,R0201,R0903
|
2021-04-11 22:55:06 +00:00
|
|
|
# -*- Python -*- See copyright, etc below
|
|
|
|
######################################################################
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import re
|
|
|
|
|
|
|
|
#######################################################################
|
|
|
|
|
2021-05-22 00:47:53 +00:00
|
|
|
|
2021-04-11 22:55:06 +00:00
|
|
|
class VlSphinxExtract:
|
|
|
|
debug = 0
|
|
|
|
SkipBasenames = {}
|
|
|
|
|
|
|
|
def process(self, filename):
|
2022-12-12 02:58:02 +00:00
|
|
|
with open(filename, "r", encoding="utf8") as fhr:
|
2021-04-11 22:55:06 +00:00
|
|
|
fhw = None
|
|
|
|
for line in fhr:
|
|
|
|
# =for VL_SPHINX_EXTRACT "file_to_write_to"
|
|
|
|
match = re.search(r'VL_SPHINX_EXTRACT +"([^"]+)"', line)
|
|
|
|
if match:
|
|
|
|
outname = match.group(1)
|
|
|
|
print("Writing %s" % outname)
|
2022-12-12 02:58:02 +00:00
|
|
|
fhw = open(outname, "w", encoding="utf8") # pylint: disable=consider-using-with
|
2021-04-11 22:55:06 +00:00
|
|
|
fhw.write(
|
|
|
|
".. comment: generated by vl_sphinx_extract from " +
|
|
|
|
filename + "\n")
|
|
|
|
fhw.write(".. code-block::\n")
|
|
|
|
elif re.match(r'^[=a-zA-Z0-9_]', line):
|
|
|
|
fhw = None
|
|
|
|
elif fhw:
|
|
|
|
fhw.write(line)
|
|
|
|
|
|
|
|
|
|
|
|
#######################################################################
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
allow_abbrev=False,
|
|
|
|
formatter_class=argparse.RawDescriptionHelpFormatter,
|
|
|
|
description="""Read a file and extract documentation data.""",
|
|
|
|
epilog=
|
2023-01-01 15:18:39 +00:00
|
|
|
""" Copyright 2021-2023 by Wilson Snyder. This package is free software;
|
2021-04-11 22:55:06 +00:00
|
|
|
you can redistribute it and/or modify it under the terms of either the GNU
|
|
|
|
Lesser General Public License Version 3 or the Perl Artistic License
|
|
|
|
Version 2.0.
|
|
|
|
|
|
|
|
SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0""")
|
|
|
|
|
|
|
|
parser.add_argument('--debug',
|
|
|
|
action='store_const',
|
|
|
|
const=9,
|
|
|
|
help='enable debug')
|
|
|
|
parser.add_argument('path', help='path to extract from')
|
|
|
|
Args = parser.parse_args()
|
|
|
|
|
|
|
|
o = VlSphinxExtract()
|
|
|
|
o.debug = Args.debug
|
|
|
|
o.process(Args.path)
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Local Variables:
|
|
|
|
# compile-command: "./vl_sphinx_extract --debug ../../bin/verilator"
|
|
|
|
# End:
|