hal/src/zutil/io/IOUtil.java

103 lines
3.3 KiB
Java
Raw Normal View History

2015-05-27 13:13:19 +00:00
/*
* The MIT License (MIT)
*
* Copyright (c) 2015 Ziver Koc
2013-05-28 19:29:24 +00:00
*
2011-07-13 17:53:17 +00:00
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
2013-05-28 19:29:24 +00:00
*
2011-07-13 17:53:17 +00:00
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
2013-05-28 19:29:24 +00:00
*
2011-07-13 17:53:17 +00:00
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
2015-05-27 13:13:19 +00:00
*/
2013-05-28 19:29:24 +00:00
2010-10-27 18:04:52 +00:00
package zutil.io;
2013-12-17 19:18:14 +00:00
import java.io.*;
2010-10-27 18:04:52 +00:00
/**
* Utility class for streams and general IO stuff
*
* @author Ziver
*
*/
public class IOUtil {
/**
2015-03-23 21:05:51 +00:00
* Reads and returns all the content of a stream.
* This function will close the inout stream at the end.
2010-10-27 18:04:52 +00:00
*
2013-12-17 19:18:14 +00:00
* @param stream
* @return the stream contents
2010-10-27 18:04:52 +00:00
*/
2013-12-17 19:18:14 +00:00
public static byte[] getContent(InputStream stream) throws IOException{
DynamicByteArrayStream dyn_buff = new DynamicByteArrayStream();
byte[] buff = new byte[256];
int len = 0;
while((len = stream.read(buff)) != -1){
dyn_buff.append(buff, 0, len);
2010-10-27 18:04:52 +00:00
}
2015-03-23 21:05:51 +00:00
stream.close();
2013-12-17 19:18:14 +00:00
return dyn_buff.getBytes();
2010-10-27 18:04:52 +00:00
}
2013-12-17 19:18:14 +00:00
2015-03-23 21:05:51 +00:00
/**
* Reads and returns all the content of a stream as a String.
2015-12-07 22:40:36 +01:00
* This function will close the input stream at the end.
2015-03-23 21:05:51 +00:00
*
* @param stream
* @return a String with the content of the stream
*/
2015-12-19 13:32:34 +01:00
public static String getContentAsString(InputStream stream) throws IOException{
return getContentAsString(new InputStreamReader(stream));
}
/**
* Reads and returns all the content of a stream as a String.
* This function will close the input stream at the end.
*
* @param reader
* @return a String with the content of the stream
*/
public static String getContentAsString(Reader reader) throws IOException{
2015-03-23 21:05:51 +00:00
StringBuilder str = new StringBuilder();
2015-12-19 13:32:34 +01:00
BufferedReader in = null;
if(reader instanceof BufferedReader)
reader = (BufferedReader) reader;
else
in = new BufferedReader(reader);
2015-03-23 21:05:51 +00:00
String line;
while((line = in.readLine()) != null){
str.append(line).append("\n");
}
in.close();
return str.toString();
}
2013-12-17 19:18:14 +00:00
/**
2015-12-07 22:40:36 +01:00
* Copies all data from the input stream to the output stream.
* The input stream will not be closed after method has returned.
2013-12-17 19:18:14 +00:00
*/
public static void copyStream(InputStream in, OutputStream out) throws IOException {
byte[] buff = new byte[256];
int len;
while((len = in.read(buff)) > 0){
out.write(buff, 0, len);
}
}
2010-10-27 18:04:52 +00:00
}