/*
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* Copyright (c) 2006 - 2013 Pentaho Corporation and Contributors. All rights reserved.
*/
package org.pentaho.reporting.libraries.fonts.encoding.manual;
import java.io.UnsupportedEncodingException;
import java.util.Locale;
import org.pentaho.reporting.libraries.fonts.encoding.ByteBuffer;
import org.pentaho.reporting.libraries.fonts.encoding.CodePointBuffer;
import org.pentaho.reporting.libraries.fonts.encoding.Encoding;
import org.pentaho.reporting.libraries.fonts.encoding.EncodingErrorType;
import org.pentaho.reporting.libraries.fonts.encoding.EncodingException;
public class BuiltInJavaEncoding implements Encoding
{
private String name;
private boolean fastMode;
public BuiltInJavaEncoding (final String name, final boolean fastMode)
{
if (name == null)
{
throw new NullPointerException();
}
this.name = name;
this.fastMode = fastMode;
}
public CodePointBuffer decode (final ByteBuffer text, final CodePointBuffer buffer)
throws EncodingException
{
try
{
final byte[] rawData = text.getData();
final String decoded =
new String (rawData, text.getOffset(), text.getLength(), name);
return Utf16LE.getInstance().decodeString(decoded, buffer);
}
catch (UnsupportedEncodingException e)
{
// this should not happen, as the encodings should have been checked by
// the system already ...
throw new EncodingException("Failed to encode the string: " + e.getMessage());
}
}
public CodePointBuffer decode (final ByteBuffer text, final CodePointBuffer buffer,
final EncodingErrorType errorHandling)
throws EncodingException
{
return decode(text, buffer);
}
/**
* Encode, but ignore errors.
*
* @param text
* @param buffer
* @return
*/
public ByteBuffer encode (final CodePointBuffer text, ByteBuffer buffer)
throws EncodingException
{
final String javaText =
Utf16LE.getInstance().encodeString(text);
try
{
final byte[] data = javaText.getBytes(name);
final int textLength = text.getLength();
if (buffer == null)
{
buffer = new ByteBuffer(textLength * 2);
}
else if ((buffer.getLength() * 2) < textLength)
{
buffer.ensureSize(textLength * 2);
}
System.arraycopy(data, 0, buffer.getData(), buffer.getOffset(), data.length);
}
catch (UnsupportedEncodingException e)
{
// this should not happen, as the encodings should have been checked by
// the system already ...
throw new EncodingException("Failed to encode the string: " + e.getMessage());
}
return buffer;
}
public ByteBuffer encode (final CodePointBuffer text, final ByteBuffer buffer,
final EncodingErrorType errorHandling)
throws EncodingException
{
return encode(text, buffer);
}
public String getName ()
{
return name;
}
public String getName (final Locale locale)
{
return name;
}
public boolean isUnicodeCharacterSupported (final int c)
{
// Damn, either fast or dead slow
if (fastMode)
{
return true;
}
// cant test that one ...
if (c == 0x3f)
{
return true;
}
final String testEncoding = String.valueOf((char) c);
try
{
final byte[] bytes = testEncoding.getBytes(name);
if (bytes.length != 1)
{
// Assume that everything went well, as if it didn't,
// it should have created a single-byte sequence
return true;
}
return (0x3f != bytes[0]);
}
catch (UnsupportedEncodingException e)
{
// this should not happen, as the encodings should have been checked by
// the system already ...
throw new IllegalStateException("Failed to encode the string: " + e.getMessage());
}
}
}