X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=inline;f=src%2Fjalview%2Fio%2FHtmlFile.java;h=af3fb5dd97d0267a94fe59a8852385ee1d173f1e;hb=ff8c06845590fd9fd423aa59809dcce9610ab295;hp=d507362c8cc5188a35eb805977099ee81f3da351;hpb=7ce1382b998c007a78c9b33a3dc331e966eebc4b;p=jalview.git
diff --git a/src/jalview/io/HtmlFile.java b/src/jalview/io/HtmlFile.java
index d507362..af3fb5d 100644
--- a/src/jalview/io/HtmlFile.java
+++ b/src/jalview/io/HtmlFile.java
@@ -1,24 +1,55 @@
+/*
+ * 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.io;
-import jalview.gui.AlignFrame;
-import jalview.schemes.ColourSchemeI;
+import jalview.api.ComplexAlignFile;
+import jalview.api.FeatureSettingsModelI;
+import jalview.api.FeaturesDisplayedI;
+import jalview.datamodel.ColumnSelection;
+import jalview.datamodel.SequenceI;
import java.io.IOException;
+import java.io.StringReader;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
-public class HtmlFile extends AlignFile
+public class HtmlFile extends AlignFile implements ComplexAlignFile
{
public static final String FILE_EXT = "html";
public static final String FILE_DESC = "HTML";
- private ColourSchemeI colourScheme;
+ private String globalColourScheme;
private boolean showSeqFeatures;
+ private ColumnSelection columnSelection;
+
+ private SequenceI[] hiddenSequences;
+
+ private FeaturesDisplayedI displayedFeatures;
+
public HtmlFile()
{
super();
@@ -29,14 +60,17 @@ public class HtmlFile extends AlignFile
super(source);
}
- public HtmlFile(String inFile, String type) throws IOException
+ public HtmlFile(String inFile, DataSourceType sourceType)
+ throws IOException
{
- super(inFile, type);
+ super(inFile, sourceType);
}
@Override
public void parse() throws IOException
{
+ Element content = null;
+ Document doc = null;
try
{
StringBuilder htmlData = new StringBuilder();
@@ -45,38 +79,54 @@ public class HtmlFile extends AlignFile
{
htmlData.append(currentLine);
}
+ doc = Jsoup.parse(htmlData.toString());
+ } catch (OutOfMemoryError oom)
+ {
+ errormessage = "Not enough memory to process HTML document";
+ throw new IOException(errormessage);
+ }
- Document doc = Jsoup.parse(htmlData.toString());
- Element content = doc.getElementById("seqData");
- String alignmentJsonString = content.val();
+ try
+ {
+ boolean contentFromDiv = true;
+ // search for BioJSON data in div element with id seqData
+ content = doc.select("div[id=seqData]").first();
+ if (content == null)
+ {
+ contentFromDiv = false;
+ // search for BioJSON data in input element with id seqData
+ content = doc.getElementById("seqData");
+ }
- JSONFile jsonFile = new JSONFile().parse(alignmentJsonString);
- seqs = jsonFile.seqs;
- seqGroups = jsonFile.seqGroups;
- annotations = jsonFile.annotations;
- showSeqFeatures = jsonFile.isShowSeqFeatures();
- colourScheme = jsonFile.getColourScheme();
+ if (content == null)
+ {
+ errormessage = "The html document is not embedded with BioJSON data";
+ throw new IOException(errormessage);
+ }
+ JSONFile jsonFile = new JSONFile().parse(new StringReader(
+ contentFromDiv ? content.text() : content.val()));
+ this.seqs = jsonFile.getSeqs();
+ this.seqGroups = jsonFile.getSeqGroups();
+ this.annotations = jsonFile.getAnnotations();
+ this.showSeqFeatures = jsonFile.isShowSeqFeatures();
+ this.globalColourScheme = jsonFile.getGlobalColourScheme();
+ this.hiddenSequences = jsonFile.getHiddenSequences();
+ this.columnSelection = jsonFile.getColumnSelection();
+ this.displayedFeatures = jsonFile.getDisplayedFeatures();
} catch (Exception e)
{
- e.printStackTrace();
+ throw e;
}
}
- public void applySettingsToAlignFrame(AlignFrame af)
- {
- af.setShowSeqFeatures(isShowSeqFeatures());
- af.changeColour(getColourScheme());
- af.setMenusForViewport();
- }
-
-
@Override
- public String print()
+ public String print(SequenceI[] sqs, boolean jvsuffix)
{
throw new UnsupportedOperationException(
"Print method of HtmlFile is not supported!");
}
+ @Override
public boolean isShowSeqFeatures()
{
return showSeqFeatures;
@@ -87,14 +137,58 @@ public class HtmlFile extends AlignFile
this.showSeqFeatures = showSeqFeatures;
}
- public ColourSchemeI getColourScheme()
+ @Override
+ public String getGlobalColourScheme()
+ {
+ return globalColourScheme;
+ }
+
+ public void setColourScheme(String globalColourScheme)
+ {
+ this.globalColourScheme = globalColourScheme;
+ }
+
+ @Override
+ public ColumnSelection getColumnSelection()
+ {
+ return columnSelection;
+ }
+
+ public void setColumnSelection(ColumnSelection columnSelection)
+ {
+ this.columnSelection = columnSelection;
+ }
+
+ @Override
+ public SequenceI[] getHiddenSequences()
+ {
+ return hiddenSequences;
+ }
+
+ public void setHiddenSequences(SequenceI[] hiddenSequences)
{
- return colourScheme;
+ this.hiddenSequences = hiddenSequences;
}
- public void setColourScheme(ColourSchemeI colourScheme)
+ @Override
+ public FeaturesDisplayedI getDisplayedFeatures()
+ {
+ return displayedFeatures;
+ }
+
+ /**
+ * Returns a descriptor for suitable feature display settings with
+ *
+ * - ResNums or insertions features visible
+ * - insertions features coloured red
+ * - ResNum features coloured by label
+ * - Insertions displayed above (on top of) ResNums
+ *
+ */
+ @Override
+ public FeatureSettingsModelI getFeatureColourScheme()
{
- this.colourScheme = colourScheme;
+ return new PDBFeatureSettings();
}
}