-
-
Notifications
You must be signed in to change notification settings - Fork 562
/
Copy pathterraform_docs_replace.py
74 lines (64 loc) · 2.27 KB
/
terraform_docs_replace.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
"""Deprecated hook to replace README.md with the output of terraform-docs."""
import argparse
import os
import subprocess
import sys
print(
'`terraform_docs_replace` hook is DEPRECATED.'
'For migration instructions see ' +
'https://github.com/antonbabenko/pre-commit-terraform/issues/248#issuecomment-1290829226',
)
def main(argv=None):
"""
TODO: Add docstring.
Args:
argv (list): List of command-line arguments (default: None)
Returns:
int: The return value indicating the success or failure of the function
"""
parser = argparse.ArgumentParser(
description="""Run terraform-docs on a set of files. Follows the standard convention of
pulling the documentation from main.tf in order to replace the entire
README.md file each time.""",
)
parser.add_argument(
'--dest', dest='dest', default='README.md',
)
parser.add_argument(
'--sort-inputs-by-required', dest='sort', action='store_true',
help='[deprecated] use --sort-by-required instead',
)
parser.add_argument(
'--sort-by-required', dest='sort', action='store_true',
)
parser.add_argument(
'--with-aggregate-type-defaults', dest='aggregate', action='store_true',
help='[deprecated]',
)
parser.add_argument('filenames', nargs='*', help='Filenames to check.')
args = parser.parse_args(argv)
dirs = []
for filename in args.filenames:
if (
os.path.realpath(filename) not in dirs and
(filename.endswith('.tf') or filename.endswith('.tfvars'))
):
dirs.append(os.path.dirname(filename))
retval = 0
for directory in dirs:
try:
proc_args = []
proc_args.append('terraform-docs')
if args.sort:
proc_args.append('--sort-by-required')
proc_args.append('md')
proc_args.append(f'./{directory}')
proc_args.append('>')
proc_args.append(f'./{directory}/{args.dest}')
subprocess.check_call(' '.join(proc_args), shell=True)
except subprocess.CalledProcessError as exeption:
print(exeption)
retval = 1
return retval
if __name__ == '__main__':
sys.exit(main())