X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Finstantlauncher%2FInstantLauncher.java;h=8c844bac3eae9ff30f2a36a881f6cea63af4e8ae;hb=155895d0ed0f436753bf862287341830653a9c9f;hp=c68c70e2e8ee1cf1d778219201b914566aa5d53a;hpb=8e31839bb326186944811ac3e54a3037ffa75106;p=instantlauncher.git diff --git a/src/main/java/eu/svjatoslav/instantlauncher/InstantLauncher.java b/src/main/java/eu/svjatoslav/instantlauncher/InstantLauncher.java index c68c70e..8c844ba 100755 --- a/src/main/java/eu/svjatoslav/instantlauncher/InstantLauncher.java +++ b/src/main/java/eu/svjatoslav/instantlauncher/InstantLauncher.java @@ -1,25 +1,57 @@ +/* + * Instantlauncher. Copyright ©2012-2019, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of version 3 of the GNU Lesser General Public License + * or later as published by the Free Software Foundation. + */ + package eu.svjatoslav.instantlauncher; -import org.apache.log4j.Logger; +import eu.svjatoslav.instantlauncher.configuration.ConfigurationManager; +import eu.svjatoslav.instantlauncher.configuration.FileAssociation; +import java.io.File; import java.io.IOException; +import static eu.svjatoslav.instantlauncher.Utils.runOpeningApplication; + public class InstantLauncher { - private static final Logger LOGGER = Logger.getLogger(InstantLauncher.class); - public Configuration configuration; - FileAssociationManager associationManager = new FileAssociationManager(); + private final MainFrame mainFrame; + public ConfigurationManager configurationManager; + + public InstantLauncher() throws IOException { + configurationManager = new ConfigurationManager(); + mainFrame = new MainFrame(this); + } public static void exitProgram() { - LOGGER.info("Closing InstantLauncher"); System.exit(0); } - public void run() throws IOException { - configuration = new Configuration(); + /** + * @return true if file was opened. false if + * unknown file type. + */ + public boolean openFile(final File file) { + FileAssociation fileAssociation = configurationManager.getConfiguration().findFileAssociation(file); + if (fileAssociation == null) return false; + + runOpeningApplication(fileAssociation.command, file); + return true; + } - final MainFrame mainFrame = new MainFrame(this); + public void run() { mainFrame.show(); } + public void openDirectory(File chosenFile) { + runOpeningApplication(configurationManager.getConfiguration().directoryOpenCommand, chosenFile); + } + + public void openDirectoryInTerminal(File chosenFile) { + runOpeningApplication(configurationManager.getConfiguration().directoryTerminalOpenCommand, chosenFile); + } + }