001/* 002 * BioJava development code 003 * 004 * This code may be freely distributed and modified under the 005 * terms of the GNU Lesser General Public Licence. This should 006 * be distributed with the code. If you do not have a copy, 007 * see: 008 * 009 * http://www.gnu.org/copyleft/lesser.html 010 * 011 * Copyright for this code is held jointly by the individual 012 * authors. These should be listed in @author doc comments. 013 * 014 * For more information on the BioJava project and its aims, 015 * or to join the biojava-l mailing list, visit the home page 016 * at: 017 * 018 * http://www.biojava.org/ 019 * 020 */ 021package org.biojava.nbio.structure.align.xml; 022 023import org.biojava.nbio.structure.align.client.PdbPair; 024import org.biojava.nbio.structure.align.fatcat.FatCatRigid; 025import org.biojava.nbio.core.util.PrettyXMLWriter; 026import org.w3c.dom.Document; 027import org.w3c.dom.NamedNodeMap; 028import org.w3c.dom.Node; 029import org.w3c.dom.NodeList; 030import org.xml.sax.InputSource; 031 032import javax.xml.parsers.DocumentBuilder; 033import javax.xml.parsers.DocumentBuilderFactory; 034import java.io.IOException; 035import java.io.PrintWriter; 036import java.io.StringReader; 037import java.io.StringWriter; 038import java.util.SortedSet; 039import java.util.TreeSet; 040 041public class PdbPairXMLConverter { 042 043 044 public static final String DEFAULT_METHOD_NAME = FatCatRigid.algorithmName; 045 046 public static PdbPairsMessage convertXMLtoPairs(String xml) { 047 SortedSet<PdbPair> pairs = new TreeSet<>(); 048 PdbPairsMessage message = new PdbPairsMessage(); 049 try 050 { 051 //Convert string to XML document 052 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); 053 DocumentBuilder db = factory.newDocumentBuilder(); 054 InputSource inStream = new InputSource(); 055 inStream.setCharacterStream(new StringReader(xml)); 056 Document doc = db.parse(inStream); 057 058 // normalize text representation 059 doc.getDocumentElement().normalize(); 060 061 NodeList algorithms = doc.getElementsByTagName("pairs"); 062 //System.out.println(algorithms.getLength()); 063 for(int i=0; i<algorithms.getLength() ; i++) { 064 065 Node algo = algorithms.item(i); 066 067 NamedNodeMap map = algo.getAttributes(); 068 069 String name = map.getNamedItem("algorithm").getTextContent(); 070 071 if ( name != null) { 072 073 message.setMethod(name); 074 075 } 076 077 } 078 079 080 NodeList listOfPairs = doc.getElementsByTagName("pair"); 081 //System.out.println(listOfPairs.getLength()); 082 083 // go over the blocks 084 for(int i=0; i<listOfPairs.getLength() ; i++) 085 { 086 Node pair = listOfPairs.item(i); 087 //NodeList valList = pair.getChildNodes(); 088 //int numChildren = valList.getLength(); 089 090 NamedNodeMap map = pair.getAttributes(); 091 092 String name1 = map.getNamedItem("name1").getTextContent(); 093 String name2 = map.getNamedItem("name2").getTextContent(); 094 PdbPair pdbPair = new PdbPair(name1, name2); 095 pairs.add(pdbPair); 096 } 097 098 } catch (Exception e){ 099 e.printStackTrace(); 100 } 101 message.setPairs(pairs); 102 return message; 103 } 104 105 public static String convertPairsToXML(SortedSet<PdbPair> pairs, String method){ 106 StringWriter sw = new StringWriter(); 107 PrintWriter writer = new PrintWriter(sw); 108 109 if (method == null){ 110 method = DEFAULT_METHOD_NAME; 111 } 112 113 114 PrettyXMLWriter xml = new PrettyXMLWriter(writer); 115 try { 116 117 118 xml.openTag("pairs"); 119 xml.attribute("algorithm", method); 120 for ( PdbPair pair : pairs){ 121 xml.openTag("pair"); 122 xml.attribute("name1", pair.getName1()); 123 xml.attribute("name2", pair.getName2()); 124 xml.closeTag("pair"); 125 } 126 xml.closeTag("pairs"); 127 } catch(IOException ex){ 128 ex.printStackTrace(); 129 } 130 131 return sw.toString(); 132 } 133 134 135}