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 May 27, 2010 021 * Author: Jianjiong Gao 022 * 023 */ 024 025package org.biojava.nbio.protmod; 026 027import java.util.Collection; 028import java.util.LinkedHashSet; 029import java.util.Set; 030 031/** 032 * This class contains information about a specific protein 033 * modification. 034 * 035 * @author Jianjiong Gao 036 * @since 3.0 037 */ 038public class ProteinModificationImpl 039implements ProteinModification , Comparable<ProteinModification> { 040 041 private final String id; 042 private final ModificationCondition condition; 043 private final ModificationCategory category; 044 private final ModificationOccurrenceType occurrenceType; 045 046 private final String pdbccId; 047 private final String pdbccName; 048 private final String residId; 049 private final String residName; 050 private final String psimodId; 051 private final String psimodName; 052 private final String sysName; 053 private final String formula; 054 055 private final Set<String> keywords; 056 057 @Override 058 public String getId() { 059 return id; 060 } 061 062 @Override 063 public String getPdbccId() { 064 return pdbccId; 065 } 066 067 @Override 068 public String getPdbccName() { 069 return pdbccName; 070 } 071 072 @Override 073 public String getResidId() { 074 return residId; 075 } 076 077 @Override 078 public String getResidName() { 079 return residName; 080 } 081 082 @Override 083 public String getPsimodId() { 084 return psimodId; 085 } 086 087 @Override 088 public String getPsimodName() { 089 return psimodName; 090 } 091 092 @Override 093 public String getSystematicName() { 094 return sysName; 095 } 096 097 @Override 098 public String getDescription() { 099 return toString(); 100 //return description; 101 } 102 103 @Override 104 public Set<String> getKeywords() { 105 return keywords; 106 } 107 108 @Override 109 public ModificationCondition getCondition() { 110 return condition; 111 } 112 113 @Override 114 public String getFormula() { 115 return formula; 116 } 117 118 @Override 119 public ModificationCategory getCategory() { 120 return category; 121 } 122 123 @Override 124 public ModificationOccurrenceType getOccurrenceType() { 125 return occurrenceType; 126 } 127 128 @Override 129 public String toString() { 130 return "ProteinModificationImpl [id=" + id + ", condition=" + condition 131 + ", category=" + category + ", occurrenceType=" 132 + occurrenceType + ", pdbccId=" + pdbccId + ", pdbccName=" 133 + pdbccName + ", residId=" + residId + ", residName=" 134 + residName + ", psimodId=" + psimodId + ", psimodName=" 135 + psimodName + ", sysName=" + sysName + ", formula=" + formula 136 + ", keywords=" + keywords + "]"; 137 } 138 139 /* 140 private String printModification(ProteinModificationImpl mod) { 141 StringBuilder sb = new StringBuilder(); 142 143 String name = getBestPossibleName(mod); 144 boolean hasName = true; 145 if ( name.equals("")) 146 hasName = false; 147 sb.append(name); 148 149 Set<String> keywords = mod.getKeywords(); 150 if (keywords!=null && !keywords.isEmpty()) { 151 if ( hasName) 152 sb.append(" ("); 153 for (String keyword : keywords) { 154 155 sb.append(keyword); 156 sb.append(", "); 157 } 158 sb.delete(sb.length()-2,sb.length()); 159 } 160 if ( hasName) 161 sb.append(")"); 162 return sb.toString(); 163 } 164 165 166 private String getBestPossibleName(ProteinModificationImpl mod) { 167 168 //System.out.println(mod.getResidName() + " : " + mod.getPsimodName() + " : " + mod.getPdbccName() + " : " + mod.getSystematicName()); 169 170 // first: get resid 171 String resid = mod.getResidId(); 172 if (resid != null) { 173 String residname = mod.getResidName(); 174 if (residname != null) { 175 return residname; 176 } 177 } 178 179 // 2nd: PSI-MOD 180 181 String name = mod.getPsimodName(); 182 if ( name != null) { 183 //System.out.println("PSI_MOD name:" + name); 184 return name; 185 } 186 187 // 3rd PDB-CC 188 189 String pdbcc = mod.getPdbccName(); 190 if ( pdbcc != null ) { 191 //System.out.println("PDBCC name: " + pdbcc); 192 return pdbcc; 193 } 194 195 196 // no public name know, use the systematic name 197 198 String systematic = mod.getSystematicName(); 199 if ( systematic != null) { 200 //System.out.println("SYSTEMATIC NAME: " + mod.getSystematicName()); 201 return systematic; 202 } 203 204 205 return ""; 206 207 } 208 */ 209 210 @Override 211 public int hashCode() { 212 int ret = id.hashCode(); 213 ret = ret * 31 + category.hashCode(); 214 return ret; 215 } 216 217 @Override 218 public boolean equals(Object obj) { 219 if (!(obj instanceof ProteinModification)) 220 return false; 221 222 ProteinModification mod = (ProteinModification)obj; 223 if (!id.equals(mod.getId())) 224 return false; 225 226 if (category != mod.getCategory()) 227 return false; 228 229 return true; 230 } 231 232 233 234 235 /** 236 * Uses Builder pattern to build a ProteinModification. 237 */ 238 public static class Builder { 239 private final String id; 240 241 private ModificationCondition condition; 242 private ModificationCategory category; 243 private ModificationOccurrenceType occurrenceType; 244 245 private String pdbccId = null; 246 private String pdbccName = null; 247 private String residId = null; 248 private String residName = null; 249 private String psimodId = null; 250 private String psimodName = null; 251 private String sysName = null; 252 private String formula = null; 253 254 private Set<String> keywords = new LinkedHashSet<>(); 255 256 /** 257 * 258 * @param id 259 * @param cat 260 * @param occType 261 * @param condition 262 */ 263 public Builder(final String id, final ModificationCategory cat, 264 final ModificationOccurrenceType occType, 265 final ModificationCondition condition) { 266 if ( id == null) throw new IllegalArgumentException("id == null!"); 267 if ( cat == null) throw new IllegalArgumentException("cat == null!"); 268 if ( occType == null) throw new IllegalArgumentException("occType == null!"); 269 if ( condition == null) throw new IllegalArgumentException("condition == null!"); 270 271 this.id = id; 272 this.category = cat; 273 this.occurrenceType = occType; 274 this.condition = condition; 275 } 276 277 /** 278 * Create a Builder from an existing ProteinModification. 279 * @param copyFrom the ProteinModification to be copied from. 280 */ 281 public Builder(final ProteinModification copyFrom) { 282 this(copyFrom.getId(), copyFrom.getCategory(), copyFrom.getOccurrenceType(), copyFrom.getCondition()); 283 this.pdbccId = copyFrom.getPdbccId(); 284 this.pdbccName = copyFrom.getPdbccName(); 285 this.residId = copyFrom.getResidId(); 286 this.residName = copyFrom.getResidName(); 287 this.psimodId = copyFrom.getPsimodId(); 288 this.psimodName = copyFrom.getPsimodName(); 289 this.sysName = copyFrom.getSystematicName(); 290 this.formula = copyFrom.getFormula(); 291 292 this.keywords = new LinkedHashSet<>(copyFrom.getKeywords()); 293 } 294 295 public Builder setCategory(final ModificationCategory cat) { 296 if (cat == null) throw new IllegalArgumentException("cat == null!"); 297 this.category = cat; 298 return this; 299 } 300 301 public Builder setOccurrenceType(final ModificationOccurrenceType occType) { 302 if (occType == null) throw new IllegalArgumentException("occType == null!"); 303 this.occurrenceType =occType; 304 return this; 305 } 306 307 public Builder setCondition(final ModificationCondition condition) { 308 if (condition == null) throw new IllegalArgumentException("condition == null!"); 309 this.condition = condition; 310 return this; 311 } 312 313 /** 314 * Set the Protein Data Bank Chemical Component ID. 315 * @param pdbccId Protein Data Bank Chemical Component ID. 316 * @return the same Builder object so you can chain setters. 317 */ 318 public Builder setPdbccId(final String pdbccId) { 319 this.pdbccId = pdbccId; 320 return this; 321 } 322 323 /** 324 * Set the Protein Data Bank Chemical Component name. 325 * @param pdbccName Protein Data Bank Chemical Component name. 326 * @return the same Builder object so you can chain setters. 327 */ 328 public Builder setPdbccName(final String pdbccName) { 329 this.pdbccName = pdbccName; 330 return this; 331 } 332 333 /** 334 * Set the RESID ID. 335 * @param residId RESID ID. 336 * @return the same Builder object so you can chain setters. 337 */ 338 public Builder setResidId(final String residId) { 339 this.residId = residId; 340 return this; 341 } 342 343 /** 344 * Set the RESID name. 345 * @param residName RESID name. 346 * @return the same Builder object so you can chain setters. 347 */ 348 public Builder setResidName(final String residName) { 349 this.residName = residName; 350 return this; 351 } 352 353 /** 354 * Set the PSI-MOD ID. 355 * @param psimodId PSI-MOD ID. 356 * @return the same Builder object so you can chain setters. 357 */ 358 public Builder setPsimodId(final String psimodId) { 359 this.psimodId = psimodId; 360 return this; 361 } 362 363 /** 364 * Set the PSI-MOD name. 365 * @param psimodName PSI-MOD name. 366 * @return the same Builder object so you can chain setters. 367 */ 368 public Builder setPsimodName(final String psimodName) { 369 this.psimodName = psimodName; 370 return this; 371 } 372 373 /** 374 * Set the systematic name. 375 * @param sysName systematic name. 376 * @return the same Builder object so you can chain setters. 377 */ 378 public Builder setSystematicName(final String sysName) { 379 this.sysName = sysName; 380 return this; 381 } 382 383 /** 384 * 385 * @param description description of the modification. 386 * @return the same Builder object so you can chain setters. 387 */ 388 public Builder setDescription(final String description) { 389 // description is created on the fly in getDescription 390 return this; 391 } 392 393 /** 394 * Add a keyword associate with the PTM. 395 * @param keyword a keyword. 396 * @return the same Builder object so you can chain setters. 397 * @throws IllegalArgumentException if the keyword is null. 398 */ 399 public Builder addKeyword(String keyword) { 400 if (keyword == null) throw new IllegalArgumentException("Keyword cannot be null."); 401 keywords.add(keyword); 402 return this; 403 } 404 405 public Builder addKeywords(Collection<String> keywords) { 406 if (keywords==null) throw new IllegalArgumentException("Keywords cannot be null."); 407 408 for (String keyword : keywords) { 409 addKeyword(keyword); 410 } 411 412 return this; 413 } 414 415 /** 416 * Set the residue formula. 417 * @param formula residue formula. 418 * @return the same Builder object so you can chain setters. 419 */ 420 public Builder setFormula(final String formula) { 421 this.formula = formula; 422 return this; 423 } 424 425 /** 426 * 427 * @return build ProteinModification. 428 */ 429 public ProteinModificationImpl build() { 430 return new ProteinModificationImpl(this); 431 } 432 } 433 434 /** 435 * 436 */ 437 private ProteinModificationImpl(Builder builder) { 438 this.id = builder.id; 439 this.category = builder.category; 440 this.occurrenceType = builder.occurrenceType; 441 this.condition = builder.condition; 442 this.pdbccId = builder.pdbccId; 443 this.pdbccName = builder.pdbccName; 444 this.residId = builder.residId; 445 this.residName = builder.residName; 446 this.psimodId = builder.psimodId; 447 this.psimodName = builder.psimodName; 448 this.sysName = builder.sysName; 449 this.formula = builder.formula; 450 451 this.keywords = new LinkedHashSet<>(builder.keywords); 452 } 453 454 @Override 455 public int compareTo(ProteinModification arg0) { 456 if ( this.equals(arg0)) 457 return 0; 458 459 return this.toString().compareTo(arg0.toString()); 460 } 461}