org.infinispan.util.stream.Streams Maven / Gradle / Ivy
package org.infinispan.util.stream;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import org.infinispan.util.logging.Log;
import org.infinispan.util.logging.LogFactory;
/**
* A collection of stream related utility methods.
*
* Exceptions that are thrown and not explicitly declared are ignored.
*
* @author Jason Dillon
* @since 4.2
*/
public class Streams {
private static final Log log = LogFactory.getLog(Streams.class);
private static final boolean trace = log.isTraceEnabled();
/////////////////////////////////////////////////////////////////////////
// Closing //
/////////////////////////////////////////////////////////////////////////
/**
* Attempt to close an InputStream.
*
* @param stream InputStream to attempt to close.
* @return True if stream was closed (or stream was null), or
* false if an exception was thrown.
*/
public static boolean close(final InputStream stream) {
// do not attempt to close null stream, but return sucess
if (stream == null) {
return true;
}
boolean success = true;
try {
stream.close();
} catch (IOException e) {
success = false;
}
return success;
}
/**
* Attempt to close an OutputStream.
*
* @param stream OutputStream to attempt to close.
* @return True if stream was closed (or stream was null), or
* false if an exception was thrown.
*/
public static boolean close(final OutputStream stream) {
// do not attempt to close null stream, but return sucess
if (stream == null) {
return true;
}
boolean success = true;
try {
stream.close();
} catch (IOException e) {
success = false;
}
return success;
}
/**
* Attempt to close an InputStream or OutputStream.
*
* @param stream Stream to attempt to close.
* @return True if stream was closed (or stream was null), or
* false if an exception was thrown.
* @throws IllegalArgumentException Stream is not an InputStream or
* OuputStream.
*/
public static boolean close(final Object stream) {
boolean success;
if (stream instanceof InputStream) {
success = close((InputStream) stream);
} else if (stream instanceof OutputStream) {
success = close((OutputStream) stream);
} else {
throw new IllegalArgumentException
("stream is not an InputStream or OutputStream");
}
return success;
}
/**
* Attempt to close an array of InputStreams.
*
* @param streams Array of InputStreams to attempt to close.
* @return True if all streams were closed, or false if an
* exception was thrown.
*/
public static boolean close(final InputStream[] streams) {
boolean success = true;
for (InputStream stream : streams) {
boolean rv = close(stream);
if (!rv) success = false;
}
return success;
}
/**
* Attempt to close an array of OutputStreams.
*
* @param streams Array of OutputStreams to attempt to close.
* @return True if all streams were closed, or false if an
* exception was thrown.
*/
public static boolean close(final OutputStream[] streams) {
boolean success = true;
for (OutputStream stream : streams) {
boolean rv = close(stream);
if (!rv) success = false;
}
return success;
}
/**
* Attempt to close an array of InputStreama and/or
* OutputStreams.
*
* @param streams Array of streams to attempt to close.
* @return True if all streams were closed, or false if an
* exception was thrown.
* @throws IllegalArgumentException Stream is not an InputStream or
* OuputStream. Closing stops at
* the last valid stream object in this
* case.
*/
public static boolean close(final Object[] streams) {
boolean success = true;
for (Object stream : streams) {
boolean rv = close(stream);
if (!rv) success = false;
}
return success;
}
/**
* Attempt to flush and close an OutputStream.
*
* @param stream OutputStream to attempt to flush and close.
* @return True if stream was flushed and closed, or false
* if an exception was thrown.
*/
public static boolean fclose(final OutputStream stream) {
return flush(stream) && close(stream);
}
/**
* Attempt to flush and close an array of OutputStreams.
*
* @param streams OutputStreams to attempt to flush and close.
* @return True if all streams were flushed and closed, or
* false if an exception was thrown.
*/
public static boolean fclose(final OutputStream[] streams) {
boolean success = true;
for (OutputStream stream : streams) {
boolean rv = fclose(stream);
if (!rv) success = false;
}
return success;
}
/////////////////////////////////////////////////////////////////////////
// Flushing //
/////////////////////////////////////////////////////////////////////////
/**
* Attempt to flush an OutputStream.
*
* @param stream OutputStream to attempt to flush.
* @return True if stream was flushed (or stream was null), or
* false if an exception was thrown.
*/
public static boolean flush(final OutputStream stream) {
// do not attempt to close null stream, but return sucess
if (stream == null) {
return true;
}
boolean success = true;
try {
stream.flush();
} catch (IOException e) {
success = false;
}
return success;
}
/**
* Attempt to flush an array of OutputStreams.
*
* @param streams OutputStreams to attempt to flush.
* @return True if all streams were flushed, or false if
* an exception was thrown.
*/
public static boolean flush(final OutputStream[] streams) {
boolean success = true;
for (OutputStream stream : streams) {
boolean rv = flush(stream);
if (!rv) success = false;
}
return success;
}
/////////////////////////////////////////////////////////////////////////
// Misc //
/////////////////////////////////////////////////////////////////////////
/**
* The default buffer size that will be used for buffered operations.
*/
public static final int DEFAULT_BUFFER_SIZE = 2048;
/**
* Copy all of the bytes from the input stream to the output stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @param buffer The buffer to use while copying.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copy(final InputStream input,
final OutputStream output,
final byte buffer[])
throws IOException {
long total = 0;
int read;
if (trace) {
log.tracef("copying %s to %s with buffer size: %d", input, output, buffer.length);
}
while ((read = input.read(buffer)) != -1) {
output.write(buffer, 0, read);
total += read;
if (trace) {
log.tracef("bytes read: %d; total bytes read: %d", read, total);
}
}
return total;
}
/**
* Copy all of the bytes from the input stream to the output stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @param size The size of the buffer to use while copying.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copy(final InputStream input,
final OutputStream output,
final int size)
throws IOException {
return copy(input, output, new byte[size]);
}
/**
* Copy all of the bytes from the input stream to the output stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copy(final InputStream input,
final OutputStream output)
throws IOException {
return copy(input, output, DEFAULT_BUFFER_SIZE);
}
/**
* Copy all of the bytes from the input stream to the output stream wrapping
* streams in buffers as needed.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copyb(InputStream input,
OutputStream output)
throws IOException {
if (!(input instanceof BufferedInputStream)) {
input = new BufferedInputStream(input);
}
if (!(output instanceof BufferedOutputStream)) {
output = new BufferedOutputStream(output);
}
long bytes = copy(input, output, DEFAULT_BUFFER_SIZE);
output.flush();
return bytes;
}
/**
* Copy a limited number of bytes from the input stream to the output
* stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @param buffer The buffer to use while copying.
* @param length The maximum number of bytes to copy.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copySome(final InputStream input,
final OutputStream output,
final byte buffer[],
final long length)
throws IOException {
long total = 0;
int read;
int readLength;
boolean trace = Streams.trace;
// setup the initial readLength, if length is less than the buffer
// size, then we only want to read that much
readLength = Math.min((int) length, buffer.length);
if (trace) {
log.tracef("initial read length: %d", readLength);
}
while (readLength != 0 && (read = input.read(buffer, 0, readLength)) != -1) {
if (trace) log.tracef("read bytes: %d", read);
output.write(buffer, 0, read);
total += read;
if (trace) log.tracef("total bytes read: %d", total);
// update the readLength
readLength = Math.min((int) (length - total), buffer.length);
if (trace) log.tracef("next read length: %d", readLength);
}
return total;
}
/**
* Copy a limited number of bytes from the input stream to the output
* stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @param size The size of the buffer to use while copying.
* @param length The maximum number of bytes to copy.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copySome(final InputStream input,
final OutputStream output,
final int size,
final long length)
throws IOException {
return copySome(input, output, new byte[size], length);
}
/**
* Copy a limited number of bytes from the input stream to the output
* stream.
*
* @param input Stream to read bytes from.
* @param output Stream to write bytes to.
* @param length The maximum number of bytes to copy.
* @return The total number of bytes copied.
* @throws IOException Failed to copy bytes.
*/
public static long copySome(final InputStream input,
final OutputStream output,
final long length)
throws IOException {
return copySome(input, output, DEFAULT_BUFFER_SIZE, length);
}
}