X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Finstantlauncher%2FFileAssociationManager.java;h=88545f2f16eec2cba777ac035e488c6cd2a1fda5;hb=d1e8c10e0d84bab26c5bb89d2b17af4988c390a2;hp=5c3cc517c7662ff8b2fc8d688894f9d55370695b;hpb=7afbbed8e0cef27a47dd7599aadc5c2c814c7dea;p=instantlauncher.git diff --git a/src/main/java/eu/svjatoslav/instantlauncher/FileAssociationManager.java b/src/main/java/eu/svjatoslav/instantlauncher/FileAssociationManager.java index 5c3cc51..88545f2 100755 --- a/src/main/java/eu/svjatoslav/instantlauncher/FileAssociationManager.java +++ b/src/main/java/eu/svjatoslav/instantlauncher/FileAssociationManager.java @@ -10,10 +10,46 @@ public class FileAssociationManager { private static final String TEXT_EDITOR = "scribes"; + private static final String DOCUMENT_EDITOR = "lowriter"; + + private static final String SPREADSHEET_EDITOR = "localc"; + private static final String FILE_INDICATOR = ""; + private static final String MUSIC_PLAYER = "clementine"; + public static HashMap extensionToApplication = new HashMap(); + public static boolean openFile(final File file) { + + final String fileExtension = Utils.getFileExtension(file); + + System.out.println("About to open file with extension: " + fileExtension); + + if (extensionToApplication.containsKey(fileExtension)) { + + System.out.println("Commands found"); + + final String[] commands = extensionToApplication.get(fileExtension); + + for (int i = 0; i < commands.length; i++) + if (commands[i].equals(FILE_INDICATOR)) + commands[i] = file.getAbsolutePath(); + + try { + Runtime.getRuntime().exec(commands); + InstantLauncher.exitProgram(); + + } catch (final IOException e) { + new ExceptionDialog(e); + } + + return true; + } else + return false; + + } + public FileAssociationManager() { extensionToApplication.put("txt", new String[] { TEXT_EDITOR, FILE_INDICATOR }); @@ -38,45 +74,22 @@ public class FileAssociationManager { extensionToApplication.put("flv", new String[] { "vlc", FILE_INDICATOR }); extensionToApplication.put("wmv", new String[] { "vlc", FILE_INDICATOR }); - extensionToApplication.put("ods", new String[] { "localc", FILE_INDICATOR }); - - } - - public static boolean openFile(final File file) { - - final String fileExtension = Utils.getFileExtension(file); - - System.out.println("About to open file with extension: " + fileExtension); - - if (extensionToApplication.containsKey(fileExtension)) { - - System.out.println("Commands found"); - - final String[] commands = extensionToApplication.get(fileExtension); + extensionToApplication.put("flac", new String[] { MUSIC_PLAYER, FILE_INDICATOR }); + extensionToApplication.put("mp3", new String[] { MUSIC_PLAYER, FILE_INDICATOR }); + extensionToApplication.put("ogg", new String[] { MUSIC_PLAYER, FILE_INDICATOR }); + extensionToApplication.put("wav", new String[] { MUSIC_PLAYER, FILE_INDICATOR }); - final String[] c = new String[commands.length]; + extensionToApplication.put("ods", new String[] { SPREADSHEET_EDITOR, FILE_INDICATOR }); + extensionToApplication.put("xls", new String[] { SPREADSHEET_EDITOR, FILE_INDICATOR }); + extensionToApplication.put("xlsx", new String[] { SPREADSHEET_EDITOR, FILE_INDICATOR }); - for (int i = 0; i < commands.length; i++) { + extensionToApplication.put("docx", new String[] { DOCUMENT_EDITOR, FILE_INDICATOR }); + extensionToApplication.put("doc", new String[] { DOCUMENT_EDITOR, FILE_INDICATOR }); - if (commands[i].equals(FILE_INDICATOR)) { - c[i] = file.getAbsolutePath(); - } else { - c[i] = commands[i]; - } - } - - try { - Runtime.getRuntime().exec(c); - InstantLauncher.exitProgram(); + extensionToApplication.put("desktop", new String[] { "run-desktop", FILE_INDICATOR }); - } catch (final IOException e) { - new ExceptionDialog(e); - } - - return true; - } else { - return false; - } + extensionToApplication.put("log", new String[] { "glogg", FILE_INDICATOR }); + extensionToApplication.put("out", new String[] { "glogg", FILE_INDICATOR }); }