X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Futil%2FUrlLink.java;h=18ee9b6014bf0bc02b8e7f291e08a420883bcf00;hb=383fd91269f510b189450fbe174e9c051103c7eb;hp=f9dda09c5ab2f96e69cf09ecc4dc8387ef12ecee;hpb=e2e909ef04c5ec3d5b87cd6cc6fe5d6cc4cb3ac6;p=jalview.git diff --git a/src/jalview/util/UrlLink.java b/src/jalview/util/UrlLink.java index f9dda09..18ee9b6 100644 --- a/src/jalview/util/UrlLink.java +++ b/src/jalview/util/UrlLink.java @@ -20,32 +20,91 @@ */ package jalview.util; +import static jalview.util.UrlConstants.DB_ACCESSION; +import static jalview.util.UrlConstants.DELIM; +import static jalview.util.UrlConstants.SEP; import static jalview.util.UrlConstants.SEQUENCE_ID; -import static jalview.util.UrlConstants.SEQUENCE_NAME; +import jalview.datamodel.DBRefEntry; +import jalview.datamodel.SequenceI; + +import java.util.Arrays; +import java.util.Collections; +import java.util.Comparator; +import java.util.List; +import java.util.Map; import java.util.Vector; +/** + * A helper class to parse URL Link strings taken from applet parameters or + * jalview properties file using the com.stevesoft.pat.Regex implementation. + * Jalview 2.4 extension allows regular expressions to be used to parse ID + * strings and replace the result in the URL. Regex's operate on the whole ID + * string given to the matchURL method, if no regex is supplied, then only text + * following the first pipe symbol will be substituted. Usage documentation + * todo. + */ public class UrlLink { + private static final String SEQUENCEID_PLACEHOLDER = DELIM + SEQUENCE_ID + + DELIM; + + private static final String ACCESSION_PLACEHOLDER = DELIM + DB_ACCESSION + + DELIM; + /** - * helper class to parse URL Link strings taken from applet parameters or - * jalview properties file using the com.stevesoft.pat.Regex implementation. - * Jalview 2.4 extension allows regular expressions to be used to parse ID - * strings and replace the result in the URL. Regex's operate on the whole ID - * string given to the matchURL method, if no regex is supplied, then only - * text following the first pipe symbol will be susbstituted. Usage - * documentation todo. + * A comparator that puts SEQUENCE_ID template links before DB_ACCESSION + * links, and otherwise orders by link name + url (not case sensitive). It + * expects to compare strings formatted as "Name|URLTemplate" where the + * template may include $SEQUENCE_ID$ or $DB_ACCESSION$ or neither. */ - private String url_suffix, url_prefix, target, label, regexReplace; + public static final Comparator LINK_COMPARATOR = new Comparator() + { + @Override + public int compare(String link1, String link2) + { + if (link1 == null || link2 == null) + { + return 0; // for failsafe only + } + if (link1.contains(SEQUENCEID_PLACEHOLDER) + && link2.contains(ACCESSION_PLACEHOLDER)) + { + return -1; + } + if (link2.contains(SEQUENCEID_PLACEHOLDER) + && link1.contains(ACCESSION_PLACEHOLDER)) + { + return 1; + } + return String.CASE_INSENSITIVE_ORDER.compare(link1, link2); + } + }; + + private static final String EQUALS = "="; + + private static final String SPACE = " "; + + private String urlSuffix; + + private String urlPrefix; + + private String target; + + private String label; + + private String dbname; + + private String regexReplace; private boolean dynamic = false; - private boolean uses_seq_id = false; + private boolean usesDBaccession = false; private String invalidMessage = null; /** - * parse the given linkString of the form '