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

时间:2012-01-08 22:35:18

标签: 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());
    }

如果存在线程问题,但这也只会延迟写入控制台。有什么想法发生了什么?

---- ----- EDIT

如果它有用,请参阅方法的代码......

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;
    }

}

1 个答案:

答案 0 :(得分:1)

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

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