author | cli |
Sun, 29 Aug 2010 23:23:15 +0200 | |
changeset 38 | fdfc7225f799 |
parent 37 | 74139325d305 |
permissions | -rw-r--r-- |
chris@1 | 1 |
/* |
chris@1 | 2 |
* SONEWS News Server |
chris@1 | 3 |
* see AUTHORS for the list of contributors |
chris@1 | 4 |
* |
chris@1 | 5 |
* This program is free software: you can redistribute it and/or modify |
chris@1 | 6 |
* it under the terms of the GNU General Public License as published by |
chris@1 | 7 |
* the Free Software Foundation, either version 3 of the License, or |
chris@1 | 8 |
* (at your option) any later version. |
chris@1 | 9 |
* |
chris@1 | 10 |
* This program is distributed in the hope that it will be useful, |
chris@1 | 11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
chris@1 | 12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
chris@1 | 13 |
* GNU General Public License for more details. |
chris@1 | 14 |
* |
chris@1 | 15 |
* You should have received a copy of the GNU General Public License |
chris@1 | 16 |
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
chris@1 | 17 |
*/ |
chris@1 | 18 |
|
chris@1 | 19 |
package org.sonews.daemon; |
chris@1 | 20 |
|
chris@1 | 21 |
import java.nio.ByteBuffer; |
chris@1 | 22 |
import java.nio.CharBuffer; |
chris@1 | 23 |
import java.nio.channels.ClosedChannelException; |
chris@1 | 24 |
import java.nio.charset.Charset; |
chris@1 | 25 |
import java.nio.charset.CharsetEncoder; |
chris@1 | 26 |
import java.nio.charset.CoderResult; |
chris@1 | 27 |
|
chris@1 | 28 |
/** |
chris@1 | 29 |
* Encodes a line to buffers using the correct charset. |
chris@1 | 30 |
* @author Christian Lins |
chris@1 | 31 |
* @since sonews/0.5.0 |
chris@1 | 32 |
*/ |
chris@1 | 33 |
class LineEncoder |
chris@1 | 34 |
{ |
chris@1 | 35 |
|
cli@37 | 36 |
private CharBuffer characters; |
cli@37 | 37 |
private Charset charset; |
chris@1 | 38 |
|
cli@37 | 39 |
/** |
cli@37 | 40 |
* Constructs new LineEncoder. |
cli@37 | 41 |
* @param characters |
cli@37 | 42 |
* @param charset |
cli@37 | 43 |
*/ |
cli@37 | 44 |
public LineEncoder(CharBuffer characters, Charset charset) |
cli@37 | 45 |
{ |
cli@37 | 46 |
this.characters = characters; |
cli@37 | 47 |
this.charset = charset; |
cli@37 | 48 |
} |
chris@1 | 49 |
|
cli@37 | 50 |
/** |
cli@37 | 51 |
* Encodes the characters of this instance to the given ChannelLineBuffers |
cli@37 | 52 |
* using the Charset of this instance. |
cli@37 | 53 |
* @param buffer |
cli@37 | 54 |
* @throws java.nio.channels.ClosedChannelException |
cli@37 | 55 |
*/ |
cli@37 | 56 |
public void encode(ChannelLineBuffers buffer) |
cli@37 | 57 |
throws ClosedChannelException |
cli@37 | 58 |
{ |
cli@37 | 59 |
CharsetEncoder encoder = charset.newEncoder(); |
cli@37 | 60 |
while (characters.hasRemaining()) { |
cli@37 | 61 |
ByteBuffer buf = ChannelLineBuffers.newLineBuffer(); |
cli@37 | 62 |
assert buf.position() == 0; |
cli@37 | 63 |
assert buf.capacity() >= 512; |
chris@1 | 64 |
|
cli@37 | 65 |
CoderResult res = encoder.encode(characters, buf, true); |
cli@37 | 66 |
|
cli@37 | 67 |
// Set limit to current position and current position to 0; |
cli@37 | 68 |
// means make ready for read from buffer |
cli@37 | 69 |
buf.flip(); |
cli@37 | 70 |
buffer.addOutputBuffer(buf); |
cli@37 | 71 |
|
cli@37 | 72 |
if (res.isUnderflow()) // All input processed |
cli@37 | 73 |
{ |
cli@37 | 74 |
break; |
cli@37 | 75 |
} |
cli@37 | 76 |
} |
cli@37 | 77 |
} |
chris@1 | 78 |
} |