5

ErrorDialog.openError接受对话框标题、消息和状态(本身有消息)的参数。

我想在主区域显示异常的消息,在细节区域显示调用堆栈。但是,这两种变体都在主要区域中显示了调用堆栈:

void showException(Throwable e) {
    Status status = 
        new Status(IStatus.ERROR, "SCS Admin", e.getLocalizedMessage(), e);
    e.printStackTrace;
    ErrorDialog.openError(getShell(), null, Util.getStackTrace(e), status);
}

void showException(Throwable e) {
    Status status = 
        new Status(IStatus.ERROR, "SCS Admin", Util.getStackTrace(e), e);
    e.printStackTrace;
    ErrorDialog.openError(getShell(), null, e.getLocalizedMessage(), status);
}

我该如何切换它?

4

3 回答 3

9

在默认的 JFace ErrorDialog 中,显示完整异常堆栈跟踪(与 printStackTrace() 生成的相同)的唯一方法是将堆栈跟踪的每一行构建为一个状态。最后将这些状态设置为 MultiStatus 的子状态。

以下是我在 RCP 应用程序中使用的实用方法示例:

/**
 * Shows JFace ErrorDialog but improved by constructing full stack trace in
 * detail area.
 */
public static void errorDialogWithStackTrace(String msg, Throwable t) {

    StringWriter sw = new StringWriter();
    PrintWriter pw = new PrintWriter(sw);
    t.printStackTrace(pw);

    final String trace = sw.toString(); // stack trace as a string

    // Temp holder of child statuses
    List<Status> childStatuses = new ArrayList<>();

    // Split output by OS-independend new-line
    for (String line : trace.split(System.getProperty("line.separator"))) {
        // build & add status
        childStatuses.add(new Status(IStatus.ERROR, Activator.PLUGIN_ID, line));
    }

    MultiStatus ms = new MultiStatus(Activator.PLUGIN_ID, IStatus.ERROR,
            childStatuses.toArray(new Status[] {}), // convert to array of statuses
            t.getLocalizedMessage(), t);

    ErrorDialog.openError(null, PxConstants.DIALOG_TITLE, msg, ms);
}
于 2012-02-22T22:23:13.027 回答
3

您可以使用包含堆栈跟踪作为消息的新异常来包装异常。

public void showException(final Exception ex) {
    Display.getDefault().syncExec(new Runnable() {
        @Override
        public void run() {
            StringWriter sw = new StringWriter();
            ex.printStackTrace(new PrintWriter(sw));
            IStatus status = new Status(IStatus.ERROR, Activator.PLUGIN_ID, ex.getMessage(), new Exception(sw.toString()));
            ErrorDialog.openError(Display.getDefault().getActiveShell(), "Error", null, status);
        }
    });
}
于 2013-10-31T09:55:19.453 回答
1

看起来您正在混淆 openError 上的第二个和第三个参数。第三个参数是要显示的消息。由于您提供了堆栈跟踪,因此它显示了它。

一旦你得到修复,你可能想看看使用 MultiStatus。

于 2010-11-05T21:09:38.663 回答