X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fio%2FFileLoader.java;h=a2585b31ff8a0d0a24a6aa6c2f7bd85765a76700;hb=d4271d32477e99e9fbbfa5db3e11f1b79324e60d;hp=7d226ed0a07e5a7ed432d8b923299de5634e9a91;hpb=a327fd39320e482fad4b57f256f3e3c8ebcf015b;p=jalview.git diff --git a/src/jalview/io/FileLoader.java b/src/jalview/io/FileLoader.java index 7d226ed..a2585b3 100755 --- a/src/jalview/io/FileLoader.java +++ b/src/jalview/io/FileLoader.java @@ -96,32 +96,51 @@ public class FileLoader implements Runnable public void LoadFile(AlignViewport viewport, Object file, DataSourceType protocol, FileFormatI format) { + LoadFile(viewport, file, protocol, format, true); + } + + public void LoadFile(AlignViewport viewport, Object file, + DataSourceType protocol, FileFormatI format, boolean async) + { this.viewport = viewport; if (file instanceof File) { this.selectedFile = (File) file; file = selectedFile.getPath(); } - LoadFile(file.toString(), protocol, format); + LoadFile(file.toString(), protocol, format, async); } public void LoadFile(String file, DataSourceType protocol, FileFormatI format) { + LoadFile(file, protocol, format, true); + } + + public void LoadFile(String file, DataSourceType protocol, + FileFormatI format, boolean async) + { this.file = file; this.protocol = protocol; this.format = format; - final Thread loader = new Thread(this); - - SwingUtilities.invokeLater(new Runnable() + if (async) { - @Override - public void run() + final Thread loader = new Thread(this); + + SwingUtilities.invokeLater(new Runnable() { - loader.start(); - } - }); + @Override + public void run() + { + loader.start(); + } + }); + } + else + { + this.run(); + } } /** @@ -273,6 +292,7 @@ public class FileLoader implements Runnable ? "Copied From Clipboard" : file; Runtime rt = Runtime.getRuntime(); + try { if (Desktop.instance != null) @@ -312,7 +332,8 @@ public class FileLoader implements Runnable MessageManager.getString("label.couldnt_read_data"), JvOptionPane.WARNING_MESSAGE); } - this.setShouldBeSaved(); + // don't set shouldBeSaved if didn't load anything + // this.setShouldBeSaved(); return; } // TODO: cache any stream datasources as a temporary file (eg. PDBs @@ -380,12 +401,12 @@ public class FileLoader implements Runnable { if (selectedFile == null) { - al = fa.readFile(file, protocol, format); + al = fa.readFile(null, file, protocol, format); } else { - al = fa.readFile(selectedFile, protocol, format); + al = fa.readFile(selectedFile, null, protocol, format); } source = fa.getAlignFile(); // keep reference for later if