From 3c3d06543a71591f6ebf49fd01fd4ccdaa25c2c3 Mon Sep 17 00:00:00 2001 From: Reinhard Pointner Date: Wed, 19 Oct 2016 19:48:00 +0800 Subject: [PATCH] Run sysinfo script on startup whenever GroovyPad is displayed --- source/net/filebot/cli/GroovyPad.java | 16 +++++++++++----- source/net/filebot/ui/MainFrame.java | 7 +++++-- 2 files changed, 16 insertions(+), 7 deletions(-) diff --git a/source/net/filebot/cli/GroovyPad.java b/source/net/filebot/cli/GroovyPad.java index 4ee15766..ba2dafa2 100644 --- a/source/net/filebot/cli/GroovyPad.java +++ b/source/net/filebot/cli/GroovyPad.java @@ -44,6 +44,8 @@ import net.filebot.util.TeePrintStream; public class GroovyPad extends JFrame { + public static final String DEFAULT_SCRIPT = "runScript 'sysinfo'"; + public GroovyPad() throws IOException { super("Groovy Pad"); @@ -146,7 +148,7 @@ public class GroovyPad extends JFrame { File pad = ApplicationFolder.AppData.resolve(name); if (!pad.exists()) { // use this default value so people can easily submit bug reports with fn:sysinfo logs - ScriptShellMethods.saveAs("runScript 'sysinfo'", pad); + ScriptShellMethods.saveAs(DEFAULT_SCRIPT, pad); } return FileLocation.create(pad); } @@ -166,17 +168,21 @@ public class GroovyPad extends JFrame { private Runner currentRunner = null; - protected void runScript(ActionEvent evt) { + public void runScript(ActionEvent evt) { // persist script file and clear output try { editor.save(); } catch (IOException e) { - // won't happen + debug.log(Level.WARNING, e, e::getMessage); } - output.setText(""); + output.setText(""); + runScript(editor.getText()); + } + + public void runScript(String script) { if (currentRunner == null || currentRunner.isDone()) { - currentRunner = new Runner(editor.getText()) { + currentRunner = new Runner(script) { @Override protected void done() { diff --git a/source/net/filebot/ui/MainFrame.java b/source/net/filebot/ui/MainFrame.java index dad6453c..fdcfb008 100644 --- a/source/net/filebot/ui/MainFrame.java +++ b/source/net/filebot/ui/MainFrame.java @@ -112,12 +112,15 @@ public class MainFrame extends JFrame { pad.addWindowListener(new WindowAdapter() { @Override public void windowOpened(WindowEvent e) { - MainFrame.this.setVisible(false); + setVisible(false); + + // run default script on startup + pad.runScript(GroovyPad.DEFAULT_SCRIPT); }; @Override public void windowClosing(WindowEvent e) { - MainFrame.this.setVisible(true); + setVisible(true); }; });