btstack/doc/manual/markdown_create_ports.py

115 lines
3.9 KiB
Python
Raw Normal View History

2020-10-05 16:03:24 +00:00
#!/usr/bin/env python3
2021-05-27 12:45:58 +00:00
import sys, os, shutil, re, getopt
blacklist = []
port_item = """
- [PORT_TITLE](#sec:PORT_LABELPort)"""
def get_readme_title(example_path):
title = ''
2020-10-05 16:03:24 +00:00
with open(example_path, 'r') as fin:
for line in fin:
parts = re.match(r'(##\s)(.*)\n',line)
if parts:
title = parts.group(2)
continue
return title
# write list of examples
def process_readmes(intro_file, port_folder, ports_file, ports_folder):
matches = {}
images = {}
# iterate over port folders
ports = os.listdir(port_folder)
for port in ports:
if port not in blacklist:
readme_file = port_folder + "/" + port + "/" + "README.md"
if os.path.exists(readme_file):
matches[port] = readme_file
for file in os.listdir(port_folder + "/" + port):
if file.endswith('.jpg') or file.endswith('.png'):
images[file] = port_folder + "/" + port + "/" + file
with open(ports_file, 'w') as ports:
2020-10-05 16:03:24 +00:00
with open(intro_file, 'r') as fin:
for line in fin:
ports.write(line)
fin.close()
2017-12-23 22:17:07 +00:00
for readme_dir, readme_file in sorted(matches.items()):
2020-10-05 16:03:24 +00:00
with open(readme_file, 'r') as fin:
for line in fin:
# find title, add reference
title_parts = re.match(r'(#\s+)(.*)\n',line)
if title_parts:
title = title_parts.group(2)
ports.write(port_item.replace("PORT_TITLE", title).replace("PORT_LABEL", readme_dir))
break
fin.close()
ports.write("\n\n")
2017-12-23 22:17:07 +00:00
for readme_dir, readme_file in sorted(matches.items()):
2020-10-05 16:03:24 +00:00
with open(readme_file, 'r') as fin:
for line in fin:
2017-12-23 23:35:42 +00:00
#increase level of indentation
parts = re.match(r'#(.*)\n',line)
2021-05-21 15:53:16 +00:00
title_parts_level1 = re.match(r'(#\s+)(.*)\n',line)
title_parts_level2 = re.match(r'(##\s+)(.*)\n',line)
2021-05-21 15:53:16 +00:00
if parts and title_parts_level1:
ports.write("## " + title_parts_level1.group(2) + " {" + "#sec:" + readme_dir + "Port}\n" )
elif parts and title_parts_level2:
ports.write("### " + title_parts_level2.group(2)+ "\n" )
else:
ports.write(line)
# copy images
for image_filename, image_path in images.items():
print('copy %s as %s' % (image_path, ports_folder + image_filename))
shutil.copy(image_path, ports_folder + image_filename)
fin.close()
ports.close()
def main(argv):
btstackfolder = "../../"
2021-05-27 12:45:58 +00:00
markdownfolder = "docs-markdown/"
templatefolder = "docs-intro/"
2021-05-27 13:01:29 +00:00
cmd = 'markdown_create_ports.py [-r <root_btstackfolder>] [-t <templatefolder>] [-o <output_markdownfolder>]'
2021-05-27 12:45:58 +00:00
try:
opts, args = getopt.getopt(argv,"r:t:o:",["rfolder=","tfolder=","ofolder="])
except getopt.GetoptError:
print (cmd)
sys.exit(2)
for opt, arg in opts:
if opt == '-h':
print (cmd)
sys.exit()
elif opt in ("-r", "--rfolder"):
btstackfolder = arg
elif opt in ("-t", "--tfolder"):
templatefolder = arg
elif opt in ("-o", "--ofolder"):
markdownfolder = arg
inputfolder = btstackfolder + "port/"
2021-05-27 12:45:58 +00:00
portsfolder = markdownfolder + "ports/"
introfile = templatefolder + "ports_intro.md"
outputfile = portsfolder + "existing_ports.md"
2021-05-27 12:45:58 +00:00
print ('Input folder: ', inputfolder)
print ('Intro file: ', introfile)
print ('Output file: ', outputfile)
process_readmes(introfile, inputfolder, outputfile, portsfolder)
if __name__ == "__main__":
main(sys.argv[1:])