11 from amara import bindery
12 from amara.xslt import transform
13 from Cheetah.Template import Template
15 parser = argparse.ArgumentParser(description='Process docbook article tree.')
16 parser.add_argument('--style', nargs='?',
17 default=os.path.dirname(os.getcwd())+'/style/default/')
18 parser.add_argument('--output', nargs='?',
19 default=os.path.dirname(os.getcwd())+'/htdocs/')
20 args = parser.parse_args()
22 style_xslt = args.style+"docbook.xsl"
23 style_tmpl = args.style+"index.en.html.tmpl"
24 outputdir = args.output
26 valid_scripts = ['.py','.pl']
32 except OSError as exc: # Python >2.5
33 if exc.errno == errno.EEXIST:
37 def generateSitemap():
40 sfile = open('sitemap.txt')
41 flist = sfile.read().split()
44 sitemap.append(dict(link=f))
45 except IOError, what_error:
46 print 'Sitemap missing - generating one.'
47 for dirname, dirnames, filenames in os.walk('.'):
48 for filename in filenames:
49 if fnmatch.fnmatch(filename, '*.xml'):
50 xfile = os.path.join(dirname,filename)
51 doc = bindery.parse(xfile,
52 prefixes={u'db': u'http://docbook.org/ns/docbook',
53 u'xi': u'http://www.w3.org/2001/XInclude'})
54 title = doc.xml_select(u'/db:article/db:info/db:title')
55 menu = doc.xml_select(u'/db:article/db:info/db:titleabbrev')
56 code = doc.xml_select(u"//xi:include[@parse='text']")
59 (p, ext) = os.path.splitext(c.href)
60 if ext in valid_scripts:
65 base = xfile.split('.')[1]
66 link = base.replace('index','')
67 level = len(filter(None,re.split(r'(/\w*/)',link)))
68 page = dict(title=unicode(doc.article.info.title),
69 menu=unicode(doc.article.info.titleabbrev),
70 output=os.path.join(dirname,filename.replace('xml','html')),
79 print "adding "+link+" to sitemap"
83 sfile = open('sitemap.txt','w')
85 sfile.write(l['link']+'\n')
89 def expandXincludeTxt(page):
90 doc = bindery.parse(page['file'],prefixes={u'db': u'http://docbook.org/ns/docbook',
91 u'xi': u'http://www.w3.org/2001/XInclude'})
93 code = doc.xml_select(u"//xi:include[@parse='text']")
95 (p, ext) = os.path.splitext(c.href)
96 if ext in valid_scripts:
97 exe = os.path.join(os.path.abspath(c.href))
98 xml = subprocess.Popen([exe],stdout=subprocess.PIPE)
99 xstr = bindery.parse(str(xml.stdout.read()))
100 id = c.xml_index_on_parent
101 for x in xstr.xml_children:
102 c.xml_parent.xml_insert(id,x)
103 c.xml_parent.xml_remove(c)
106 def xsltConvert(doc):
107 # amara can not handle the docbook stylesheets
108 # xmlarticle = transform(doc,style_xslt)
110 rundir = os.path.dirname(page['file'])
112 infile = os.path.basename(tempfile.mktemp())
113 outfile = tempfile.mktemp()
114 tfi = open(infile,'w')
115 tfi.write(doc.xml_encode())
117 # cmd = ["saxon-xslt-xinclude","-o",outfile,infile,style_xslt]
118 cmd = ["xsltproc","--xinclude","--output",outfile,style_xslt,infile]
119 retcode = subprocess.call(cmd)
121 print 'Error: '+' '.join(cmd)+' Returncode ['+str(retcode)+']'
122 tfo = open(outfile,'r')
130 def genMenu(page,sitemap,slevel,elevel):
133 if elevel == MAXLEVEL or elevel == 1:
136 idx = sitemap.index(page)
137 while (sitemap[idx]['level'] == page['level']):
139 title = sitemap[idx]['menu']
141 while (idx < len(sitemap) and sitemap[idx]['level'] == page['level']):
142 sm.append(sitemap[idx])
147 if slevel > p['level'] or elevel < p['level']:
149 if not title and p['link'] == '/':
152 if oldlevel < p['level']:
154 elif oldlevel > p['level']:
155 if p['link'][-1] == '/':
157 html+='</ul>\n</li>\n'
159 html+='<li><a href="%s">[%s]</a>' % (p['link'],p['menu'])
161 html+='<li><a href="%s">%s</a>' % (p['link'],p['menu'])
162 if p['link'][-1] != '/' or p['link'] == '/':
164 oldlevel = p['level']
168 def writeToTemplate(page,doc,sitemap):
169 (menu,menuname) = genMenu(page,sitemap,1,MAXLEVEL)
170 (levelmenu,levelname) = genMenu(page,sitemap,page['level'],page['level'])
171 template = Template(file=style_tmpl,
172 searchList=[{'menu':menu},
174 {'levelmenu':levelmenu},
175 {'levelname':levelname}])
176 outfile = outputdir+page['output']
177 d = os.path.split(outfile)[0]
180 out = open(outfile, 'w')
181 out.write(str(template))
183 sitemap = generateSitemap()
186 print "Page : "+page['link'],
187 doc = expandXincludeTxt(page)
188 pubdoc = xsltConvert(doc)
189 writeToTemplate(page,pubdoc,sitemap)
192 print "["+str(round(t2-t1,2))+"] done."