X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fws%2FJobStateSummary.java;h=ab3fc66b165909ec9b26e58a2827109a2119c32f;hb=8a3c31b03ed98321d1d450b658d26d50a7aa0ae6;hp=0983dc078be52da844bc5b1ded1835d6e438e505;hpb=39c0b5e5d2ff4352d36bb6705121dc5ed14ba81b;p=jalview.git diff --git a/src/jalview/ws/JobStateSummary.java b/src/jalview/ws/JobStateSummary.java index 0983dc0..ab3fc66 100644 --- a/src/jalview/ws/JobStateSummary.java +++ b/src/jalview/ws/JobStateSummary.java @@ -1,3 +1,20 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8) + * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, G Barton, M Clamp, S Searle + * + * 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 . + */ package jalview.ws; import jalview.gui.WebserviceInfo; @@ -54,8 +71,8 @@ public class JobStateSummary * @param OutputHeader * @param j */ - public void updateJobPanelState(WebserviceInfo wsInfo, String OutputHeader, - AWsJob j) + public void updateJobPanelState(WebserviceInfo wsInfo, + String OutputHeader, AWsJob j) { if (j.submitted) { @@ -92,9 +109,7 @@ public class JobStateSummary { serror++; j.subjobComplete = true; - wsInfo - .setStatus(j.jobnum, - WebserviceInfo.STATE_STOPPED_SERVERERROR); + wsInfo.setStatus(j.jobnum, WebserviceInfo.STATE_STOPPED_SERVERERROR); } else if (j.isBroken()) { @@ -104,12 +119,35 @@ public class JobStateSummary wsInfo.setStatus(j.jobnum, WebserviceInfo.STATE_STOPPED_ERROR); } // and pass on any sub-job messages to the user - wsInfo.setProgressText(j.jobnum, OutputHeader); - wsInfo.appendProgressText(j.jobnum, progheader); + StringBuffer output = new StringBuffer(); + if (OutputHeader != null) + { + + output.append(OutputHeader); + } + if (progheader != null) + { + output.append(progheader); + } if (j.hasStatus()) { - wsInfo.appendProgressText(j.jobnum, j.getStatus()); + // Could try to squash OOMs here, but it usually doesn't help - there + // probably won't be + // enough memory to handle the results later on anyway. + // try { + String stat = j.getStatus(); + if (stat != null) + { + output.append(stat); + } + // } catch (OutOfMemoryError e) + // { + // System.err.println("Out of memory when displaying status. Squashing error."); + // wsInfo.appendProgressText(j.jobnum, + // "..\n(Out of memory when displaying status)\n"); + // } } + wsInfo.setProgressText(j.jobnum, output.toString()); } else {