X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fws%2Fdbsources%2FPfam.java;h=47e66ac098a6b8489a0b288efa48837a5eebe5c9;hb=b52f1c317e9171563a69bcf5ef41ad29e9c4da49;hp=9acaa9687276fb2409d27392de9a4f52ccd02d71;hpb=37de9310bec3501cbc6381e0c3dcb282fcaad812;p=jalview.git diff --git a/src/jalview/ws/dbsources/Pfam.java b/src/jalview/ws/dbsources/Pfam.java index 9acaa96..47e66ac 100644 --- a/src/jalview/ws/dbsources/Pfam.java +++ b/src/jalview/ws/dbsources/Pfam.java @@ -20,10 +20,8 @@ */ package jalview.ws.dbsources; -import jalview.datamodel.AlignmentI; -import jalview.datamodel.DBRefEntry; +import jalview.bin.Cache; import jalview.datamodel.DBRefSource; -import jalview.io.FormatAdapter; import com.stevesoft.pat.Regex; @@ -37,6 +35,14 @@ import com.stevesoft.pat.Regex; */ abstract public class Pfam extends Xfam { + /* + * append to URLs to retrieve as a gzipped file + */ + protected static final String GZIPPED = "/gzipped"; + + static final String PFAM_BASEURL_KEY = "PFAM_BASEURL"; + + private static final String DEFAULT_PFAM_BASEURL = "https://pfam.xfam.org"; public Pfam() { @@ -51,7 +57,6 @@ abstract public class Pfam extends Xfam @Override public String getAccessionSeparator() { - // TODO Auto-generated method stub return null; } @@ -63,7 +68,6 @@ abstract public class Pfam extends Xfam @Override public Regex getAccessionValidator() { - // TODO Auto-generated method stub return null; } @@ -94,47 +98,13 @@ abstract public class Pfam extends Xfam @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[]) - */ @Override - 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 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(DBRefSource.PFAM, - // getDbSource(), - getDbVersion(), queries.trim().toUpperCase())); - if (!getDbSource().equals(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_BASEURL_KEY, DEFAULT_PFAM_BASEURL); } /*