2016-09-10 00:48:24 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import re
|
|
|
|
import os
|
|
|
|
|
|
|
|
import pprint
|
|
|
|
|
|
|
|
tsq_path = os.path.join(os.path.dirname(__file__),'../conf/uts-server.cnf')
|
|
|
|
|
|
|
|
docs = {}
|
|
|
|
|
|
|
|
text_buf = ""
|
|
|
|
cur_section = ""
|
|
|
|
|
2016-09-10 03:10:21 +02:00
|
|
|
|
|
|
|
|
2016-09-10 00:48:24 +02:00
|
|
|
with open(tsq_path) as f:
|
|
|
|
for line in f.readlines():
|
|
|
|
m = re.search('\[ (\w+) \]', line)
|
|
|
|
if m:
|
|
|
|
section = m.group(1)
|
|
|
|
docs[section] = {'text': text_buf, 'vars': {}}
|
|
|
|
cur_section = section
|
|
|
|
text_buf = ""
|
|
|
|
|
2016-09-10 03:10:21 +02:00
|
|
|
m = re.search('^#[\s](.*)', line)
|
2016-09-10 00:48:24 +02:00
|
|
|
if m:
|
|
|
|
text = m.group(1)
|
|
|
|
if text_buf:
|
2016-09-10 03:22:04 +02:00
|
|
|
text_buf += '\n'
|
2016-09-10 00:48:24 +02:00
|
|
|
text_buf += text
|
|
|
|
|
2016-09-10 03:10:21 +02:00
|
|
|
m = re.search('^#?([^\s]*)\s*=\s*(.*)', line)
|
2016-09-10 00:48:24 +02:00
|
|
|
if m:
|
|
|
|
var = m.group(1)
|
2016-09-10 03:10:21 +02:00
|
|
|
ex_val = m.group(2)
|
|
|
|
docs[cur_section]['vars'][var] = {'desc': text_buf, 'val': ex_val}
|
2016-09-10 00:48:24 +02:00
|
|
|
text_buf = ""
|
|
|
|
|
|
|
|
#print docs
|
2016-09-10 03:10:21 +02:00
|
|
|
max_var = 0
|
|
|
|
max_desc = 0
|
|
|
|
max_val = 0
|
|
|
|
max_section = 0
|
|
|
|
|
2016-09-10 00:48:24 +02:00
|
|
|
for section in docs:
|
2016-09-10 03:10:21 +02:00
|
|
|
max_section = max(len(docs[section]['text']), max_section)
|
|
|
|
for var in docs[section]['vars']:
|
|
|
|
if docs[section]['vars'][var]:
|
|
|
|
max_var = max(len(var), max_var)
|
|
|
|
for line in docs[section]['vars'][var]['desc'].split('\n'):
|
|
|
|
max_desc = max(len(line), max_desc)
|
|
|
|
max_val = max(len(docs[section]['vars'][var]['val']), max_val)
|
|
|
|
|
|
|
|
def print_line(var, desc, val):
|
|
|
|
print(\
|
|
|
|
'| ' + var + ' ' * (max_var - len(var)) + \
|
|
|
|
' | ' + desc + ' ' * (max_desc - len(desc)) + \
|
|
|
|
' | ' + val + ' ' * (max_val - len(val)) + \
|
|
|
|
' |')
|
|
|
|
|
|
|
|
|
|
|
|
for section in sorted(docs):
|
|
|
|
print(section)
|
|
|
|
print('~' * len(section))
|
2016-09-10 00:48:24 +02:00
|
|
|
print('')
|
|
|
|
print(docs[section]['text'])
|
|
|
|
print('')
|
2016-09-10 03:10:21 +02:00
|
|
|
print('+-' + '-' * max_var + '-+-' + '-' * max_desc + '-+-' + '-' * max_val + '-+')
|
|
|
|
print_line('param', 'description', 'example value')
|
|
|
|
print('+=' + '=' * max_var + '=+=' + '=' * max_desc + '=+=' + '=' * max_val + '=+')
|
|
|
|
for var in sorted(docs[section]['vars']):
|
2016-09-10 00:48:24 +02:00
|
|
|
if docs[section]['vars'][var]:
|
2016-09-10 03:10:21 +02:00
|
|
|
first = True
|
|
|
|
for line in docs[section]['vars'][var]['desc'].split('\n'):
|
|
|
|
if first:
|
|
|
|
first = False
|
2016-09-10 03:22:04 +02:00
|
|
|
print_line(
|
|
|
|
re.sub('\*', '\\*', var),
|
|
|
|
re.sub('\*', '\\*', line),
|
|
|
|
re.sub('\*', '\\*', docs[section]['vars'][var]['val']),
|
|
|
|
)
|
2016-09-10 03:10:21 +02:00
|
|
|
else:
|
2016-09-10 03:22:04 +02:00
|
|
|
print_line('', re.sub('\*', '\\*', line), '')
|
2016-09-10 03:10:21 +02:00
|
|
|
print('+-' + '-' * max_var + '-+-' + '-' * max_desc + '-+-' + '-' * max_val + '-+')
|
2016-09-10 00:48:24 +02:00
|
|
|
print('')
|