mitsuba/doc/gendoc.py

49 lines
1.3 KiB
Python
Raw Normal View History

#! /usr/bin/python
#
# This script walks through all plugin files and
# extracts documentation that should go into the
# reference manual
import os, re
def process(target, filename):
f = open(filename)
inheader = False
for line in f.readlines():
match = re.match(r'^/\*!(.*)$', line)
if match != None:
print("Processing %s" % filename)
line = match.group(1).replace('%', '\%')
target.write(line + '\n')
inheader = True
continue
if not inheader:
continue
if re.search(r'^[\s\*]*\*/$', line):
inheader = False
continue
match = re.match(r'^\s*\**(.*)$', line)
if match != None:
line = match.group(1).replace('%', '\%')
target.write(line + '\n')
f.close()
# Traverse all source directories and find any plugin code
def traverse(target, dirname, files):
suffix = os.path.split(dirname)[1]
if 'lib' in suffix or suffix == 'tests' \
or suffix == 'mitsuba' or suffix == 'utils' \
or suffix == 'converter' or suffix == 'qtgui':
return
for filename in files:
if '.cpp' == os.path.splitext(filename)[1]:
process(target,os.path.join(dirname, filename))
os.chdir(os.path.dirname(__file__))
f = open('plugins_generated.tex', 'w')
f.write('\section{Plugin reference}\n')
os.path.walk('../src', traverse, f)
f.close()
os.system('pdflatex main.tex')