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 * Created on Jul 25, 2006
021 *
022 */
023package org.biojava.nbio.structure.align.gui.jmol;
024
025import java.util.regex.Matcher;
026import java.util.regex.Pattern;
027
028
029/** This class uniquely describes an atom
030 *
031 * @author Andreas Prlic
032 *
033 */
034public class AtomInfo {
035
036        String chainId;
037        String atomName;
038
039        String residueName;
040        String residueNumber;
041        int modelNumber;
042
043        private static Pattern inscodePatter ;
044        static {
045                inscodePatter = Pattern.compile("([0-9]+)([a-zA-Z]*)?");
046        }
047
048        public AtomInfo() {
049                super();
050
051        }
052
053        public static AtomInfo fromString(String atomInfo){
054                return AtomInfoParser.parse(atomInfo);
055        }
056
057        public int getModelNumber() {
058                return modelNumber;
059        }
060
061        public void setModelNumber(int modelNumber) {
062                this.modelNumber = modelNumber;
063        }
064
065        public String getResidueName() {
066                return residueName;
067        }
068
069        /** Including insertion code
070         *
071         * @param residueName
072         */
073        public void setResidueName(String residueName) {
074                this.residueName = residueName;
075        }
076
077        public String getResidueNumber() {
078                return residueNumber;
079        }
080
081        public void setResidueNumber(String residueNumber) {
082                this.residueNumber = residueNumber;
083        }
084
085        public String getChainId() {
086                return chainId;
087        }
088
089
090
091        public void setChainId(String chainId) {
092                this.chainId = chainId;
093        }
094
095
096
097        public String getAtomName() {
098                return atomName;
099        }
100
101
102
103        public void setAtomName(String name) {
104                this.atomName = name;
105        }
106
107        @Override
108        public String toString() {
109                String aa3 = "";
110                boolean printResName = true;
111
112                String chain1 ="";
113                String res1 = "";
114
115                aa3 = residueName;
116                res1 = residueNumber;
117                chain1 = chainId;
118
119                StringBuffer buf = new StringBuffer();
120                if ( printResName) {
121                        if ( !"".equals(aa3)){
122                                buf.append("[");
123                                buf.append(aa3);
124                                buf.append("]");
125                        }
126                }
127                if ( ! "".equals(res1)) {
128
129                        // let's check if there is an insertion code...
130                        Matcher matcher = inscodePatter.matcher(res1);
131
132                        boolean found = matcher.find();
133                        if ( ! found) {
134                                System.err.println("JmolTools: could not parse the residue number string " + res1);
135                                buf.append(res1);
136                        } else {
137                                String residueNumber = matcher.group(1);
138                                String insCode = matcher.group(2);
139                                buf.append(residueNumber);
140                                if ( insCode != null && ! "".equals(insCode)) {
141                                        buf.append("^");
142                                        buf.append(insCode);
143                                }
144                        }
145
146                }
147
148                if ( ! "".equals(chain1)){
149                        buf.append(":");
150                        buf.append(chain1);
151                }
152
153                if ( atomName != null) {
154                        buf.append(".");
155                        buf.append(atomName);
156                }
157                if ( modelNumber > 0) {
158                        buf.append("/");
159                        buf.append(modelNumber);
160                }
161                return buf.toString();
162        }
163
164
165
166
167}