forked from stan-dev/docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathextract_function_sigs.py
71 lines (59 loc) · 2.2 KB
/
extract_function_sigs.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
#!/usr/bin/env python
"""
Extract function signatures from html comments in markdown.
"""
import glob
import os
import os.path
import pathlib
import sys
import contextlib
import subprocess
@contextlib.contextmanager
def pushd(new_dir):
previous_dir = os.getcwd()
os.chdir(new_dir)
yield
os.chdir(previous_dir)
HERE = pathlib.Path(__file__).parent
def get_sigs():
sigs = set()
ref_dir = os.path.join(HERE, 'src', 'functions-reference')
with pushd(ref_dir):
for file in glob.glob('*.qmd'):
with open(file) as rmd_file:
lines = rmd_file.readlines()
for line in lines:
if line.startswith('<!-- '):
line = line.lstrip('<!- ')
parts = [x.strip(' ~') for x in line.split(';')]
if len(parts) == 3:
parts[1] = parts[1]
sigs.add((parts[1], '~' ,parts[0], file))
elif len(parts) == 4:
sigs.add((parts[1], parts[2], parts[0], file))
else:
print('not a function sig: {}'.format(line))
return sigs
def main():
if len(sys.argv) > 2:
stan_major = int(sys.argv[1])
stan_minor = int(sys.argv[2])
outfile_name = 'stan-functions-{}_{}.txt'.format(str(stan_major), str(stan_minor))
else:
try:
bash_git_hash = ['git', 'rev-parse', 'HEAD']
git_hash = subprocess.run(bash_git_hash, stdout=subprocess.PIPE, universal_newlines=True).stdout
outfile_name = 'stan-functions-{}.txt'.format(str(git_hash).strip())
except OSError:
print('Stan version not found and Git not found! Either install Git or add 2 arguments <MAJOR> <MINOR> version numbers')
sys.exit(1)
sigs = map(lambda x: f'{x[0]}; {x[1]}; {x[2]}', get_sigs())
with open(outfile_name, 'w') as outfile:
outfile.write('# This file is semicolon delimited\n')
outfile.write('StanFunction; Arguments; ReturnType\n')
for sig in sorted(sigs):
outfile.write(sig)
outfile.write('\n')
if __name__ == '__main__':
main()