#! /usr/bin/python
#
# Copyright 2008, The Android Open Source Project
#
# 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.
#
# This script is used to split the jdiff xml into several smaller xml files
# so that we could avoid the xml resource limit in Android platform.
#
# Usage:
#    android_api_description.py xmlfile tagname
#
# The script will do the following:
#    1. Read the xml file and generate DOM tree
#    2. Generate xml file for each tagname.
#
# Example:
# xml source:
#    
#        
#            1
#            2
#        
#        
#            3
#        
#    
# 
# when the tagname is specified as A, it will generate two xml files:
# first one's source:
#    
#        
#            1
#            2
#        
#    
# second one's source:
#    
#        
#            3
#        
#    
#
# when the tagname is specified as B, it will generated three xml files:
# first one's source:
#    
#        
#            1
#        
#    
# second one's source:
#    
#        
#            2
#        
#    
# third one's source:
#    
#        
#            3
#        
#    
#
# NOTE: 
#    1. Currently just suppor the top level element
#    2. Use the name attribute of the specified element as the file name
#    3. Currently will remove all the doc element. - workaround for jdiff xml
#
import os, sys;
import xml.dom.minidom;
"""Split the jdiff xml into several smaller xml files by specified tag.
"""
class XMLSplitter:
    def __init__(self, xmlfile, outPath):
        self.doc = xml.dom.minidom.parse(xmlfile)
        self.root = self.doc.documentElement
        self.out = os.path.join(outPath, "xml")
        if not os.path.isdir(self.out):
            os.makedirs(self.out)
        return
    def split(self, tag):
        elemlist = self.doc.getElementsByTagName(tag)
        for elem in elemlist:
            elem = self.__trimElem(elem)
            self.__generateFile(elem)
        return
    def __trimElem(self, elem):
        children = []
        for child in elem.childNodes:
            if child.nodeType == xml.dom.minidom.Node.ELEMENT_NODE:
                children.append(child)
        for child in children:
            if child.nodeName == "doc":
                elem.removeChild(child)
                children.remove(child)
        for child in children:
            child = self.__trimElem(child)
        return elem
    def __generateFile(self, elem):
        self.__removeAllChild(self.root)
        filename = os.path.join(self.out, elem.getAttribute("name").replace(".", "_").lower() + ".xml")
        doc = xml.dom.minidom.Document()
        doc.appendChild(self.root)
        self.root.appendChild(elem)
        fd = open(filename, "w")
        fd.write(doc.toxml())
        fd.close
        return
    def __removeAllChild(self, elem):
        children = []
        for child in elem.childNodes:
            children.append(child)
        for child in children:
            elem.removeChild(child)
        return
if __name__ == "__main__":
    if len(sys.argv) < 4:
        print "Usage: splitxml.py xmlfile outpath tagname"
        sys.exit(1)
    xmlsplitter = XMLSplitter(sys.argv[1], sys.argv[2])
    xmlsplitter.split(sys.argv[3])