godot/doc/tools/doc_merge.py

238 lines
6.5 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# -*- coding: utf-8 -*-
2014-02-10 09:10:30 +08:00
import sys
import xml.etree.ElementTree as ET
tree = ET.parse(sys.argv[1])
old_doc = tree.getroot()
2014-02-10 09:10:30 +08:00
tree = ET.parse(sys.argv[2])
new_doc = tree.getroot()
2014-02-10 09:10:30 +08:00
f = file(sys.argv[3], "wb")
tab = 0
2014-02-10 09:10:30 +08:00
old_classes = {}
2014-02-10 09:10:30 +08:00
def write_string(_f, text, newline=True):
for t in range(tab):
_f.write("\t")
_f.write(text)
if newline:
_f.write("\n")
2014-02-10 09:10:30 +08:00
2014-02-10 09:10:30 +08:00
def escape(ret):
ret = ret.replace("&", "&")
ret = ret.replace("<", "&gt;")
ret = ret.replace(">", "&lt;")
ret = ret.replace("'", "&apos;")
ret = ret.replace('"', "&quot;")
return ret
2016-04-03 02:26:12 +08:00
2014-02-10 09:10:30 +08:00
def inc_tab():
global tab
tab += 1
2014-02-10 09:10:30 +08:00
2014-02-10 09:10:30 +08:00
def dec_tab():
global tab
tab -= 1
2014-02-10 09:10:30 +08:00
write_string(f, '<?xml version="1.0" encoding="UTF-8" ?>')
write_string(f, '<doc version="' + new_doc.attrib["version"] + '">')
2014-02-10 09:10:30 +08:00
def get_tag(node, name):
tag = ""
if name in node.attrib:
tag = " " + name + '="' + escape(node.attrib[name]) + '" '
return tag
2014-02-10 09:10:30 +08:00
def find_method_descr(old_class, name):
2016-04-03 02:26:12 +08:00
methods = old_class.find("methods")
if methods != None and len(list(methods)) > 0:
for m in list(methods):
if m.attrib["name"] == name:
description = m.find("description")
if description != None and description.text.strip() != "":
return description.text
2016-04-03 02:26:12 +08:00
return None
2014-02-10 09:10:30 +08:00
def find_signal_descr(old_class, name):
2016-04-03 02:26:12 +08:00
signals = old_class.find("signals")
if signals != None and len(list(signals)) > 0:
for m in list(signals):
if m.attrib["name"] == name:
description = m.find("description")
if description != None and description.text.strip() != "":
return description.text
2016-04-03 02:26:12 +08:00
return None
2014-02-10 09:10:30 +08:00
def find_constant_descr(old_class, name):
2014-02-10 09:10:30 +08:00
if old_class is None:
return None
constants = old_class.find("constants")
if constants != None and len(list(constants)) > 0:
for m in list(constants):
if m.attrib["name"] == name:
if m.text.strip() != "":
return m.text
return None
2014-02-10 09:10:30 +08:00
2014-02-10 09:10:30 +08:00
def write_class(c):
class_name = c.attrib["name"]
print("Parsing Class: " + class_name)
if class_name in old_classes:
old_class = old_classes[class_name]
else:
old_class = None
2014-02-10 09:10:30 +08:00
category = get_tag(c, "category")
inherits = get_tag(c, "inherits")
write_string(f, '<class name="' + class_name + '" ' + category + inherits + ">")
inc_tab()
2016-04-03 02:26:12 +08:00
write_string(f, "<brief_description>")
2014-02-10 09:10:30 +08:00
if old_class != None:
old_brief_descr = old_class.find("brief_description")
if old_brief_descr != None:
write_string(f, escape(old_brief_descr.text.strip()))
2016-04-03 02:26:12 +08:00
write_string(f, "</brief_description>")
2016-04-03 02:26:12 +08:00
write_string(f, "<description>")
if old_class != None:
old_descr = old_class.find("description")
if old_descr != None:
write_string(f, escape(old_descr.text.strip()))
2016-04-03 02:26:12 +08:00
write_string(f, "</description>")
2014-02-10 09:10:30 +08:00
methods = c.find("methods")
if methods != None and len(list(methods)) > 0:
2014-02-10 09:10:30 +08:00
write_string(f, "<methods>")
inc_tab()
2016-04-03 02:26:12 +08:00
for m in list(methods):
qualifiers = get_tag(m, "qualifiers")
2014-02-10 09:10:30 +08:00
write_string(f, '<method name="' + escape(m.attrib["name"]) + '" ' + qualifiers + ">")
inc_tab()
2014-02-10 09:10:30 +08:00
for a in list(m):
if a.tag == "return":
typ = get_tag(a, "type")
write_string(f, "<return" + typ + ">")
write_string(f, "</return>")
elif a.tag == "argument":
2016-04-03 02:26:12 +08:00
default = get_tag(a, "default")
2014-02-10 09:10:30 +08:00
write_string(
f,
'<argument index="'
+ a.attrib["index"]
+ '" name="'
+ escape(a.attrib["name"])
+ '" type="'
+ a.attrib["type"]
+ '"'
+ default
+ ">",
)
write_string(f, "</argument>")
write_string(f, "<description>")
if old_class != None:
old_method_descr = find_method_descr(old_class, m.attrib["name"])
if old_method_descr:
write_string(f, escape(escape(old_method_descr.strip())))
2016-04-03 02:26:12 +08:00
write_string(f, "</description>")
dec_tab()
write_string(f, "</method>")
dec_tab()
write_string(f, "</methods>")
2014-02-10 09:10:30 +08:00
signals = c.find("signals")
if signals != None and len(list(signals)) > 0:
2014-02-10 09:10:30 +08:00
write_string(f, "<signals>")
inc_tab()
2016-04-03 02:26:12 +08:00
for m in list(signals):
2014-02-10 09:10:30 +08:00
write_string(f, '<signal name="' + escape(m.attrib["name"]) + '">')
inc_tab()
2014-02-10 09:10:30 +08:00
for a in list(m):
if a.tag == "argument":
write_string(
f,
'<argument index="'
+ a.attrib["index"]
+ '" name="'
+ escape(a.attrib["name"])
+ '" type="'
+ a.attrib["type"]
+ '">',
)
write_string(f, "</argument>")
write_string(f, "<description>")
if old_class != None:
old_signal_descr = find_signal_descr(old_class, m.attrib["name"])
if old_signal_descr:
write_string(f, escape(old_signal_descr.strip()))
write_string(f, "</description>")
dec_tab()
write_string(f, "</signal>")
dec_tab()
write_string(f, "</signals>")
2014-02-10 09:10:30 +08:00
constants = c.find("constants")
if constants != None and len(list(constants)) > 0:
2014-02-10 09:10:30 +08:00
write_string(f, "<constants>")
inc_tab()
2016-04-03 02:26:12 +08:00
for m in list(constants):
2014-02-10 09:10:30 +08:00
write_string(f, '<constant name="' + escape(m.attrib["name"]) + '" value="' + m.attrib["value"] + '">')
old_constant_descr = find_constant_descr(old_class, m.attrib["name"])
if old_constant_descr:
write_string(f, escape(old_constant_descr.strip()))
write_string(f, "</constant>")
2014-02-10 09:10:30 +08:00
dec_tab()
write_string(f, "</constants>")
2014-02-10 09:10:30 +08:00
dec_tab()
write_string(f, "</class>")
2014-02-10 09:10:30 +08:00
2014-02-10 09:10:30 +08:00
for c in list(old_doc):
old_classes[c.attrib["name"]] = c
2014-02-10 09:10:30 +08:00
for c in list(new_doc):
write_class(c)
write_string(f, "</doc>\n")