java - Eclipse 插件 - 延迟写入控制台

标签 java eclipse plugins

我正在开发一个 Eclipse 插件,它可以读取和写入控制台。我希望以下代码能够闪烁一个带有“Hello World”的警告窗口。

public void run(IAction action) {
        ConsoleCommands.writeToConsole("Hello World!");
        Alert(ConsoleCommands.readConsole());
    }

但是,警报只显示空白。一些调查显示读取发生在写入之前(控制台上的显示很好,只是警报显示控制台的先前状态)所以我尝试了,

public void run(IAction action) {
        ConsoleCommands.writeToConsole("Hello Wolrd!");
        try {
            Thread.sleep(4000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        Alert(ConsoleCommands.readConsole());
    }

以防出现线程问题,但这也只会延迟写入控制台。任何想法发生了什么?

----编辑-----

如果它有用,这里是方法的代码...

import org.eclipse.jface.text.IDocument;
import org.eclipse.ui.console.ConsolePlugin;
import org.eclipse.ui.console.IConsole;
import org.eclipse.ui.console.IConsoleManager;
import org.eclipse.ui.console.MessageConsole;
import org.eclipse.ui.console.MessageConsoleStream;

import org.eclipse.jface.action.IAction;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.jface.text.IDocument;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.ui.IWorkbenchWindow;
import org.eclipse.ui.IWorkbenchWindowActionDelegate;
import org.eclipse.ui.console.ConsolePlugin;
import org.eclipse.ui.console.IConsole;
import org.eclipse.ui.console.IConsoleManager;
import org.eclipse.ui.console.MessageConsole;
import org.eclipse.ui.console.MessageConsoleStream;


public class ConsoleCommands {

    private static MessageConsole findConsole(String name) {
        ConsolePlugin plugin = ConsolePlugin.getDefault();
        IConsoleManager conMan = plugin.getConsoleManager();
        IConsole[] existing = conMan.getConsoles();
        for (int i = 0; i < existing.length; i++)
            if (name.equals(existing[i].getName()))
                return (MessageConsole) existing[i];
        // no console found, so create a new one
        MessageConsole myConsole = new MessageConsole(name, null);
        conMan.addConsoles(new IConsole[] { myConsole });
        return myConsole;
    }

    public static String readConsole() {
        MessageConsole myConsole = findConsole("Joe's Console");
        IDocument doc = myConsole.getDocument();
        return doc.get();
    }

    public static MessageConsole writeToConsole(String output) {
        MessageConsole myConsole = findConsole("Joe's Console");
        MessageConsoleStream out = myConsole.newMessageStream();
        out.println(output);
        return myConsole;
    }

}

最佳答案

尝试使用 myConsole.getDocument().set(output) 而不是使用流写入控制台。

我不知道这是否是推荐的做法,但它为我们解决了问题......

关于java - Eclipse 插件 - 延迟写入控制台,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8781977/

相关文章:

java - Java 中静态方法的范围

java - 自动设置 Eclipse 工作区(导入项目、目标平台和首选项)

java - 扩展 File 类,为用户通过网络 channel 透明地提供一致的文件系统方式

java - 使用反射,我可以确定 Java static final 字段是否将被内联吗?

java - Spring 数据休息 : How to search by another object's key?

java - 如果所有类都扩展了对象,为什么他们不能都调用克隆

java - android开发需要JDK吗

javascript - 更改 ckeditor iframe 对话框 url

xcode - xcode 6.1的plugins文件夹在哪里

plugins - .NET 反射器 + Reflexil 插件