X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fws%2Fdbsources%2FPfam.java;h=fb4e3960d3396674fd1e8bfa6fd4894cf379e8e8;hb=7b9c6bc2db695c996b7bd4e536a6718b22042125;hp=b2d3dc98a50d1f62de92b7eb5d1c3b7f7f92113d;hpb=ab43013b7e357b84b4abade0dba949668dfb2a0e;p=jalview.git diff --git a/src/jalview/ws/dbsources/Pfam.java b/src/jalview/ws/dbsources/Pfam.java index b2d3dc9..fb4e396 100644 --- a/src/jalview/ws/dbsources/Pfam.java +++ b/src/jalview/ws/dbsources/Pfam.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2b1) - * Copyright (C) 2014 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -20,11 +20,10 @@ */ package jalview.ws.dbsources; -import com.stevesoft.pat.Regex; +import jalview.bin.Cache; +import jalview.datamodel.DBRefSource; -import jalview.datamodel.AlignmentI; -import jalview.datamodel.DBRefEntry; -import jalview.ws.seqfetcher.DbSourceProxy; +import com.stevesoft.pat.Regex; /** * TODO: later PFAM is a complex datasource - it could return a tree in addition @@ -34,15 +33,14 @@ import jalview.ws.seqfetcher.DbSourceProxy; * @author JimP * */ -abstract public class Pfam extends Xfam implements DbSourceProxy +abstract public class Pfam extends Xfam { + private static final String PFAM_DOMAIN_KEY = "PFAM_DOMAIN"; + private static final String DEFAULT_PFAM_DOMAIN = "http://pfam.xfam.org"; public Pfam() { super(); - // all extensions of this PFAM source base class are DOMAINDB sources - addDbSourceProperty(jalview.datamodel.DBRefSource.DOMAINDB); - addDbSourceProperty(jalview.datamodel.DBRefSource.ALIGNMENTDB); } /* @@ -50,9 +48,9 @@ abstract public class Pfam extends Xfam implements DbSourceProxy * * @see jalview.ws.DbSourceProxy#getAccessionSeparator() */ + @Override public String getAccessionSeparator() { - // TODO Auto-generated method stub return null; } @@ -61,9 +59,9 @@ abstract public class Pfam extends Xfam implements DbSourceProxy * * @see jalview.ws.DbSourceProxy#getAccessionValidator() */ + @Override public Regex getAccessionValidator() { - // TODO Auto-generated method stub return null; } @@ -94,47 +92,13 @@ abstract public class Pfam extends Xfam implements DbSourceProxy @Override public String getDbVersion() { - // TODO Auto-generated method stub return null; } - /** - * Returns base URL for selected Pfam alignment type - * - * @return PFAM URL stub for this DbSource - */ @Override - protected abstract String getXFAMURL(); - - /* - * (non-Javadoc) - * - * @see jalview.ws.DbSourceProxy#getSequenceRecords(java.lang.String[]) - */ - public AlignmentI getSequenceRecords(String queries) throws Exception + protected String getURLPrefix() { - // TODO: this is not a perfect implementation. We need to be able to add - // individual references to each sequence in each family alignment that's - // retrieved. - startQuery(); - AlignmentI rcds = new jalview.io.FormatAdapter().readFile(getXFAMURL() - + queries.trim().toUpperCase(), jalview.io.FormatAdapter.URL, - "STH"); - for (int s = 0, sNum = rcds.getHeight(); s < sNum; s++) - { - rcds.getSequenceAt(s).addDBRef( - new DBRefEntry(jalview.datamodel.DBRefSource.PFAM, - // getDbSource(), - getDbVersion(), queries.trim().toUpperCase())); - if (!getDbSource().equals(jalview.datamodel.DBRefSource.PFAM)) - { // add the specific ref too - rcds.getSequenceAt(s).addDBRef( - new DBRefEntry(getDbSource(), getDbVersion(), queries - .trim().toUpperCase())); - } - } - stopQuery(); - return rcds; + return Cache.getDefault(PFAM_DOMAIN_KEY, DEFAULT_PFAM_DOMAIN); } /* @@ -142,6 +106,7 @@ abstract public class Pfam extends Xfam implements DbSourceProxy * * @see jalview.ws.DbSourceProxy#isValidReference(java.lang.String) */ + @Override public boolean isValidReference(String accession) { return accession.indexOf("PF") == 0; @@ -151,9 +116,10 @@ abstract public class Pfam extends Xfam implements DbSourceProxy * public String getDbName() { return "PFAM"; // getDbSource(); } */ + @Override public String getXfamSource() { - return jalview.datamodel.DBRefSource.PFAM; + return DBRefSource.PFAM; } }