import jalview.xml.binding.sifts.Entry.Entity.Segment.ListResidue.Residue;
import jalview.xml.binding.sifts.Entry.Entity.Segment.ListResidue.Residue.CrossRefDb;
import jalview.xml.binding.sifts.Entry.Entity.Segment.ListResidue.Residue.ResidueDetail;
-import jalview.xml.binding.sifts.Entry.ListDB.Db;
import java.io.File;
import java.io.FileInputStream;
-import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
+import java.util.Map;
+import java.util.Set;
import java.util.TreeMap;
import java.util.zip.GZIPInputStream;
import javax.xml.bind.JAXBContext;
-import javax.xml.bind.JAXBException;
import javax.xml.bind.Unmarshaller;
-import javax.xml.stream.FactoryConfigurationError;
import javax.xml.stream.XMLInputFactory;
-import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import MCview.Atom;
import MCview.PDBChain;
-import MCview.PDBfile;
public class SiftsClient implements SiftsClientI
{
private String structId;
- private String segStartEnd;
+ // private String segStartEnd;
private CoordinateSys seqCoordSys = CoordinateSys.UNIPROT;
siftsEntry = parseSIFTs(siftsFile);
}
- /**
- * Construct an instance of SiftsClient using the supplied SIFTs file. Note:
- * The SIFTs file should correspond to the PDB Id in PDBfile instance
- *
- * @param pdbId
- * @param siftsFile
- * @throws SiftsException
- * @throws Exception
- */
- public SiftsClient(PDBfile pdb, File siftsFile) throws SiftsException
- {
- this.pdb = pdb;
- this.pdbId = pdb.getId();
- siftsEntry = parseSIFTs(siftsFile);
- }
/**
* Parse the given SIFTs File and return a JAXB POJO of parsed data
.createXMLStreamReader(gzis);
Unmarshaller um = jc.createUnmarshaller();
return (Entry) um.unmarshal(streamReader);
- } catch (JAXBException e)
- {
- e.printStackTrace();
- throw new SiftsException(e.getMessage());
- } catch (FileNotFoundException e)
- {
- e.printStackTrace();
- throw new SiftsException(e.getMessage());
- } catch (XMLStreamException e)
- {
- e.printStackTrace();
- throw new SiftsException(e.getMessage());
- } catch (FactoryConfigurationError e)
- {
- e.printStackTrace();
- throw new SiftsException(e.getMessage());
- } catch (IOException e)
+ } catch (Exception e)
{
e.printStackTrace();
throw new SiftsException(e.getMessage());
* - DBRefEntry to validate
* @return true validation is successful otherwise false is returned.
*/
- private boolean isValidDBRefEntry(DBRefEntryI entry)
+ boolean isValidDBRefEntry(DBRefEntryI entry)
{
return entry != null && entry.getAccessionId() != null
&& isFoundInSiftsEntry(entry.getAccessionId());
public HashMap<Integer, int[]> getGreedyMapping(String entityId,
SequenceI seq, java.io.PrintStream os) throws SiftsException
{
- ArrayList<Integer> omitNonObserved = new ArrayList<Integer>();
+ List<Integer> omitNonObserved = new ArrayList<Integer>();
int nonObservedShiftIndex = 0;
// System.out.println("Generating mappings for : " + entityId);
Entity entity = null;
List<Segment> segments = entity.getSegment();
for (Segment segment : segments)
{
- segStartEnd = segment.getStart() + " - " + segment.getEnd();
+ // segStartEnd = segment.getStart() + " - " + segment.getEnd();
// System.out.println("Mapping segments : " + segment.getSegId() + "\\"
// + segStartEnd);
List<Residue> residues = segment.getListResidue().getResidue();
mop.setType("pep");
os.print(getMappingOutput(mop).toString());
+ os.println();
}
return mapping;
}
* Two dimension array of residue index versus atom position
* @throws IllegalArgumentException
* Thrown if chainId or mapping is null
+ * @throws SiftsException
*/
- void populateAtomPositions(String chainId,
- HashMap<Integer, int[]> mapping) throws IllegalArgumentException
+ void populateAtomPositions(String chainId, Map<Integer, int[]> mapping)
+ throws IllegalArgumentException, SiftsException
{
try
{
map[PDB_ATOM_POS] = getAtomIndex(map[PDB_RES_POS], chain.atoms);
}
}
+ } catch (NullPointerException e)
+ {
+ throw new SiftsException(e.getMessage());
} catch (Exception e)
{
- e.printStackTrace();
+ throw new SiftsException(e.getMessage());
}
}
*/
private boolean isResidueObserved(Residue residue)
{
- HashSet<String> annotations = getResidueAnnotaitons(residue,
+ Set<String> annotations = getResidueAnnotaitons(residue,
ResidueDetailType.ANNOTATION);
if (annotations == null || annotations.isEmpty())
{
* @param type
* @return
*/
- private HashSet<String> getResidueAnnotaitons(Residue residue,
+ private Set<String> getResidueAnnotaitons(Residue residue,
ResidueDetailType type)
{
HashSet<String> foundAnnotations = new HashSet<String>();
private boolean isFoundInSiftsEntry(String accessionId)
{
- HashSet<String> siftsDBRefs = getAllMappingAccession();
+ Set<String> siftsDBRefs = getAllMappingAccession();
return accessionId != null
&& siftsDBRefs.contains(accessionId.toLowerCase());
}
*
* @param resNumMap
*/
- void padWithGaps(TreeMap<Integer, String> resNumMap,
- ArrayList<Integer> omitNonObserved)
+ void padWithGaps(Map<Integer, String> resNumMap,
+ List<Integer> omitNonObserved)
{
if (resNumMap == null || resNumMap.isEmpty())
{
// less optimised processing, where as changing the value to 'true'
// optimises performance but might result to incorrect mapping in some cases
// where SIFTS mappings are wrongly swapped between different chains.
- boolean isGetEntityIdDirectly = false;
- if (isGetEntityIdDirectly)
- {
- List<Entity> entities = siftsEntry.getEntity();
- for (Entity entity : entities)
- {
- if (!entity.getEntityId().equalsIgnoreCase(id))
- {
- continue;
- }
- return entity;
- }
- }
+ // boolean isGetEntityIdDirectly = false;
+ // if (isGetEntityIdDirectly)
+ // {
+ // List<Entity> entities = siftsEntry.getEntity();
+ // for (Entity entity : entities)
+ // {
+ // if (!entity.getEntityId().equalsIgnoreCase(id))
+ // {
+ // continue;
+ // }
+ // return entity;
+ // }
+ // }
Entity entity = getEntityByMostOptimalMatchedId(id);
if (entity != null)
{
}
}
- @Override
- public String[] getEntryDBs()
- {
- System.out.println("\nListing DB entries...");
- List<String> availDbs = new ArrayList<String>();
- List<Db> dbs = siftsEntry.getListDB().getDb();
- for (Db db : dbs)
- {
- availDbs.add(db.getDbSource());
- System.out.println(db.getDbSource() + " | " + db.getDbCoordSys());
- }
- return availDbs.toArray(new String[0]);
- }
@Override
public StringBuffer getMappingOutput(MappingOutputPojo mp)
output.append("Length of alignment = " + seqRes.length()).append(
NEWLINE);
output.append(new Format("Percentage ID = %2.2f").form(pid));
- output.append(NEWLINE);
return output;
}
}
@Override
- public String getDbEvidence()
- {
- return siftsEntry.getDbEvidence();
- }
-
- @Override
public String getDbSource()
{
return siftsEntry.getDbSource();