ACE3/tools/extract_dependencies.py

121 lines
4.1 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# Author: Jonpas
# Extracts dependencies to "docs/_includes/dependencies_list.md" and "docs/_includes/dependenciesx_list.md" for use with Jekyll include statement.
# Use the following line to add dependencies to an ACE3 feature page: {% include dependencies_list.md component="<component>" %}
# Use the following line to add dependencies to an ACEX feature page: {% include dependenciesx_list.md component="<component>" %}
import os
import sys
import re
def get_dependencies(line):
dependencies = re.findall(r'"(.*?)"', line)
return dependencies
def main():
if "--markdown" not in sys.argv:
print("""
#############################################
# Extract ACE3 and ACEX Module Dependencies #
# (for Jekyll include) #
#############################################
""")
# Mod paths
script_path = os.path.realpath(__file__)
project_path = os.path.dirname(os.path.dirname(script_path))
addons_path = os.path.join(project_path, "addons")
if "--acex" in sys.argv:
projectx_path = sys.argv[sys.argv.index("--acex") + 1]
addonsx_path = os.path.join(projectx_path, "addons")
# Documentation paths
include_path = os.path.join(project_path, "docs", "_includes")
dependencies_path = os.path.join(include_path, "dependencies_list.md")
dependenciesx_path = os.path.join(include_path, "dependenciesx_list.md")
# Prepare files and paths list
if not os.path.exists(include_path):
print("Jekyll documentation not found!")
sys.exit(0)
open(dependencies_path, "w", newline="\n").close()
addons = next(os.walk(addons_path))[1]
dependencies_path_current = dependencies_path
addons_path_current = addons_path
if "--acex" in sys.argv:
open(dependenciesx_path, "w", newline="\n").close()
addons.append(".")
addons += next(os.walk(addonsx_path))[1]
# Iterate through folders in the addons directories
for folder in addons:
# Ignore "main" component
if folder == "main":
continue
# Change to ACEX list on "." separator
if folder == ".":
dependencies_path_current = dependenciesx_path
addons_path_current = addonsx_path
continue
# Open config.cpp file and extract dependencies
data = []
configfile = os.path.join(addons_path_current, folder, "config.cpp")
if os.path.exists(configfile):
with open(os.path.join(addons_path_current, folder, "config.cpp")) as file:
match = False
for line in file:
# One-line
if not match and re.match(r"\s+requiredAddons\[\]\ = {.+?};", line):
data += get_dependencies(line)
print(get_dependencies(line))
break
# Multi-line
else:
if re.match(r"\s+requiredAddons\[\]\ = {", line):
# First line
match = True
data += get_dependencies(line)
continue
elif match and re.match(r"\s+};", line):
# Final line
data += get_dependencies(line)
match = False
break
elif match:
# All lines between
data += get_dependencies(line)
continue
data = "`, `".join(data)
data = "`{}`".format(data)
jekyll_statement = "".join([
"{% if include.component == \"" + folder + "\" %}\n",
"{}\n".format(data),
"{% endif %}\n"
])
with open(dependencies_path_current, "a", newline="\n") as file:
file.writelines([jekyll_statement, "\n"])
if "--markdown" not in sys.argv:
print("{}: {}".format(folder,data))
else:
print(jekyll_statement)
if __name__ == "__main__":
main()