Class StrictLineReader
- All Implemented Interfaces:
Closeable,AutoCloseable
public class StrictLineReader extends Object implements Closeable
InputStream for reading lines.
This class is used for buffered reading of lines. For purposes of this class, a line ends with
"\n" or "\r\n". End of input is reported by throwing EOFException. Unterminated line at
end of input is invalid and will be ignored, the caller may use hasUnterminatedLine()
to detect it after catching the EOFException.
This class is intended for reading input that strictly consists of lines, such as line-based
cache entries or cache journal. Unlike the BufferedReader which in conjunction
with InputStreamReader provides similar functionality, this class uses different
end-of-input reporting and a more restrictive definition of a line.
This class supports only charsets that encode '\r' and '\n' as a single byte with value 13 and 10, respectively, and the representation of no other character contains these values. We currently check in constructor that the charset is one of US-ASCII, UTF-8 and ISO-8859-1. The default charset is US_ASCII.
-
Constructor Summary
Constructors Constructor Description StrictLineReader(InputStream in, int capacity, Charset charset)Constructs a newLineReaderwith the specified capacity and charset.StrictLineReader(InputStream in, Charset charset)Constructs a newLineReaderwith the specified charset and the default capacity. -
Method Summary
-
Constructor Details
-
StrictLineReader
Constructs a newLineReaderwith the specified charset and the default capacity.- Parameters:
in- theInputStreamto read data from.charset- the charset used to decode data. Only US-ASCII, UTF-8 and ISO-8859-1 are supported.- Throws:
NullPointerException- ifinorcharsetis null.IllegalArgumentException- if the specified charset is not supported.
-
StrictLineReader
Constructs a newLineReaderwith the specified capacity and charset.- Parameters:
in- theInputStreamto read data from.capacity- the capacity of the buffer.charset- the charset used to decode data. Only US-ASCII, UTF-8 and ISO-8859-1 are supported.- Throws:
NullPointerException- ifinorcharsetis null.IllegalArgumentException- ifcapacityis negative or zero or the specified charset is not supported.
-
-
Method Details
-
close
Closes the reader by closing the underlyingInputStreamand marking this reader as closed.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Throws:
IOException- for errors when closing the underlyingInputStream.
-
readLine
Reads the next line. A line ends with"\n"or"\r\n", this end of line marker is not included in the result.- Returns:
- the next line from the input.
- Throws:
IOException- for underlyingInputStreamerrors.EOFException- for the end of source stream.
-
readInt
Read anintfrom a line containing its decimal representation.- Returns:
- the value of the
intfrom the next line. - Throws:
IOException- for underlyingInputStreamerrors or conversion error.EOFException- for the end of source stream.
-