/************************************************************************* * * * This file is part of the 20n/act project. * * 20n/act enables DNA prediction for synthetic biology/bioengineering. * * Copyright (C) 2017 20n Labs, Inc. * * * * Please direct all queries to act@20n.com. * * * * This program is free software: you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation, either version 3 of the License, or * * (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program. If not, see <http://www.gnu.org/licenses/>. * * * *************************************************************************/ package org.twentyn.proteintodna; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileWriter; import java.io.IOException; import java.io.InputStream; import java.io.Writer; public class FileUtils { /** * dump an InputStream, returning a newly created byte[] array */ public static byte[] dumpInputStream(InputStream instream) throws IOException { int lastindex = 0; int increment; byte[] A = new byte[2048]; byte[] B; do { B = new byte[2*A.length]; System.arraycopy(A, 0, B, 0, A.length); A = B; try { increment = instream.read(A, lastindex, A.length - lastindex); } catch (IOException e) { throw e; } if (increment == -1) /* EOF, no characters read */ break; lastindex += increment; } while (lastindex >= A.length); /* copy A into B of precisely correct length */ B = new byte[lastindex]; System.arraycopy(A, 0, B, 0, B.length); return B; } /** * @param fileName * @return */ public static boolean isXMLFile(String fileName) { return isFileType(fileName, "xml"); } /** * @param fileName * @param extension without the . * @return */ public static boolean isFileType(String fileName, String extension) { return fileName.endsWith( "." + extension ); } public static String readFile(String path) { File f = new File(path); if (!f.isFile()) return ""; FileInputStream s; try { s = new FileInputStream(f); } catch (FileNotFoundException e) { return ""; } byte[] content; try { content = dumpInputStream(s); } catch (IOException e) { return ""; } return new String(content); } public static void writeFile(String datafile, String filePath) { try { Writer output = null; File file = new File(filePath); output = new FileWriter(file); output.write(datafile); output.close(); } catch (IOException ex) { ex.printStackTrace(); } } /** * Convenience method to determine the filepath of the persisted data. * @param feature * @return */ public static String getFilePath(String fileName, String DBName) { File afile = new File(DBName); createDir(afile); return afile.getAbsolutePath() + File.separator + fileName; } /** * Helper method, creates directory with parent directories recursiverly. */ private static void createDir(File f) { int limit = 10; while (!f.exists()) { if (!f.mkdir()) { createDir(f.getParentFile()); } limit --; if(limit < 1) { break; } } if (limit == 0) { } } public static String readFile2(String path) throws Exception { File f = new File(path); if (!f.isFile()) { System.err.println("path is not a file: " + path); throw new Exception(); } FileInputStream s; try { s = new FileInputStream(f); } catch (FileNotFoundException e) { System.err.println("File not found: " + path); throw e; } byte[] content; try { content = dumpInputStream(s); } catch (IOException e) { System.err.println("Error reading: " + path); throw e; } return new String(content); } }