mirror of
https://github.com/FEX-Emu/FEX.git
synced 2025-01-20 21:37:20 +00:00
135 lines
4.3 KiB
Python
Executable File
135 lines
4.3 KiB
Python
Executable File
#!/usr/bin/python3
|
|
|
|
# Tag Format
|
|
# $info$
|
|
# glossary: <name> ~ <definition> (Optional, registers or replaces a glossary entry)
|
|
# glossary: IR ~ Intermidiate Representation, a of storage for our high-level opcode representation
|
|
# glossary: SSA ~ Single Static Assignment, a form of representing IR in memory
|
|
# glossary: Basic Block ~ A block of instructions with no control flow, terminated by control flow
|
|
# glossary: Fragment ~ A Collection of basic blocks, possible an entire guest function or a fraction of it
|
|
# category: <name> ~ <description> (Optional, registers or replaces a category description)
|
|
# category: backend ~ Concerns itself with generating binary code from (optimized) IR
|
|
# meta: <name> ~ <description> (Optional, registers or replaces a meta, aka tag, description)
|
|
# meta: backend|arm64 ~ Arm64 Splatter backend
|
|
# tags: <meta name> [, <meta name>, ...] (Required if info tag exists)
|
|
# tags: backend|arm64
|
|
# desc: <short file description> (Optional)
|
|
# desc: Main glue logic of the arm64 splatter backend
|
|
# $end_info$
|
|
|
|
import re
|
|
from pathlib import Path
|
|
import sys
|
|
|
|
if (len(sys.argv) != 4):
|
|
print("doc_outline_generator GIT_DIR SRC_DIR LINK_PREFIX")
|
|
sys.exit(-2)
|
|
|
|
Base = Path(sys.argv[1])
|
|
Root = Path(sys.argv[2])
|
|
Prefix = sys.argv[3]
|
|
|
|
Paths = []
|
|
|
|
for path in Root.rglob('*.c'):
|
|
Paths.append(path)
|
|
|
|
for path in Root.rglob('*.cpp'):
|
|
Paths.append(path)
|
|
|
|
for path in Root.rglob('*.cc'):
|
|
Paths.append(path)
|
|
|
|
for path in Root.rglob('*.h'):
|
|
Paths.append(path)
|
|
|
|
for path in Root.rglob('*.hpp'):
|
|
Paths.append(path)
|
|
|
|
CategoryLabels = { }
|
|
MetaLabels = { }
|
|
GlossaryLabels = { }
|
|
|
|
Meta = { }
|
|
Desc = { }
|
|
|
|
for path in Paths:
|
|
with path.open() as file:
|
|
txt = file.read()
|
|
x = re.findall("\$info\$([^\$]*)\$end_info\$", txt)
|
|
if x:
|
|
for entry in x[0].strip().split("\n"):
|
|
name = entry.split(":", 1)[0].strip();
|
|
val = entry.split(":", 1)[1].strip();
|
|
if name == "category":
|
|
cat_name = val.split("~", 1)[0].strip();
|
|
cat_val = val.split("~", 1)[1].strip();
|
|
CategoryLabels[cat_name] = cat_val
|
|
elif name == "meta":
|
|
meta_name = val.split("~", 1)[0].strip();
|
|
meta_val = val.split("~", 1)[1].strip();
|
|
MetaLabels[meta_name] = meta_val
|
|
elif name == "glossary":
|
|
glossary_name = val.split("~", 1)[0].strip();
|
|
glossary_val = val.split("~", 1)[1].strip();
|
|
GlossaryLabels[glossary_name] = glossary_val
|
|
elif name == "tags":
|
|
for meta_name in val.split(","):
|
|
if meta_name.strip() not in Meta:
|
|
Meta[meta_name.strip()] = []
|
|
Meta[meta_name.strip()].append(path)
|
|
elif name == "desc":
|
|
Desc[path] = val;
|
|
else:
|
|
print("Error")
|
|
sys.exit(-1)
|
|
|
|
|
|
Readme = None
|
|
if (Root / "README.md").is_file():
|
|
Readme = Root / "README.md"
|
|
|
|
if (Root / "Readme.md").is_file():
|
|
Readme = Root / "Readme.md"
|
|
|
|
print("## " + Root.relative_to(Base).as_posix())
|
|
|
|
if Readme:
|
|
print("See [" + Root.name + "/" + Readme.name + "](" + Prefix + Readme.relative_to(Base).as_posix() + ") for more details")
|
|
|
|
print("")
|
|
|
|
if (GlossaryLabels):
|
|
print ("### Glossary")
|
|
print("")
|
|
for item in GlossaryLabels.items():
|
|
print("- " + item[0] + ": " + item[1])
|
|
print("")
|
|
print("")
|
|
|
|
Category = ""
|
|
for item in sorted(Meta.items()):
|
|
meta = item[0]
|
|
category = meta.split("|")[0]
|
|
topic = meta.split("|")[1]
|
|
if Category != category:
|
|
if Category != "":
|
|
print("")
|
|
print("")
|
|
Category = category
|
|
print("### " + Category)
|
|
if Category in CategoryLabels:
|
|
print(CategoryLabels[Category])
|
|
print("")
|
|
|
|
print("#### " + topic)
|
|
if meta in MetaLabels:
|
|
print(MetaLabels[meta])
|
|
|
|
for path in sorted(item[1]):
|
|
if path in Desc:
|
|
print("- [" + path.name + "](" + Prefix + path.relative_to(Base).as_posix() + ")" + ": " + Desc[path])
|
|
else:
|
|
print("- [" + path.name + "](" + Prefix + path.relative_to(Base).as_posix() + ")")
|
|
print("")
|