
org.jwat.common.CharCountingStringReader Maven / Gradle / Ivy
/**
* Java Web Archive Toolkit - Software to read and validate ARC, WARC
* and GZip files. (http://jwat.org/)
* Copyright 2011-2012 Netarkivet.dk (http://netarkivet.dk/)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jwat.common;
import java.io.IOException;
import java.io.StringReader;
/**
* StringReader
that keeps tracks of the number of consumed chars
* at any given time.
*
* @author lbihanic, selghissassi, nicl
*/
public class CharCountingStringReader extends StringReader {
/** Number of consumed bytes since the beginning of the stream. */
protected long consumed = 0;
/** Byte counter which can also be changed. */
protected long counter = 0;
/**
* Creates a new StringReader
that keeps track of
* consumed characters.
* @param str Arbitrary string.
*/
public CharCountingStringReader(String str) {
super(str);
}
@Override
public boolean markSupported() {
return false;
}
@Override
public synchronized void mark(int readlimit) {
}
@Override
public synchronized void reset() throws IOException {
throw new UnsupportedOperationException();
}
/**
* Consumed length getter.
* @return the consumed length
*/
public long getConsumed() {
return consumed;
}
/**
* Change the counter value.
* Useful for reading zero indexed relative data.
* @param bytes new counter value
*/
public void setCounter(long bytes) {
counter = bytes;
}
/**
* Retrieve the current counter value.
* @return current counter value
*/
public long getCounter() {
return counter;
}
@Override
public int read() throws IOException {
int c = super.read();
if (c != -1) {
++consumed;
++counter;
}
return c;
}
@Override
public int read(char[] cbuf, int off, int len) throws IOException {
int bytesRead = super.read(cbuf, off, len);
if (bytesRead > 0) {
consumed += bytesRead;
counter += bytesRead;
}
return bytesRead;
}
@Override
public long skip(long n) throws IOException {
long bytesSkipped = super.skip(n);
consumed += bytesSkipped;
counter += bytesSkipped;
return bytesSkipped;
}
/**
* Reads a line defined as characters read until encountering a
* LF
or EOF.
* @return Line read from buffered StringReader
* @throws IOException if an i/o error occurs while reading line
*/
public String readLine() throws IOException {
StringBuilder buf = new StringBuilder();
int c;
while (true) {
c = read();
if (c == -1) {
return null;
}
if (c == '\n') {
break;
}
if (c != '\r') {
buf.append((char) c);
}
}
return buf.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy