Package groovy.io
Class LineColumnReader
java.lang.Object
java.io.Reader
java.io.BufferedReader
groovy.io.LineColumnReader
- All Implemented Interfaces:
Closeable,AutoCloseable,Readable
The
LineColumnReader is an extension to BufferedReader
that keeps track of the line and column information of where the cursor is.- Since:
- 1.8.0
-
Field Summary
-
Constructor Summary
ConstructorsConstructorDescriptionLineColumnReader(Reader reader) Constructor wrapping aReader(FileReader,FileReader,InputStreamReader, etc.) -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Closes the stream and releases any system resources associated with it.longReturns the current column number.longReturns the marked column number.longgetLine()Returns the current line number.longReturns the marked line number.voidmark(int readAheadLimit) Marks the present position in the stream.intread()Reads a single character.intread(char[] chars) Reads characters into an array.intread(char[] chars, int startOffset, int length) Reads characters into a portion of an array.intread(CharBuffer buffer) Not implemented.readLine()Reads a line of text.voidreset()Resets the stream to the most recent mark.voidsetColumn(long column) Sets the current column number.voidsetColumnMark(long columnMark) Sets the marked column number.voidsetLine(long line) Sets the current line number.voidsetLineMark(long lineMark) Sets the marked line number.longskip(long toSkip) Skips characters.Methods inherited from class java.io.BufferedReader
lines, markSupported, readyMethods inherited from class java.io.Reader
nullReader, transferTo
-
Constructor Details
-
LineColumnReader
Constructor wrapping aReader(FileReader,FileReader,InputStreamReader, etc.)- Parameters:
reader- the reader to wrap
-
-
Method Details
-
mark
Marks the present position in the stream. Subsequent calls to reset() will attempt to reposition the stream to this point.- Overrides:
markin classBufferedReader- Parameters:
readAheadLimit- Limit on the number of characters that may be read while still preserving the mark. An attempt to reset the stream after reading characters up to this limit or beyond may fail. A limit value larger than the size of the input buffer will cause a new buffer to be allocated whose size is no smaller than limit. Therefore large values should be used with care.- Throws:
IOException
-
reset
Resets the stream to the most recent mark.- Overrides:
resetin classBufferedReader- Throws:
IOException
-
read
Reads a single character.- Overrides:
readin classBufferedReader- Returns:
- The character read, as an integer in the range 0 to 65535 (0x00-0xffff), or -1 if the end of the stream has been reached
- Throws:
IOException
-
read
Reads characters into a portion of an array.- Overrides:
readin classBufferedReader- Parameters:
chars- Destination array of charstartOffset- Offset at which to start storing characterslength- Maximum number of characters to read- Returns:
- an exception if an error occurs
- Throws:
IOException
-
readLine
Reads a line of text. A line is considered to be terminated by any one of a line feed ('\n'), a carriage return ('\r'), or a carriage return followed immediately by a linefeed.- Overrides:
readLinein classBufferedReader- Returns:
- A String containing the contents of the line, not including any line-termination characters, or null if the end of the stream has been reached
- Throws:
IOException
-
skip
Skips characters.- Overrides:
skipin classBufferedReader- Parameters:
toSkip- the number of characters to skip- Returns:
- The number of characters actually skipped
- Throws:
IOException
-
read
Reads characters into an array. This method will block until some input is available, an I/O error occurs, or the end of the stream is reached.- Overrides:
readin classReader- Parameters:
chars- Destination buffer- Returns:
- The number of characters read, or -1 if the end of the stream has been reached
- Throws:
IOException
-
read
Not implemented.- Specified by:
readin interfaceReadable- Overrides:
readin classReader- Parameters:
buffer- Destination buffer- Returns:
- The number of characters read, or -1 if the end of the stream has been reached
- Throws:
UnsupportedOperationException- as the method is not implemented
-
close
Closes the stream and releases any system resources associated with it. Once the stream has been closed, further read(), ready(), mark(), reset(), or skip() invocations will throw an IOException. Closing a previously closed stream has no effect.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Overrides:
closein classBufferedReader- Throws:
IOException
-
getColumn
public long getColumn()Returns the current column number.- Returns:
- the current column number
-
setColumn
public void setColumn(long column) Sets the current column number.- Parameters:
column- the current column number
-
getColumnMark
public long getColumnMark()Returns the marked column number.- Returns:
- the marked column number
-
setColumnMark
public void setColumnMark(long columnMark) Sets the marked column number.- Parameters:
columnMark- the marked column number
-
getLine
public long getLine()Returns the current line number.- Returns:
- the current line number
-
setLine
public void setLine(long line) Sets the current line number.- Parameters:
line- the current line number
-
getLineMark
public long getLineMark()Returns the marked line number.- Returns:
- the marked line number
-
setLineMark
public void setLineMark(long lineMark) Sets the marked line number.- Parameters:
lineMark- the marked line number
-