Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
99992fcd31
1 changed files with 59 additions and 0 deletions
|
@ -0,0 +1,59 @@
|
||||||
|
package net.osmand.render;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
|
import javax.xml.transform.Transformer;
|
||||||
|
import javax.xml.transform.TransformerException;
|
||||||
|
import javax.xml.transform.TransformerFactory;
|
||||||
|
import javax.xml.transform.dom.DOMSource;
|
||||||
|
import javax.xml.transform.stream.StreamResult;
|
||||||
|
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
import org.w3c.dom.NamedNodeMap;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
import org.w3c.dom.NodeList;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
|
public class RenderingRulesTransformer {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException, TransformerException {
|
||||||
|
if(args.length == 0) {
|
||||||
|
System.out.println("Please specify source and target file path.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String srcFile = args[0];
|
||||||
|
String targetFile = args[1];
|
||||||
|
DocumentBuilder db = DocumentBuilderFactory.newInstance().newDocumentBuilder();
|
||||||
|
Document document = db.parse(new File(srcFile));
|
||||||
|
transform(document);
|
||||||
|
TransformerFactory transformerFactory = TransformerFactory.newInstance();
|
||||||
|
Transformer transformer = transformerFactory.newTransformer();
|
||||||
|
DOMSource source = new DOMSource(document.getDocumentElement());
|
||||||
|
StreamResult streamResult = new StreamResult(new File(targetFile));
|
||||||
|
transformer.transform(source, streamResult);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static void transform(Document document) {
|
||||||
|
NodeList nl = document.getElementsByTagName("ifelse");
|
||||||
|
while(nl.getLength() > 0) {
|
||||||
|
Element old = (Element) nl.item(0);
|
||||||
|
Element newElement = document.createElement("filter");
|
||||||
|
while(old.getChildNodes().getLength() > 0) {
|
||||||
|
newElement.appendChild(old.getChildNodes().item(0));
|
||||||
|
}
|
||||||
|
NamedNodeMap attrs = old.getAttributes();
|
||||||
|
for(int i = 0; i < attrs.getLength(); i++) {
|
||||||
|
Node ns = attrs.item(i);
|
||||||
|
newElement.setAttribute(ns.getNodeName(), ns.getNodeValue());
|
||||||
|
}
|
||||||
|
((Element)old.getParentNode()).replaceChild(newElement, old);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue