X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fdatamodel%2FSequenceFeature.java;h=b50c50d0613ff4cd91a6d56b810826aeda519c9b;hb=6c0f1d821f0efc00d81df7f2a81103de1a40e9b6;hp=a2856fa6ce4867ca27a943c8b442209f2fe96f9c;hpb=99c58ee0ae2a848f982552e53feaf6d5cb9925e5;p=jalview.git
diff --git a/src/jalview/datamodel/SequenceFeature.java b/src/jalview/datamodel/SequenceFeature.java
index a2856fa..b50c50d 100755
--- a/src/jalview/datamodel/SequenceFeature.java
+++ b/src/jalview/datamodel/SequenceFeature.java
@@ -1,100 +1,236 @@
/*
-* Jalview - A Sequence Alignment Editor and Viewer
-* Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
-*
-* This program 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 2
-* of the License, or (at your option) any later version.
-*
-* This program 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 this program; if not, write to the Free Software
-* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
-*/
-
+ * Jalview - A Sequence Alignment Editor and Viewer
+ * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
+ *
+ * This program 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 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+ */
package jalview.datamodel;
-import java.awt.*;
-
-public class SequenceFeature {
- int begin;
- int end;
- String type;
- String description;
- String status;
-
- public SequenceFeature()
- {
- }
-
- public SequenceFeature(String type, int start, int end, String description, String status)
- {
- this.type = type;
- this.begin = start;
- this.end = end;
- this.description = description;
- this.status = status;
- }
-
- public int getStart() {
- return begin;
- }
- public int getEnd() {
- return end;
- }
- public String getType() {
- return type;
- }
- public String getDescription() {
- return description;
- }
- public String getStatus()
- {return status;}
+import java.util.Hashtable;
+/**
+ * DOCUMENT ME!
+ *
+ * @author $author$
+ * @version $Revision$
+ */
+public class SequenceFeature
+{
+ public int begin;
+ public int end;
+ public float score;
+ public String type;
+ public String description;
+ public Hashtable otherDetails;
+ public java.util.Vector links;
-/*
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-*/
+ // Feature group can be set from a features file
+ // as a group of features between STARTGROUP and ENDGROUP markers
+ public String featureGroup;
-}
+ public SequenceFeature()
+ {}
+
+ public SequenceFeature(String type,
+ String desc,
+ String status,
+ int begin, int end,
+ String featureGroup)
+ {
+ this.type = type;
+ this.description = desc;
+ setValue("status", status);
+ this.begin = begin;
+ this.end = end;
+ this.featureGroup = featureGroup;
+ }
+
+ public SequenceFeature(String type,
+ String desc,
+ int begin, int end,
+ float score,
+ String featureGroup)
+ {
+ this.type = type;
+ this.description = desc;
+ this.begin = begin;
+ this.end = end;
+ this.score = score;
+ this.featureGroup = featureGroup;
+ }
+
+ public boolean equals(SequenceFeature sf)
+ {
+ if (begin != sf.begin
+ || end != sf.end
+ || score != sf.score)
+ return false;
+
+ if(!(type+description+featureGroup).equals
+ (sf.type+sf.description+sf.featureGroup))
+ return false;
+
+ return true;
+ }
+
+
+ /**
+ * DOCUMENT ME!
+ *
+ * @return DOCUMENT ME!
+ */
+ public int getBegin()
+ {
+ return begin;
+ }
+
+ public void setBegin(int start)
+ {
+ this.begin = start;
+ }
+
+ /**
+ * DOCUMENT ME!
+ *
+ * @return DOCUMENT ME!
+ */
+ public int getEnd()
+ {
+ return end;
+ }
+
+ public void setEnd(int end)
+ {
+ this.end = end;
+ }
+
+ /**
+ * DOCUMENT ME!
+ *
+ * @return DOCUMENT ME!
+ */
+ public String getType()
+ {
+ return type;
+ }
+
+ public void setType(String type)
+ {
+ this.type = type;
+ }
+
+ /**
+ * DOCUMENT ME!
+ *
+ * @return DOCUMENT ME!
+ */
+ public String getDescription()
+ {
+ return description;
+ }
+ public void setDescription(String desc)
+ {
+ description = desc;
+ }
+
+ public String getFeatureGroup()
+ {
+ return featureGroup;
+ }
+
+ public void setFeatureGroup(String featureGroup)
+ {
+ this.featureGroup = featureGroup;
+ }
+
+ public void addLink(String labelLink)
+ {
+ if(links==null)
+ links = new java.util.Vector();
+
+ links.insertElementAt(labelLink,0);
+ }
+
+ public float getScore()
+ {
+ return score;
+ }
+
+ public void setScore(float value)
+ {
+ score = value;
+ }
+
+ /**
+ * Used for getting values which are not in the
+ * basic set. eg STRAND, FRAME for GFF file
+ * @param key String
+ */
+ public Object getValue(String key)
+ {
+ if(otherDetails==null)
+ return null;
+ else
+ return otherDetails.get(key);
+ }
+
+ /**
+ * Used for setting values which are not in the
+ * basic set. eg STRAND, FRAME for GFF file
+ * @param key eg STRAND
+ * @param value eg +
+ */
+ public void setValue(String key, Object value)
+ {
+ if(value!=null)
+ {
+ if (otherDetails == null)
+ otherDetails = new Hashtable();
+
+ otherDetails.put(key, value);
+ }
+ }
+
+
+ /*
+ * The following methods are added to maintain
+ * the castor Uniprot mapping file for the moment.
+ */
+ public void setStatus(String status)
+ {
+ setValue("status", status);
+ }
+
+ public String getStatus()
+ {
+ if (otherDetails != null)
+ return otherDetails.get("status").toString();
+ else
+ return null;
+ }
+
+ public void setPosition(int pos)
+ {
+ begin = pos;
+ end = pos;
+ }
+
+ public int getPosition()
+ {
+ return begin;
+ }
+
+}