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.gui.jmol;
022
023import org.biojava.nbio.structure.*;
024
025import java.util.regex.Matcher;
026import java.util.regex.Pattern;
027
028public class JmolTools {
029
030        /** get jmol style info:
031         *  jmol style: [MET]508:A.CA/1 #3918
032         *  insertion code: [ASP]1^A:A.CA/1 #2
033         * @param a .. the Atom
034         *
035         * @return a String representation in Jmol style of the PDB information of this atom
036         */
037        public static final String getPdbInfo(Atom a){
038                return getPdbInfo(a,true);
039        }
040
041        private static Pattern inscodePatter ;
042        static {
043                inscodePatter = Pattern.compile("([0-9]+)([a-zA-Z]*)?");
044        }
045        public static void main(String[] args){
046
047                Chain c = new ChainImpl();
048                c.setId("X");
049
050                Group g = new AminoAcidImpl();
051                g.setResidueNumber(ResidueNumber.fromString("1A"));
052                try {
053                        g.setPDBName("ALA");
054                } catch (Exception e){}
055                Atom a = new AtomImpl();
056                a.setName("CA");
057                g.addAtom(a);
058                c.addGroup(g);
059
060                System.out.println(getPdbInfo(a));
061        }
062
063
064        // TODO: move this to AtomInfo class
065
066        public static final String getPdbInfo(Atom a, boolean printResName){
067                String aa3 = "";
068
069                String chain1 ="";
070                String res1 = "";
071
072                if ( a != null){
073                        Group g1 = a.getGroup();
074                        if ( g1 != null){
075                                aa3 = g1.getPDBName();
076                                res1 = g1.getResidueNumber().toString();
077                                Chain ch1 = g1.getChain();
078                                if (ch1 != null)
079                                        chain1 = ch1.getId();
080                        }
081                }
082
083                StringBuffer buf = new StringBuffer();
084                if ( printResName) {
085                        if ( !"".equals(aa3)){
086                                buf.append("[");
087                                buf.append(aa3);
088                                buf.append("]");
089                        }
090                }
091                if ( ! "".equals(res1)) {
092
093                        // let's check if there is an insertion code...
094                        Matcher matcher = inscodePatter.matcher(res1);
095
096                        boolean found = matcher.find();
097                        if ( ! found) {
098                                System.err.println("JmolTools: could not parse the residue number string " + res1);
099                                buf.append(res1);
100                        } else {
101                                String residueNumber = matcher.group(1);
102                                String insCode = matcher.group(2);
103                                buf.append(residueNumber);
104                                if ( insCode != null && ! "".equals(insCode)) {
105                                        buf.append("^");
106                                        buf.append(insCode);
107                                }
108                        }
109
110                }
111
112
113
114
115                if ( ! "".equals(chain1)){
116                        buf.append(":");
117                        buf.append(chain1);
118                }
119                return buf.toString();
120        }
121}