#!/usr/bin/env python # -*- coding: utf-8 -*- import sys import xml.etree.ElementTree as ET tree = ET.parse(sys.argv[1]) old_doc = tree.getroot() tree = ET.parse(sys.argv[2]) new_doc = tree.getroot() f = file(sys.argv[3], "wb") tab = 0 old_classes = {} def write_string(_f, text, newline=True): for t in range(tab): _f.write("\t") _f.write(text) if newline: _f.write("\n") def escape(ret): ret = ret.replace("&", "&") ret = ret.replace("<", ">") ret = ret.replace(">", "<") ret = ret.replace("'", "'") ret = ret.replace('"', """) return ret def inc_tab(): global tab tab += 1 def dec_tab(): global tab tab -= 1 write_string(f, '') write_string(f, '') def get_tag(node, name): tag = "" if name in node.attrib: tag = " " + name + '="' + escape(node.attrib[name]) + '" ' return tag def find_method_descr(old_class, name): 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 return None def find_signal_descr(old_class, name): 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 return None def find_constant_descr(old_class, name): 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 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 category = get_tag(c, "category") inherits = get_tag(c, "inherits") write_string(f, '") inc_tab() write_string(f, "") 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())) write_string(f, "") write_string(f, "") if old_class != None: old_descr = old_class.find("description") if old_descr != None: write_string(f, escape(old_descr.text.strip())) write_string(f, "") methods = c.find("methods") if methods != None and len(list(methods)) > 0: write_string(f, "") inc_tab() for m in list(methods): qualifiers = get_tag(m, "qualifiers") write_string(f, '") inc_tab() for a in list(m): if a.tag == "return": typ = get_tag(a, "type") write_string(f, "") write_string(f, "") elif a.tag == "argument": default = get_tag(a, "default") write_string( f, '", ) write_string(f, "") write_string(f, "") 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()))) write_string(f, "") dec_tab() write_string(f, "") dec_tab() write_string(f, "") signals = c.find("signals") if signals != None and len(list(signals)) > 0: write_string(f, "") inc_tab() for m in list(signals): write_string(f, '') inc_tab() for a in list(m): if a.tag == "argument": write_string( f, '', ) write_string(f, "") write_string(f, "") 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, "") dec_tab() write_string(f, "") dec_tab() write_string(f, "") constants = c.find("constants") if constants != None and len(list(constants)) > 0: write_string(f, "") inc_tab() for m in list(constants): write_string(f, '') 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, "") dec_tab() write_string(f, "") dec_tab() write_string(f, "") for c in list(old_doc): old_classes[c.attrib["name"]] = c for c in list(new_doc): write_class(c) write_string(f, "\n")