summaryrefslogtreecommitdiffstats
path: root/ansible_collections/community/routeros/update-docs.py
diff options
context:
space:
mode:
Diffstat (limited to '')
-rwxr-xr-xansible_collections/community/routeros/update-docs.py44
1 files changed, 44 insertions, 0 deletions
diff --git a/ansible_collections/community/routeros/update-docs.py b/ansible_collections/community/routeros/update-docs.py
new file mode 100755
index 000000000..17a431b05
--- /dev/null
+++ b/ansible_collections/community/routeros/update-docs.py
@@ -0,0 +1,44 @@
+#!/usr/bin/env python3
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2022, Felix Fontein (@felixfontein) <felix@fontein.de>
+# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
+# SPDX-License-Identifier: GPL-3.0-or-later
+
+'''
+Updates DOCUMENTATION of modules using module_utils._api_data with the correct list of supported paths.
+'''
+
+from plugins.module_utils._api_data import (
+ PATHS,
+ join_path,
+)
+
+
+MODULES = [
+ 'plugins/modules/api_info.py',
+ 'plugins/modules/api_modify.py',
+]
+
+
+def update_file(file, begin_line, end_line, choice_line, path_choices):
+ with open(file, 'r', encoding='utf-8') as f:
+ lines = f.read().splitlines()
+ begin_index = lines.index(begin_line)
+ end_index = lines.index(end_line, begin_index + 1)
+ new_lines = lines[:begin_index + 1] + [choice_line.format(choice=choice) for choice in path_choices] + lines[end_index:]
+ if lines != new_lines:
+ print(f'{file} has been updated')
+ with open(file, 'w', encoding='utf-8') as f:
+ f.write('\n'.join(new_lines) + '\n')
+
+
+def main():
+ path_choices = sorted([join_path(path) for path, path_info in PATHS.items() if path_info.fully_understood])
+
+ for file in MODULES:
+ update_file(file, ' # BEGIN PATH LIST', ' # END PATH LIST', ' - {choice}', path_choices)
+
+
+if __name__ == '__main__':
+ main()