src/org/sonews/daemon/LineEncoder.java
author František Kučera <franta-hg@frantovo.cz>
Mon Oct 17 13:55:28 2011 +0200 (2011-10-17)
changeset 88 cbf1a1153313
parent 35 ed84c8bdd87b
permissions -rwxr-xr-x
Drupal: žádný doctype a povolíme vodorovné čáry <hr/>
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
}