1
0
Fork 0
ansible-systemd/update_doc

41 Zeilen
1,6 KiB
Text

#!/usr/bin/python
import importlib
2023-04-20 22:09:58 +02:00
import pathlib
import re
import sys
2023-04-15 19:02:20 +02:00
sys.path.append(".")
2023-04-16 00:10:13 +02:00
mindocstring = "DOCUMENTATION = ''''''"
moduledir = pathlib.Path("plugins/modules")
regex = re.compile("DOCUMENTATION *= *r?(?P<quote>\"{3}|'{3})(---)?.*?(?P=quote)", re.MULTILINE | re.DOTALL)
if __name__ == "__main__":
for modfile in moduledir.iterdir():
if modfile.name in ( "__init__.py", "__pycache__"):
continue
2023-04-16 00:10:13 +02:00
mod = importlib.import_module(".".join((modfile.parts[:-1])+(modfile.stem,)))
if hasattr(mod, "Module"):
module = mod.Module
elif hasattr(mod, "__module_name__"):
module = getattr(mod, mod.__module_name__)
2023-04-16 00:10:13 +02:00
else:
print("Error loading Module of File: {}. No Module or __module_name__ defined".format(modfile))
continue
2023-04-20 22:09:58 +02:00
try:
moddoc = module.doc()
except AttributeError:
print("Broken module. skipping {}".format(modfile))
2023-04-20 22:10:43 +02:00
continue
2023-04-21 00:17:54 +02:00
except Exception as e:
print("Error in documentation of module {}: {}".format(modfile, e))
continue
moddata = modfile.read_text()
match = regex.search(moddata)
if not match:
print("no Documentation set for module {}. Please add at least \"{}\" to the file".format(modfile.stem, mindocstring))
continue
newmod = "{pre}DOCUMENTATION = {quote}{doc}{quote}{post}".format(pre=moddata[:match.start()], quote=match.group("quote"), doc=moddoc, post=moddata[match.end():])
modfile.write_text(newmod)
2023-04-21 00:17:54 +02:00
# code: python