org/sonews/daemon/LineEncoder.java
author cli
Sun, 29 Aug 2010 17:03:21 +0200
changeset 33 f9bf183447d1
parent 1 6fceb66e1ad7
permissions -rw-r--r--
Article(javax.mail.Message) now has a safe method to read the byte body from the given message object (fixes #16).
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
chris@1
    36
  private CharBuffer    characters;
chris@1
    37
  private Charset       charset;
chris@1
    38
  
chris@1
    39
  /**
chris@1
    40
   * Constructs new LineEncoder.
chris@1
    41
   * @param characters
chris@1
    42
   * @param charset
chris@1
    43
   */
chris@1
    44
  public LineEncoder(CharBuffer characters, Charset charset)
chris@1
    45
  {
chris@1
    46
    this.characters = characters;
chris@1
    47
    this.charset    = charset;
chris@1
    48
  }
chris@1
    49
  
chris@1
    50
  /**
chris@1
    51
   * Encodes the characters of this instance to the given ChannelLineBuffers
chris@1
    52
   * using the Charset of this instance.
chris@1
    53
   * @param buffer
chris@1
    54
   * @throws java.nio.channels.ClosedChannelException
chris@1
    55
   */
chris@1
    56
  public void encode(ChannelLineBuffers buffer)
chris@1
    57
    throws ClosedChannelException
chris@1
    58
  {
chris@1
    59
    CharsetEncoder encoder = charset.newEncoder();
chris@1
    60
    while (characters.hasRemaining())
chris@1
    61
    {
chris@1
    62
      ByteBuffer buf = ChannelLineBuffers.newLineBuffer();
chris@1
    63
      assert buf.position() == 0;
chris@1
    64
      assert buf.capacity() >= 512;
chris@1
    65
chris@1
    66
      CoderResult res = encoder.encode(characters, buf, true);
chris@1
    67
chris@1
    68
      // Set limit to current position and current position to 0;
chris@1
    69
      // means make ready for read from buffer
chris@1
    70
      buf.flip();
chris@1
    71
      buffer.addOutputBuffer(buf);
chris@1
    72
chris@1
    73
      if (res.isUnderflow()) // All input processed
chris@1
    74
      {
chris@1
    75
        break;
chris@1
    76
      }
chris@1
    77
    }
chris@1
    78
  }
chris@1
    79
  
chris@1
    80
}