org.carrot2.util.StreamUtils Maven / Gradle / Ivy
/*
* Carrot2 project.
*
* Copyright (C) 2002-2016, Dawid Weiss, Stanisław Osiński.
* All rights reserved.
*
* Refer to the full license file "carrot2.LICENSE"
* in the root folder of the repository checkout or at:
* http://www.carrot2.org/carrot2.LICENSE
*/
package org.carrot2.util;
import java.io.*;
/**
* A set of common helper methods used with input streams and file objects.
*/
public final class StreamUtils
{
/** */
private StreamUtils()
{
// no instances.
}
/**
* Read the contents of an opened stream until EOF (or an exception is thrown). Note
* that this method does close the input stream, regardless whether exception has been
* thrown or not.
*
* @param input Input stream to be read.
* @throws IOException propagated from the underlying stream.
*/
public static byte [] readFullyAndClose(InputStream input) throws IOException
{
try
{
return readFully(input);
}
finally
{
CloseableUtils.close(input);
}
}
/**
* Read the contents of an opened stream until EOF (or an exception is thrown). Note
* that this method does NOT close the stream.
*
* @param input InputStream from which data is to be read.
* @throws IOException propagated from the underlying stream.
*/
public static byte [] readFully(final InputStream input) throws IOException
{
final ByteArrayOutputStream baos = new ByteArrayOutputStream(8 * 1024);
final byte [] buffer = new byte [8 * 1024];
int z;
while ((z = input.read(buffer)) > 0)
{
baos.write(buffer, 0, z);
}
return baos.toByteArray();
}
/**
* Read the contents of an opened Reader until EOF (or an exception is thrown). Note
* that this method does close the input stream, regardless whether exception has been
* thrown or not.
*
* @param input Reader to be read.
* @throws IOException propagated from the underlying stream.
*/
public static char [] readFullyAndClose(Reader input) throws IOException
{
try
{
return readFully(input);
}
finally
{
CloseableUtils.close(input);
}
}
/**
* Read the contents of an opened reader until EOF (or an exception is thrown). Note
* that this method does NOT close the stream.
*
* @param input Reader from which data will be read.
* @throws IOException propagated from the underlying stream.
*/
public static char [] readFully(Reader input) throws IOException
{
final CharArrayWriter baos = new CharArrayWriter(8 * 1024);
final char [] buffer = new char [8 * 1024];
int z;
while ((z = input.read(buffer)) > 0)
{
baos.write(buffer, 0, z);
}
return baos.toCharArray();
}
/**
* Prefetch the entire content of stream
, close it and return
* an {@link InputStream} to an in-memory {@link ByteArrayInputStream}. If
* stream
is already a {@link ByteArrayInputStream}, it is
* returned immediately.
*/
public static InputStream prefetch(InputStream stream) throws IOException
{
if (stream instanceof ByteArrayInputStream)
{
return stream;
}
return new ByteArrayInputStream(readFullyAndClose(stream));
}
/**
* Copies all available data from the input stream to the output stream. Data is
* internally buffered. Neither of the streams will be closed.
*/
public static void copy(InputStream in, OutputStream out, int bufSize)
throws IOException
{
final byte [] buffer = new byte [bufSize];
int tmp;
while ((tmp = in.read(buffer)) > 0)
{
out.write(buffer, 0, tmp);
}
}
/**
* Copies all available data from the input stream to the output stream. Data is
* internally buffered. Both stream will be closed before the method returns.
*/
public static void copyAndClose(InputStream in, OutputStream out, int bufSize)
throws IOException
{
try
{
copy(in, out, bufSize);
}
finally
{
CloseableUtils.close(in, out);
}
}
/**
* A writer with empty implementations of all {@link Writer} methods.
*/
static class NullWriter extends Writer
{
@Override
public void close() throws IOException
{
}
@Override
public void flush() throws IOException
{
}
@Override
public void write(char [] cbuf, int off, int len) throws IOException
{
}
}
/**
* A dummy writer with empty implementations of {@link Writer} methods.
*/
public static final Writer NULL_WRITER = new NullWriter();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy