X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2FMCview%2FPDBfile.java;h=3272d1540cf10186704f38b449028100a1ce996a;hb=c07ef0cc5eabc7df4eb15bb3541a702278783f05;hp=95dec131f53c360841d1d41561a160296d43e5f0;hpb=1e5dc0e8a71d9eb0be4748f994072b11f25b04e0;p=jalview.git diff --git a/src/MCview/PDBfile.java b/src/MCview/PDBfile.java index 95dec13..3272d15 100755 --- a/src/MCview/PDBfile.java +++ b/src/MCview/PDBfile.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8) - * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.0b1) + * Copyright (C) 2014 The Jalview Authors * * This file is part of Jalview. * @@ -14,6 +14,7 @@ * PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. */ package MCview; @@ -25,7 +26,6 @@ import java.awt.*; import jalview.analysis.AlignSeq; import jalview.datamodel.*; import jalview.io.FileParse; -import jalview.ws.jws1.Annotate3D; public class PDBfile extends jalview.io.AlignFile { @@ -159,7 +159,9 @@ public class PDBfile extends jalview.io.AlignFile PDBEntry entry = new PDBEntry(); entry.setId(id); entry.setProperty(new Hashtable()); - entry.getProperty().put("CHAIN", ((PDBChain)chains.elementAt(i)).id); + if (((PDBChain)chains.elementAt(i)).id!=null) { + entry.getProperty().put("CHAIN", ((PDBChain)chains.elementAt(i)).id); + } if (inFile != null) { entry.setFile(inFile.getAbsolutePath()); @@ -211,6 +213,15 @@ public class PDBfile extends jalview.io.AlignFile x.printStackTrace(); }; + if (prot.size()>0) + try { + processPdbFileWithJmol(prot); + } catch (Exception x) + { + System.err.println("Exceptions when dealing with RNA in pdb file"); + x.printStackTrace(); + + }; } catch (OutOfMemoryError er) { System.out.println("OUT OF MEMORY LOADING PDB FILE"); @@ -226,15 +237,34 @@ public class PDBfile extends jalview.io.AlignFile } private void processPdbFileWithJmol(ArrayList prot) throws Exception { - // process prot sequence with Jmol to get annotated alignment. - // replaceMatchingSeqsWith(prot, al, AlignSeq.PEP); + try { + Class cl = Class.forName("jalview.ext.jmol.PDBFileWithJmol"); + if (cl!=null) + { + Object jmf = cl.getConstructor(new Class[] {FileParse.class}).newInstance(new Object[] {new FileParse(getDataName(),type)}); + Alignment al = new Alignment((SequenceI[]) cl.getMethod("getSeqsAsArray", new Class[] {}).invoke(jmf)); + cl.getMethod("addAnnotations",new Class[] {Alignment.class}).invoke(jmf, al); + replaceMatchingSeqsWith(prot, al, AlignSeq.PEP); + } + } catch (ClassNotFoundException q) + {} } private void processPdbFileWithAnnotate3d(ArrayList rna) throws Exception { // System.out.println("this is a PDB format and RNA sequence"); - Annotate3D an3d = new Annotate3D(); - // TODO: use the PDB ID of the structure if one is available, to save bandwidth and avoid uploading the whole structure to the service - AlignmentI al = an3d.getRNAMLFor(new FileParse(getDataName(),type)); - replaceMatchingSeqsWith(rna, al, AlignSeq.DNA); + // note: we use reflection here so that the applet can compile and run without the HTTPClient bits and pieces needed for accessing Annotate3D web service + try { + Class cl = Class.forName("jalview.ws.jws1.Annotate3D"); + if (cl!=null) + { + // TODO: use the PDB ID of the structure if one is available, to save bandwidth and avoid uploading the whole structure to the service + Object annotate3d = cl.getConstructor(new Class[] {}).newInstance(new Object[] {}); + AlignmentI al = ((AlignmentI) cl.getMethod("getRNAMLFor", new Class[] { FileParse.class}).invoke(annotate3d, new Object[] { new FileParse(getDataName(),type)})); + replaceMatchingSeqsWith(rna, al, AlignSeq.DNA); + } + } catch (ClassNotFoundException x) + { + //ignore classnotfounds - occurs in applet + }; } private void replaceMatchingSeqsWith(ArrayList ochains, AlignmentI al, String dnaOrProtein) { @@ -286,7 +316,9 @@ public class PDBfile extends jalview.io.AlignFile ap++; } } - annotations.addAll(inspos, Arrays.asList(sq.getAnnotation())); + if (sq.getAnnotation()!=null) { + annotations.addAll(inspos, Arrays.asList(sq.getAnnotation())); + } } } }