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.protmod.io; 022 023import org.biojava.nbio.protmod.Component; 024import org.biojava.nbio.core.util.PrettyXMLWriter; 025import org.w3c.dom.NamedNodeMap; 026import org.w3c.dom.Node; 027import org.w3c.dom.NodeList; 028 029import java.io.IOException; 030import java.io.PrintWriter; 031import java.io.StringWriter; 032import java.util.HashSet; 033import java.util.Set; 034 035 036public class ComponentXMLConverter { 037 public static String toXML(Component component) throws IOException{ 038 StringWriter out = new StringWriter(); 039 040 PrettyXMLWriter xml = new PrettyXMLWriter(new PrintWriter(out)); 041 toXML(component, xml); 042 043 return out.toString(); 044 } 045 046 public static void toXML(Component component, PrettyXMLWriter xml) throws IOException{ 047 xml.openTag("component"); 048 049 xml.attribute("nTerminal" , component.isNTerminal()+""); 050 xml.attribute("cTerminal", component.isCTerminal()+""); 051 for (String pdbccId : component.getPdbccIds()){ 052 xml.openTag("pdbccID"); 053 xml.attribute("id", pdbccId); 054 xml.closeTag("pdbccID"); 055 } 056 057 xml.closeTag("component"); 058 } 059 060 public static Component fromXML(String xml){ 061 return null; 062 } 063 064 public static Component fromXML(Node componentN) { 065 066 String name = componentN.getNodeName(); 067 if ( ! "component".equals(name)) 068 throw new RuntimeException("did not get component element, but " + name); 069 070 //String type = getAttribute(componentN, "type"); 071 String nTerminalS = getAttribute(componentN, "nTerminal"); 072 String cTerminalS = getAttribute(componentN, "cTerminal"); 073 074 boolean isNTerminal = Boolean.parseBoolean(nTerminalS); 075 boolean isCTerminal = Boolean.parseBoolean(cTerminalS); 076 077 Set<String>pdbccIds = new HashSet<>(); 078 079 NodeList valList = componentN.getChildNodes(); 080 int numChildren = valList.getLength(); 081 082 083 for ( int e =0; e< numChildren ; e++){ 084 Node pdbccN = valList.item(e); 085 086 if(!pdbccN.hasAttributes()) continue; 087 088 089 if ( "pdbccID".equals(pdbccN.getNodeName())) { 090 String id = getAttribute(pdbccN, "id"); 091 pdbccIds.add(id); 092 } 093 094 } 095 096 Component c = Component.of(pdbccIds, isNTerminal, isCTerminal); 097 return c; 098 099 } 100 101 private static String getAttribute(Node node, String attr){ 102 if( ! node.hasAttributes()) 103 return null; 104 105 NamedNodeMap atts = node.getAttributes(); 106 107 if ( atts == null) 108 return null; 109 110 Node att = atts.getNamedItem(attr); 111 if ( att == null) 112 return null; 113 114 String value = att.getTextContent(); 115 116 return value; 117 118 } 119}