| #!/usr/bin/env python | 
 | # | 
 | # Copyright 2007 Google Inc. | 
 | # | 
 | # Licensed under the Apache License, Version 2.0 (the "License"); | 
 | # you may not use this file except in compliance with the License. | 
 | # You may obtain a copy of the License at | 
 | # | 
 | #     http://www.apache.org/licenses/LICENSE-2.0 | 
 | # | 
 | # Unless required by applicable law or agreed to in writing, software | 
 | # distributed under the License is distributed on an "AS IS" BASIS, | 
 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | # See the License for the specific language governing permissions and | 
 | # limitations under the License. | 
 | # | 
 |  | 
 | """Routines and a class for describing and manipulating data from a | 
 | TableOfContents wiki page. | 
 | """ | 
 |  | 
 | nodes = {} | 
 | def lookup(wikiWord): | 
 |   if nodes.has_key(wikiWord): | 
 |     return nodes[wikiWord] | 
 |   else: | 
 |     return None | 
 |  | 
 | class TOCNode: | 
 |   def __init__(self, caption, wikiWord=None): | 
 |     self.caption = caption | 
 |     self.wikiWord = wikiWord | 
 |     self.children = [] | 
 |  | 
 |     if(wikiWord): | 
 |       nodes[wikiWord] = self | 
 |  | 
 |   def addChild(self, child): | 
 |     self.children.append(child) | 
 |  | 
 |   def AsTree(self): | 
 |     out = {"caption":self.caption, "wikiword":self.wikiWord} | 
 |  | 
 |     if(not self.children): | 
 |       out["children"] = None | 
 |     else: | 
 |       out["children"] = map(TOCNode.AsTree, self.children) | 
 |  | 
 |     return out | 
 |  | 
 |   def __repr__(self): | 
 |     return str(self) | 
 |  | 
 |   def __str__(self): | 
 |     return "(((%s)))" % self.caption |