os.chdir(cwd)
def template(self,sitemap):
- htmlmenu = sitemap.gen_menu(self._lang,None)
- levelmenu = sitemap.gen_menu(self._lang,self)
+ htmlmenu = sitemap.gen_menu(self._lang,None,None)
+ levelmenu = sitemap.gen_menu(self._lang,self,"tree")
template = Template(file=style_tmpl,
searchList=[{'title':self._title},
{'menu':htmlmenu},
{'article':self._rendered_article},
{'levelmenu':levelmenu},
- {'levelname':levelname}])
- outfile = tmptarget+self._file+'.'+self._lang+'.html'
+ {'levelname':'Menu'}])
+ outfile = tmptarget+'html'.join(self._file.rsplit('xml',1))
mkdir_p(os.path.dirname(outfile))
out = open(outfile, 'w')
out.write(str(template))
def inorder(self,t):
for l in t:
yield l.value()
- for ch in l.children():
- self.inorder(ch)
+ for x in self.inorder(l.children()):
+ yield x
def _add(self,trie, key, content):
# is the key a leaf
# G.draw('g.png')
# print G.string()
+ def _menu(self, trie, lang, page, css):
+ html = "<ul%s>\n" % css
+ for l in trie:
+ sel = ''
+ if l.value().page(lang) == page:
+ sel = ' class="selected"'
+ html += '<li%s><a href="%s">%s</a>\n' \
+ % (sel,l.value().link(),l.value().page(lang).menu())
+ html += self._menu(l.children(), lang, page, "")
+ html += "</ul>\n"
+ return html
+
+ def menu(self,lang,page,cssclass):
+ css = ''
+ if cssclass:
+ css = ' class="'+cssclass+'"'
+ return self._menu(self._root, lang, page, css)
+
class Sitemap():
"""Class keeping the internal site structure"""
def __init__(self):
tokens = filter(None,re.split(r'(^/\w*/|\w*/)',link))
self._tree.add(tokens,Link(link))
+ def write_map(self):
+ f = open(self._file,'w')
+ f.write('\n'.join(link.link() for link in self._tree))
+ f.close()
+
def read_map(self):
try:
f = open(self._file)
def set(self):
return set(link.link() for link in self._tree)
+ def process(self):
+ t1 = time.time()
+ for link in self._tree:
+ link.prepare()
+ t2 = time.time()
+ print "Prepare [%5.2f s]" % (round(t2-t1,2))
+ sitelang = set()
+ for link in self._tree:
+ sitelang = lang.union(set(link.languages()))
+ t3 = time.time()
+ print "Language [%5.2f s]" % (round(t3-t2,2))
+ for link in self._tree:
+ link.render()
+ t4 = time.time()
+ print "Render [%5.2f s]" % (round(t4-t3,2))
+ for link in self._tree:
+ link.template(self)
+ t5 = time.time()
+ print "Template [%5.2f s]" % (round(t5-t4,2))
+ sm = {}
+ for l in sitelang:
+ sm[l] = Page((l,'/sitemap'))
+ sm[l].set_article(self.gen_menu(l,None,"tree sitemap"))
+ sm[l].template(self)
+ t6 = time.time()
+ print "Sitemap [%5.2f s]" % (round(t6-t5,2))
+
def graph(self):
self._tree.graph()
- def gen_menu(self,lang,page):
- return 'Generate menu from sitemap - To be implemented'
+ def gen_menu(self,lang,page,cssclass):
+ return self._tree.menu(lang,page,cssclass)
+
+ def publish(self):
+ publish(tmptarget, args.output)
+ publish(args.style+"css", args.output)
+ publish(args.style+"images",args.output)
def generateSitemap():
sitemap = []
removed = sitemap.set() - dir_.set()
for page in removed:
print removed+' pages missing!!'
-
for page in missing:
print 'adding missing page '+page
- sitemap.add_page(page)
-
+ sitemap.add_link(page)
+if len(missing & removed) != 0:
+ print 'writing new sitemap - please adjust if needed'
+ sitemap.write_map()
sitemap.graph()
+sitemap.process()
+
+t1 = time.time()
+sitemap.publish()
+t2 = time.time()
+print "Publish [%5.2f s]" % (round(t2-t1,2))
sitemap = generateSitemap()
tmptarget = tempfile.mkdtemp()+'/'