2011-06-25 09:47:41 +08:00
|
|
|
#! /usr/bin/python
|
|
|
|
#
|
|
|
|
# This script walks through all plugin files and
|
|
|
|
# extracts documentation that should go into the
|
|
|
|
# reference manual
|
|
|
|
|
2011-09-03 01:58:35 +08:00
|
|
|
import os, platform, re
|
2011-06-25 09:47:41 +08:00
|
|
|
|
2011-07-08 06:36:02 +08:00
|
|
|
def findOrderID(filename):
|
|
|
|
f = open(filename)
|
|
|
|
for line in f.readlines():
|
2011-08-22 12:17:55 +08:00
|
|
|
match = re.match(r'.*\\order{([^}]*)}.*', line)
|
2011-07-08 06:36:02 +08:00
|
|
|
if match != None:
|
|
|
|
return int(match.group(1))
|
|
|
|
return 1000
|
|
|
|
|
2011-06-25 09:47:41 +08:00
|
|
|
def process(target, filename):
|
|
|
|
f = open(filename)
|
|
|
|
inheader = False
|
|
|
|
for line in f.readlines():
|
2011-06-25 22:49:26 +08:00
|
|
|
match = re.match(r'^/\*! ?(.*)$', line)
|
2011-06-25 09:47:41 +08:00
|
|
|
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
|
2011-06-25 22:49:26 +08:00
|
|
|
match = re.match(r'^\s*\** ?(.*)$', line)
|
2011-06-25 09:47:41 +08:00
|
|
|
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
|
|
|
|
|
2011-07-08 06:36:02 +08:00
|
|
|
ordering = []
|
2011-06-25 09:47:41 +08:00
|
|
|
for filename in files:
|
|
|
|
if '.cpp' == os.path.splitext(filename)[1]:
|
2011-07-08 06:36:02 +08:00
|
|
|
fname = os.path.join(dirname, filename)
|
|
|
|
ordering = ordering + [(findOrderID(fname), fname)]
|
|
|
|
ordering = sorted(ordering, key = lambda entry: entry[0])
|
|
|
|
|
|
|
|
for entry in ordering:
|
|
|
|
process(target, entry[1])
|
2011-06-25 09:47:41 +08:00
|
|
|
|
2011-09-03 01:58:35 +08:00
|
|
|
# Wrap the walk function to make this work in python 2 and 3.
|
|
|
|
pyVer = int(platform.python_version_tuple()[0])
|
|
|
|
def walk(path, visit, arg):
|
|
|
|
if pyVer >= 3:
|
|
|
|
os.walk(path, visit, arg)
|
|
|
|
else:
|
|
|
|
os.path.walk(path, visit, arg)
|
|
|
|
|
2011-06-25 09:47:41 +08:00
|
|
|
os.chdir(os.path.dirname(__file__))
|
|
|
|
f = open('plugins_generated.tex', 'w')
|
|
|
|
f.write('\section{Plugin reference}\n')
|
2011-08-23 07:41:28 +08:00
|
|
|
f.write('\input{section_shapes}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/shapes', traverse, f)
|
2011-06-25 22:49:26 +08:00
|
|
|
f.write('\input{section_bsdf}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/bsdfs', traverse, f)
|
2011-08-26 05:22:08 +08:00
|
|
|
f.write('\input{section_textures}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/textures', traverse, f)
|
2011-07-17 21:20:55 +08:00
|
|
|
f.write('\input{section_subsurface}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/subsurface', traverse, f)
|
2011-07-17 21:20:55 +08:00
|
|
|
f.write('\input{section_media}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/medium', traverse, f)
|
2011-08-26 05:22:08 +08:00
|
|
|
f.write('\input{section_phase}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/phase', traverse, f)
|
2011-08-27 12:16:09 +08:00
|
|
|
f.write('\input{section_volumes}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/volume', traverse, f)
|
2011-07-27 03:05:43 +08:00
|
|
|
f.write('\input{section_luminaires}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/luminaires', traverse, f)
|
2011-07-02 23:03:57 +08:00
|
|
|
f.write('\input{section_integrators}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/integrators', traverse, f)
|
2011-08-26 12:33:53 +08:00
|
|
|
f.write('\input{section_films}\n')
|
2011-09-03 01:58:35 +08:00
|
|
|
walk('../src/films', traverse, f)
|
2011-06-25 09:47:41 +08:00
|
|
|
f.close()
|
2011-07-01 17:35:49 +08:00
|
|
|
os.system('bibtex main.aux')
|
2012-01-20 08:50:45 +08:00
|
|
|
os.system('pdflatex main.tex | grep -i warning')
|