from xml.dom.core import \
ELEMENT, \
+ ENTITY_REFERENCE, \
TEXT
def get_first_element(doc, gi):
for n in doc.childNodes:
- if n.nodeName == gi:
+ if n.get_nodeName() == gi:
return n
def extract_first_element(doc, gi):
def find_all_elements(doc, gi):
nodes = []
- if doc.nodeName == gi:
+ if doc.get_nodeName() == gi:
nodes.append(doc)
for child in doc.childNodes:
if child.nodeType == ELEMENT:
- if child.tagName == gi:
+ if child.get_tagName() == gi:
nodes.append(child)
for node in child.getElementsByTagName(gi):
nodes.append(node)
def find_all_child_elements(doc, gi):
nodes = []
for child in doc.childNodes:
- if child.nodeName == gi:
+ if child.get_nodeName() == gi:
nodes.append(child)
return nodes
return __find_all_elements_from_set(doc, gi_set, [])
def __find_all_elements_from_set(doc, gi_set, nodes):
- if doc.nodeName in gi_set:
+ if doc.get_nodeName() in gi_set:
nodes.append(doc)
for child in doc.childNodes:
- if child.nodeType == ELEMENT:
+ if child.get_nodeType() == ELEMENT:
__find_all_elements_from_set(child, gi_set, nodes)
return nodes
docelem.insertBefore(text, docelem.firstChild)
docelem.insertBefore(node, text)
docelem.insertBefore(doc.createTextNode("\n"), docelem.firstChild)
- while fragment.firstChild and fragment.firstChild.nodeType == TEXT:
+ while fragment.firstChild and fragment.firstChild.get_nodeType() == TEXT:
fragment.removeChild(fragment.firstChild)
for n in doc.childNodes:
prevskip = skip
skip = 0
- if n.nodeType == TEXT and not prevskip:
+ if n.get_nodeType() == TEXT and not prevskip:
discards.append(n)
- elif n.nodeName == "COMMENT":
+ elif n.get_nodeName() == "COMMENT":
skip = 1
for node in discards:
doc.removeChild(node)
def find_and_fix_descriptors(doc, container):
children = container.childNodes
for child in children:
- if child.nodeType == ELEMENT:
- tagName = child.tagName
+ if child.get_nodeType() == ELEMENT:
+ tagName = child.get_tagName()
if tagName in DESCRIPTOR_ELEMENTS:
rewrite_descriptor(doc, child)
elif tagName == "subsection":
# 6. Put it back together.
#
# 1.
- descname = descriptor.tagName
+ descname = descriptor.get_tagName()
index = 1
if descname[-2:] == "ni":
descname = descname[:-2]
pos = skip_leading_nodes(children)
if pos < len(children):
child = children[pos]
- if child.nodeName == "args":
+ if child.get_nodeName() == "args":
## bwrite("found <args> in descriptor, moving to <signature>\n")
## ewrite(descriptor.toxml() + "\n---\n")
# create an <args> in <signature>:
# 3, 4.
pos = skip_leading_nodes(children, pos)
while pos < len(children) \
- and children[pos].nodeName in (linename, "versionadded"):
- if children[pos].tagName == linename:
+ and children[pos].get_nodeName() in (linename, "versionadded"):
+ if children[pos].get_tagName() == linename:
# this is really a supplemental signature, create <signature>
sig = methodline_to_signature(doc, children[pos])
newchildren.append(sig)
def handle_appendix(doc, fragment):
# must be called after simplfy() if document is multi-rooted to begin with
docelem = get_documentElement(fragment)
- toplevel = docelem.tagName == "manual" and "chapter" or "section"
+ toplevel = docelem.get_tagName() == "manual" and "chapter" or "section"
appendices = 0
nodes = []
for node in docelem.childNodes:
if not id:
continue
parent = label.parentNode
- if parent.tagName == "title":
+ parentTagName = parent.get_tagName()
+ if parentTagName == "title":
parent.parentNode.setAttribute("id", id)
else:
parent.setAttribute("id", id)
# now, remove <label id="..."/> from parent:
parent.removeChild(label)
- if parent.tagName == "title":
+ if parentTagName == "title":
parent.normalize()
children = parent.childNodes
if children[-1].nodeType == TEXT:
while queue:
node = queue[0]
del queue[0]
- if wsmap.has_key(node.nodeName):
- ws = wsmap[node.tagName]
+ if wsmap.has_key(node.get_nodeName()):
+ ws = wsmap[node.get_tagName()]
children = node.childNodes
children.reverse()
if children[0].nodeType == TEXT:
children[0].data = data
children.reverse()
# hack to get the title in place:
- if node.tagName == "title" \
- and node.parentNode.firstChild.nodeType == ELEMENT:
+ if node.get_tagName() == "title" \
+ and node.parentNode.firstChild.get_nodeType() == ELEMENT:
node.parentNode.insertBefore(doc.createText("\n "),
node.parentNode.firstChild)
for child in node.childNodes:
while queue:
node = queue[0]
del queue[0]
- if rewrite_element(node.tagName):
+ if rewrite_element(node.get_tagName()):
children = node.childNodes
if len(children) == 1 \
and children[0].nodeType == TEXT:
if nodeType != r.nodeType:
return 0
if nodeType == ELEMENT:
- if l.tagName != r.tagName:
+ if l.get_tagName() != r.get_tagName():
return 0
# should check attributes, but that's not a problem here
if not contents_match(l, r):
modauthor.getAttribute("name")))
modauthor.removeAttribute("name")
platform = extract_first_element(section, "platform")
- if section.tagName == "section":
+ if section.get_tagName() == "section":
modinfo_pos = 2
modinfo = doc.createElement("moduleinfo")
moddecl = extract_first_element(section, "declaremodule")
if title:
children = title.childNodes
if len(children) >= 2 \
- and children[0].nodeName == "module" \
+ and children[0].get_nodeName() == "module" \
and children[0].childNodes[0].data == name:
# this is it; morph the <title> into <short-synopsis>
first_data = children[1]
children = section.childNodes
for i in range(len(children)):
node = children[i]
- if node.nodeName == "moduleinfo":
+ if node.get_nodeName() == "moduleinfo":
nextnode = children[i+1]
if nextnode.nodeType == TEXT:
data = nextnode.data
children = table.childNodes
for child in children:
if child.nodeType == ELEMENT:
- tagName = child.tagName
+ tagName = child.get_tagName()
if tagName == "hline" and prev_row is not None:
prev_row.setAttribute("rowsep", "1")
elif tagName == "row":
table.removeChild(child)
continue
if nodeType == ELEMENT:
- if child.tagName != "hline":
+ if child.get_tagName() != "hline":
raise ConversionError(
- "unexpected <%s> in table" % child.tagName)
+ "unexpected <%s> in table" % child.get_tagName())
table.removeChild(child)
continue
raise ConversionError(
def move_elements_by_name(doc, source, dest, name, sep=None):
nodes = []
for child in source.childNodes:
- if child.nodeName == name:
+ if child.get_nodeName() == name:
nodes.append(child)
for node in nodes:
source.removeChild(node)
def fixup_paras(doc, fragment):
for child in fragment.childNodes:
- if child.nodeName in RECURSE_INTO_PARA_CONTAINERS:
+ if child.get_nodeName() in RECURSE_INTO_PARA_CONTAINERS:
fixup_paras_helper(doc, child)
descriptions = find_all_elements(fragment, "description")
for description in descriptions:
children = container.childNodes
start = skip_leading_nodes(children)
while len(children) > start:
- if children[start].nodeName in RECURSE_INTO_PARA_CONTAINERS:
+ if children[start].get_nodeName() in RECURSE_INTO_PARA_CONTAINERS:
# Something to recurse into:
fixup_paras_helper(doc, children[start])
else:
child = children[j]
nodeType = child.nodeType
if nodeType == ELEMENT:
- if child.tagName in BREAK_ELEMENTS:
+ if child.get_tagName() in BREAK_ELEMENTS:
after = j
break
elif nodeType == TEXT:
return start
# all whitespace, just skip
elif nodeType == ELEMENT:
- tagName = child.tagName
+ tagName = child.get_tagName()
if tagName in RECURSE_INTO_PARA_CONTAINERS:
return start
if tagName not in PARA_LEVEL_ELEMENTS + PARA_LEVEL_PRECEEDERS:
def fixup_args(doc, arglist):
for child in arglist.childNodes:
- if child.nodeName == "optional":
+ if child.get_nodeName() == "optional":
# found it; fix and return
arglist.insertBefore(doc.createTextNode("["), child)
optkids = child.childNodes
sectauth.removeAttribute("name")
after = section.childNodes[2]
title = section.childNodes[1]
- if title.nodeName != "title":
+ if title.get_nodeName() != "title":
after = section.childNodes[0]
section.insertBefore(doc.createTextNode("\n "), after)
section.insertBefore(sectauth, after)
def fixup_refmodindexes_chunk(container):
# node is probably a <para>; let's see how often it isn't:
- if container.tagName != PARA_ELEMENT:
+ if container.get_tagName() != PARA_ELEMENT:
bwrite("--- fixup_refmodindexes_chunk(%s)\n" % container)
module_entries = find_all_elements(container, "module")
if not module_entries:
children = entry.childNodes
if len(children) != 0:
bwrite("--- unexpected number of children for %s node:\n"
- % entry.tagName)
+ % entry.get_tagName())
ewrite(entry.toxml() + "\n")
continue
found = 0
for node in doc.childNodes:
nodeType = node.nodeType
if nodeType == ELEMENT:
- gi = node.tagName
+ gi = node.get_tagName()
if knownempty(gi):
if node.hasChildNodes():
raise ValueError, \
ofp.write(")%s\n" % gi)
elif nodeType == TEXT:
ofp.write("-%s\n" % esistools.encode(node.data))
+ elif nodeType == ENTITY_REFERENCE:
+ ofp.write("&%s\n" % node.get_nodeName())
else:
raise RuntimeError, "unsupported node type: %s" % nodeType