3 * see AUTHORS for the list of contributors
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 package org.sonews.util.io;
21 import java.io.IOException;
22 import java.io.InputStream;
23 import java.nio.ByteBuffer;
24 import java.nio.charset.Charset;
27 * InputStream that can change its decoding charset while reading from the
28 * underlying byte based stream.
29 * @author Christian Lins
32 public class VarCharsetReader
35 private final ByteBuffer buf = ByteBuffer.allocate(4096);
36 private InputStream in;
38 public VarCharsetReader(final InputStream in)
42 throw new IllegalArgumentException("null InputStream");
48 * Reads up to the next newline character and returns the line as String.
49 * The String is decoded using the given charset.
51 public String readLine(Charset charset)
54 byte[] byteBuf = new byte[1];
59 int read = this.in.read(byteBuf);
67 bufStr = new String(this.buf.array(), 0, this.buf.position(), charset);
70 else if(byteBuf[0] == 10) // Is this safe? \n
72 bufStr = new String(this.buf.array(), 0, this.buf.position(), charset);
75 else if(byteBuf[0] == 13) // \r
81 this.buf.put(byteBuf[0]);