@Override
public void parse() throws IOException
{
+ Element content = null;
+ Document doc = null;
try
{
- Element content = null;
- Document doc = null;
- try {
- StringBuilder htmlData = new StringBuilder();
- String currentLine;
- while ((currentLine = nextLine()) != null)
- {
- htmlData.append(currentLine);
- }
-
- doc = Jsoup.parse(htmlData.toString());
- } catch (OutOfMemoryError oom) {
- errormessage = "Not enough memory to process HTML document";
- throw new IOException(errormessage);
+ StringBuilder htmlData = new StringBuilder();
+ String currentLine;
+ while ((currentLine = nextLine()) != null)
+ {
+ htmlData.append(currentLine);
}
+ doc = Jsoup.parse(htmlData.toString());
+ } catch (OutOfMemoryError oom)
+ {
+ errormessage = "Not enough memory to process HTML document";
+ throw new IOException(errormessage);
+ }
+
+ try
+ {
content = doc.getElementById("seqData");
-
- JSONFile jsonFile = new JSONFile().parse(new StringReader(content.val()));
+ if (content == null)
+ {
+ errormessage = "The html document is not embedded with BioJSON data";
+ throw new IOException(errormessage);
+ }
+ JSONFile jsonFile = new JSONFile().parse(new StringReader(content
+ .val()));
this.seqs = jsonFile.getSeqs();
this.seqGroups = jsonFile.getSeqGroups();
this.annotations = jsonFile.getAnnotations();
this.displayedFeatures = jsonFile.getDisplayedFeatures();
} catch (Exception e)
{
- errormessage = "Failed to extract data from HTML document.";
- throw new IOException("Unexpected exception whilst extracting JSon from HTML.",e);
+ throw e;
}
}