All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy