X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fio%2FFileParse.java;h=a5a4e3665204717acb2a2d08004bd02c7f8788a7;hb=refs%2Fheads%2FJalview-JS%2Fbug%2FJAL-3762_URLparamsOverrideInfoArg;hp=4df916564455c5bf3471d3bd59cfa818fca28599;hpb=c945c9641de88cad01b09b3db19e45667dfe751e;p=jalview.git diff --git a/src/jalview/io/FileParse.java b/src/jalview/io/FileParse.java index 4df9165..a5a4e36 100755 --- a/src/jalview/io/FileParse.java +++ b/src/jalview/io/FileParse.java @@ -20,12 +20,6 @@ */ package jalview.io; -import jalview.api.AlignExportSettingI; -import jalview.api.AlignViewportI; -import jalview.api.AlignmentViewPanel; -import jalview.api.FeatureSettingsModelI; -import jalview.util.MessageManager; - import java.io.BufferedReader; import java.io.ByteArrayInputStream; import java.io.File; @@ -40,6 +34,13 @@ import java.net.MalformedURLException; import java.net.URL; import java.util.zip.GZIPInputStream; +import jalview.api.AlignExportSettingsI; +import jalview.api.AlignViewportI; +import jalview.api.AlignmentViewPanel; +import jalview.api.FeatureSettingsModelI; +import jalview.util.MessageManager; +import jalview.util.Platform; + /** * implements a random access wrapper around a particular datasource, for * passing to identifyFile and AlignFile objects. @@ -72,7 +73,7 @@ public class FileParse /** * specific settings for exporting data from the current context */ - private AlignExportSettingI exportSettings; + private AlignExportSettingsI exportSettings; /** * sequence counter for FileParse object created from same data source @@ -331,15 +332,10 @@ public class FileParse } private void parse(File file, String fileStr, DataSourceType sourceType, - boolean isFileObject) throws MalformedURLException, IOException - { - /** - * @j2sNative - * - * this.bytes = file && file._bytes; - * - */ - this.dataSourceType = sourceType; + boolean isFileObject) throws IOException + { + bytes = Platform.getFileBytes(file); + dataSourceType = sourceType; error = false; if (sourceType == DataSourceType.FILE) @@ -375,16 +371,10 @@ public class FileParse } else if (sourceType == DataSourceType.RELATIVE_URL) { - /** - * BH 2018 hack for no support for access-origin - * - * @j2sNative - * - * this.bytes = swingjs.JSToolkit.getFileAsBytes(fileStr); - * - */ - - dataIn = new BufferedReader(new java.io.InputStreamReader(new ByteArrayInputStream(bytes))); + // BH 2018 hack for no support for access-origin + bytes = Platform.getFileAsBytes(fileStr); + dataIn = new BufferedReader( + new InputStreamReader(new ByteArrayInputStream(bytes))); dataName = fileStr; } @@ -434,8 +424,7 @@ public class FileParse else if (sourceType == DataSourceType.CLASSLOADER) { errormessage = "RESOURCE CANNOT BE LOCATED"; - java.io.InputStream is = getClass() - .getResourceAsStream("/" + fileStr); + InputStream is = getClass().getResourceAsStream("/" + fileStr); if (is == null) { String suffixLess = extractSuffix(fileStr); @@ -446,7 +435,7 @@ public class FileParse } if (is != null) { - dataIn = new BufferedReader(new java.io.InputStreamReader(is)); + dataIn = new BufferedReader(new InputStreamReader(is)); dataName = fileStr; } else @@ -634,7 +623,7 @@ public class FileParse /** * @return the currently configured exportSettings for writing data. */ - public AlignExportSettingI getExportSettings() + public AlignExportSettingsI getExportSettings() { return exportSettings; } @@ -645,7 +634,7 @@ public class FileParse * @param exportSettings * the exportSettings to set */ - public void setExportSettings(AlignExportSettingI exportSettings) + public void setExportSettings(AlignExportSettingsI exportSettings) { this.exportSettings = exportSettings; } @@ -680,4 +669,61 @@ public class FileParse { return dataSourceType; } + + /** + * Returns a buffered reader for the input object. Returns null, or throws + * IOException, on failure. + * + * @param file + * a File, or a String which is a name of a file + * @param sourceType + * @return + * @throws IOException + */ + public BufferedReader getBufferedReader(Object file, + DataSourceType sourceType) throws IOException + { + BufferedReader in = null; + byte[] bytes; + + switch (sourceType) + { + case FILE: + if (file instanceof String) + { + return new BufferedReader(new FileReader((String) file)); + } + bytes = Platform.getFileBytes((File) file); + if (bytes != null) + { + return new BufferedReader( + new InputStreamReader(new ByteArrayInputStream(bytes))); + } + return new BufferedReader(new FileReader((File) file)); + case URL: + URL url = new URL(file.toString()); + in = new BufferedReader(new InputStreamReader(url.openStream())); + break; + case RELATIVE_URL: // JalviewJS only + bytes = Platform.getFileAsBytes(file.toString()); + if (bytes != null) + { + in = new BufferedReader( + new InputStreamReader(new ByteArrayInputStream(bytes))); + } + break; + case PASTE: + in = new BufferedReader(new StringReader(file.toString())); + break; + case CLASSLOADER: + InputStream is = getClass().getResourceAsStream("/" + file); + if (is != null) + { + in = new BufferedReader(new InputStreamReader(is)); + } + break; + } + + return in; + } }