Package org.apache.commons.io.input
Class NullReader
- java.lang.Object
-
- java.io.Reader
-
- org.apache.commons.io.input.NullReader
-
- All Implemented Interfaces:
java.io.Closeable,java.lang.AutoCloseable,java.lang.Readable
public class NullReader extends java.io.ReaderA functional, light weightReaderthat emulates a reader of a specified size.This implementation provides a light weight object for testing with an
Readerwhere the contents don't matter.One use case would be for testing the handling of large
Readeras it can emulate that scenario without the overhead of actually processing large numbers of characters - significantly speeding up test execution times.This implementation returns a space from the method that reads a character and leaves the array unchanged in the read methods that are passed a character array. If alternative data is required the
processChar()andprocessChars()methods can be implemented to generate data, for example:public class TestReader extends NullReader { public TestReader(int size) { super(size); } protected char processChar() { return ... // return required value here } protected void processChars(char[] chars, int offset, int length) { for (int i = offset; i < length; i++) { chars[i] = ... // set array value here } } }- Since:
- 1.3
-
-
Constructor Summary
Constructors Constructor Description NullReader()Creates aReaderthat emulates a size 0 reader which supports marking and does not throw EOFException.NullReader(long size)Creates aReaderthat emulates a specified size which supports marking and does not throw EOFException.NullReader(long size, boolean markSupported, boolean throwEofException)Creates aReaderthat emulates a specified size with option settings.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Closes this Reader - resets the internal state to the initial values.longgetPosition()Returns the current position.longgetSize()Returns the size thisReaderemulates.voidmark(int readlimit)Marks the current position.booleanmarkSupported()Indicates whether mark is supported.intread()Reads a character.intread(char[] chars)Reads some characters into the specified array.intread(char[] chars, int offset, int length)Reads the specified number characters into an array.voidreset()Resets the stream to the point when mark was last called.longskip(long numberOfChars)Skips a specified number of characters.
-
-
-
Constructor Detail
-
NullReader
public NullReader()
Creates aReaderthat emulates a size 0 reader which supports marking and does not throw EOFException.- Since:
- 2.7
-
NullReader
public NullReader(long size)
Creates aReaderthat emulates a specified size which supports marking and does not throw EOFException.- Parameters:
size- The size of the reader to emulate.
-
NullReader
public NullReader(long size, boolean markSupported, boolean throwEofException)Creates aReaderthat emulates a specified size with option settings.- Parameters:
size- The size of the reader to emulate.markSupported- Whether this instance will support themark()functionality.throwEofException- Whether this implementation will throw anEOFExceptionor return -1 when the end of file is reached.
-
-
Method Detail
-
getPosition
public long getPosition()
Returns the current position.- Returns:
- the current position.
-
getSize
public long getSize()
Returns the size thisReaderemulates.- Returns:
- The size of the reader to emulate.
-
close
public void close() throws java.io.IOExceptionCloses this Reader - resets the internal state to the initial values.- Specified by:
closein interfacejava.lang.AutoCloseable- Specified by:
closein interfacejava.io.Closeable- Specified by:
closein classjava.io.Reader- Throws:
java.io.IOException- If an error occurs.
-
mark
public void mark(int readlimit)
Marks the current position.- Overrides:
markin classjava.io.Reader- Parameters:
readlimit- The number of characters before this marked position is invalid.- Throws:
java.lang.UnsupportedOperationException- if mark is not supported.
-
markSupported
public boolean markSupported()
Indicates whether mark is supported.- Overrides:
markSupportedin classjava.io.Reader- Returns:
- Whether mark is supported or not.
-
read
public int read() throws java.io.IOExceptionReads a character.- Overrides:
readin classjava.io.Reader- Returns:
- Either The character value returned by
processChar()or-1if the end of file has been reached andthrowEofExceptionis set tofalse. - Throws:
java.io.EOFException- if the end of file is reached andthrowEofExceptionis set totrue.java.io.IOException- if trying to read past the end of file.
-
read
public int read(char[] chars) throws java.io.IOExceptionReads some characters into the specified array.- Overrides:
readin classjava.io.Reader- Parameters:
chars- The character array to read into- Returns:
- The number of characters read or
-1if the end of file has been reached andthrowEofExceptionis set tofalse. - Throws:
java.io.EOFException- if the end of file is reached andthrowEofExceptionis set totrue.java.io.IOException- if trying to read past the end of file.
-
read
public int read(char[] chars, int offset, int length) throws java.io.IOExceptionReads the specified number characters into an array.- Specified by:
readin classjava.io.Reader- Parameters:
chars- The character array to read into.offset- The offset to start reading characters into.length- The number of characters to read.- Returns:
- The number of characters read or
-1if the end of file has been reached andthrowEofExceptionis set tofalse. - Throws:
java.io.EOFException- if the end of file is reached andthrowEofExceptionis set totrue.java.io.IOException- if trying to read past the end of file.
-
reset
public void reset() throws java.io.IOExceptionResets the stream to the point when mark was last called.- Overrides:
resetin classjava.io.Reader- Throws:
java.lang.UnsupportedOperationException- if mark is not supported.java.io.IOException- If no position has been marked or the read limit has been exceed since the last position was marked.
-
skip
public long skip(long numberOfChars) throws java.io.IOExceptionSkips a specified number of characters.- Overrides:
skipin classjava.io.Reader- Parameters:
numberOfChars- The number of characters to skip.- Returns:
- The number of characters skipped or
-1if the end of file has been reached andthrowEofExceptionis set tofalse. - Throws:
java.io.EOFException- if the end of file is reached andthrowEofExceptionis set totrue.java.io.IOException- if trying to read past the end of file.
-
-