X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=inline;f=src%2Fjalview%2Fanalysis%2FParseProperties.java;h=4b68d93a666340d0fd6539fc3f1f2f0bcae26464;hb=a6f0678764ea06034460236c7a811bbfcad682aa;hp=79c1325aab21b6efed5177d827e1b47bf0b25dba;hpb=f683f4d6c8af43be0ffeb96513b52572619efed5;p=jalview.git
diff --git a/src/jalview/analysis/ParseProperties.java b/src/jalview/analysis/ParseProperties.java
index 79c1325..4b68d93 100644
--- a/src/jalview/analysis/ParseProperties.java
+++ b/src/jalview/analysis/ParseProperties.java
@@ -1,108 +1,156 @@
+/*
+ * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
+ * Copyright (C) $$Year-Rel$$ The Jalview Authors
+ *
+ * This file is part of Jalview.
+ *
+ * Jalview is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation, either version 3
+ * of the License, or (at your option) any later version.
+ *
+ * Jalview is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty
+ * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * 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 jalview.analysis;
-import com.stevesoft.pat.Regex;
+import jalview.datamodel.AlignmentAnnotation;
+import jalview.datamodel.AlignmentI;
+import jalview.datamodel.SequenceI;
-import jalview.datamodel.*;
+import com.stevesoft.pat.Regex;
public class ParseProperties
{
/**
- * Methods for parsing free text properties on alignments and sequences.
- * There are a number of ways we might want to do this:
- * arbitrary regex. and an associated score name for the number that's extracted.
- * Regex that provides both score and name.
+ * Methods for parsing free text properties on alignments and sequences. There
+ * are a number of ways we might want to do this: arbitrary regex. and an
+ * associated score name for the number that's extracted. Regex that provides
+ * both score and name.
*
- * We may also want to :
- * - modify description to remove parsed numbers (this behaviour is dangerous since exporting the alignment would lose the original form then)
- * -
+ * We may also want to : - modify description to remove parsed numbers (this
+ * behaviour is dangerous since exporting the alignment would lose the
+ * original form then) -
*
*/
/**
* The alignment being operated on
*/
- private AlignmentI al=null;
-
+ private AlignmentI al = null;
+
/**
* initialise a new property parser
+ *
* @param al
*/
- public ParseProperties(AlignmentI al) {
+ public ParseProperties(AlignmentI al)
+ {
this.al = al;
}
- public int getScoresFromDescription(String ScoreName, String ScoreDescriptions, String regex, boolean repeat)
+ public int getScoresFromDescription(String ScoreName,
+ String ScoreDescriptions, String regex, boolean repeat)
{
- return getScoresFromDescription(new String[] { ScoreName }, new String[] { ScoreDescriptions}, regex, repeat);
+ return getScoresFromDescription(new String[] { ScoreName },
+ new String[]
+ { ScoreDescriptions }, regex, repeat);
}
- public int getScoresFromDescription(String[] ScoreNames, String[] ScoreDescriptions, String regex, boolean repeat)
+ public int getScoresFromDescription(String[] ScoreNames,
+ String[] ScoreDescriptions, String regex, boolean repeat)
{
- return getScoresFromDescription(al.getSequencesArray(), ScoreNames, ScoreDescriptions, regex, repeat);
+ return getScoresFromDescription(al.getSequencesArray(), ScoreNames,
+ ScoreDescriptions, regex, repeat);
}
+
/**
* Extract scores for sequences by applying regex to description string.
- * @param seqs seuqences to extract annotation from.
- * @param ScoreNames labels for each numeric field in regex match
- * @param ScoreDescriptions description for each numeric field in regex match
- * @param regex Regular Expression string for passing to new com.stevesoft.patt.Regex(regex)
- * @param repeat true means the regex will be applied multiple times along the description string of each sequence
+ *
+ * @param seqs
+ * seuqences to extract annotation from.
+ * @param ScoreNames
+ * labels for each numeric field in regex match
+ * @param ScoreDescriptions
+ * description for each numeric field in regex match
+ * @param regex
+ * Regular Expression string for passing to
+ * new com.stevesoft.patt.Regex(regex)
+ * @param repeat
+ * true means the regex will be applied multiple times along the
+ * description string of each sequence
* @return total number of sequences that matched the regex
*/
- public int getScoresFromDescription(SequenceI[] seqs, String[] ScoreNames, String[] ScoreDescriptions, String regex, boolean repeat)
+ public int getScoresFromDescription(SequenceI[] seqs, String[] ScoreNames,
+ String[] ScoreDescriptions, String regex, boolean repeat)
{
- int count=0;
+ int count = 0;
Regex pattern = new Regex(regex);
- if (pattern.numSubs()>ScoreNames.length)
+ if (pattern.numSubs() > ScoreNames.length)
{
- // Check that we have enough labels and descriptions for any parsed scores.
+ // Check that we have enough labels and descriptions for any parsed
+ // scores.
int onamelen = ScoreNames.length;
- String[] tnames = new String[pattern.numSubs()+1];
+ String[] tnames = new String[pattern.numSubs() + 1];
System.arraycopy(ScoreNames, 0, tnames, 0, ScoreNames.length);
- String base = tnames[ScoreNames.length-1];
+ String base = tnames[ScoreNames.length - 1];
ScoreNames = tnames;
- String descrbase = ScoreDescriptions[onamelen-1];
+ String descrbase = ScoreDescriptions[onamelen - 1];
if (descrbase == null)
- descrbase = "Score parsed from ("+regex+")";
- tnames = new String[pattern.numSubs()+1];
- System.arraycopy(ScoreDescriptions, 0, tnames, 0, ScoreDescriptions.length);
+ {
+ descrbase = "Score parsed from (" + regex + ")";
+ }
+ tnames = new String[pattern.numSubs() + 1];
+ System.arraycopy(ScoreDescriptions, 0, tnames, 0,
+ ScoreDescriptions.length);
ScoreDescriptions = tnames;
- for (int i=onamelen; i0) ? "_"+reps : ""), ScoreDescriptions[cols], null);
+ AlignmentAnnotation an = new AlignmentAnnotation(
+ ScoreNames[cols] + ((reps > 0) ? "_" + reps : ""),
+ ScoreDescriptions[cols], null);
an.setScore(score);
- System.out.println("Score: "+ScoreNames[cols]+"="+score); // DEBUG
+ System.out.println(seqs[i].getName() + " score: '"
+ + ScoreNames[cols] + "' = " + score); // DEBUG
an.setSequenceRef(seqs[i]);
seqs[i].addAlignmentAnnotation(an);
al.addAnnotation(an);
- added=true;
+ added = true;
}
reps++; // repeated matches
}
@@ -111,24 +159,6 @@ public class ParseProperties
count++;
}
}
- return count;
- }
- public static void main(String argv[]) {
- SequenceI[] seqs = new SequenceI[] { new Sequence("sq1","THISISAPLACEHOLDER"),
- new Sequence("sq2","THISISAPLACEHOLDER"),
- new Sequence("sq3","THISISAPLACEHOLDER"),
- new Sequence("sq4","THISISAPLACEHOLDER")};
- seqs[0].setDescription("1 mydescription1");
- seqs[1].setDescription("mydescription2");
- seqs[2].setDescription("2. 0.1 mydescription3");
- seqs[3].setDescription("3 0.01 mydescription4");
- //seqs[4].setDescription("5 mydescription5");
- Alignment al = new Alignment(seqs);
- ParseProperties pp = new ParseProperties(al);
- String regex = ".*([-0-9.+]+)";
- System.out.println("Matched "+pp.getScoresFromDescription("my Score", "my Score Description",regex, true)+" for "+regex);
- regex = ".*([-0-9.+]+).+([-0-9.+]+).*";
- System.out.println("Matched "+pp.getScoresFromDescription("my Score", "my Score Description",regex, true)+" for "+regex);
- System.out.println("Finished.");
+ return count;
}
}