2000-03-08 03:55:28 +08:00
|
|
|
/* Copyright (C) 1999, 2000 Free Software Foundation
|
1999-04-07 22:42:40 +08:00
|
|
|
|
|
|
|
This file is part of libgcj.
|
|
|
|
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
package gnu.gcj.convert;
|
|
|
|
|
2000-08-03 03:56:53 +08:00
|
|
|
public abstract class UnicodeToBytes extends IOConverter
|
1999-04-07 22:42:40 +08:00
|
|
|
{
|
|
|
|
/** Buffer to emit bytes to.
|
|
|
|
* The locations buf[count] ... buf[buf.length-1] are available. */
|
|
|
|
public byte[] buf;
|
|
|
|
public int count;
|
|
|
|
|
|
|
|
static Class defaultEncodingClass;
|
|
|
|
|
|
|
|
static synchronized void getDefaultEncodingClass()
|
|
|
|
{
|
|
|
|
// Test (defaultEncodingClass == null) again in case of race condition.
|
|
|
|
if (defaultEncodingClass == null)
|
|
|
|
{
|
2000-08-03 03:56:53 +08:00
|
|
|
String encoding = canonicalize (System.getProperty("file.encoding"));
|
1999-04-07 22:42:40 +08:00
|
|
|
String className = "gnu.gcj.convert.Output_"+encoding;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
defaultEncodingClass = Class.forName(className);
|
|
|
|
}
|
|
|
|
catch (ClassNotFoundException ex)
|
|
|
|
{
|
|
|
|
throw new NoClassDefFoundError("missing default encoding "
|
|
|
|
+ encoding + " (class "
|
|
|
|
+ className + " not found)");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public abstract String getName();
|
|
|
|
|
|
|
|
public static UnicodeToBytes getDefaultEncoder()
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
if (defaultEncodingClass == null)
|
|
|
|
getDefaultEncodingClass();
|
|
|
|
return (UnicodeToBytes) defaultEncodingClass.newInstance();
|
|
|
|
}
|
|
|
|
catch (Throwable ex)
|
|
|
|
{
|
2000-09-11 08:35:51 +08:00
|
|
|
try
|
|
|
|
{
|
|
|
|
return new Output_iconv (System.getProperty ("file.encoding"));
|
|
|
|
}
|
|
|
|
catch (Throwable ex2)
|
|
|
|
{
|
|
|
|
return new Output_8859_1();
|
|
|
|
}
|
1999-04-07 22:42:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Get a char-stream->byte-stream converter given an encoding name. */
|
|
|
|
public static UnicodeToBytes getEncoder (String encoding)
|
|
|
|
throws java.io.UnsupportedEncodingException
|
|
|
|
{
|
2000-08-03 03:56:53 +08:00
|
|
|
String className = "gnu.gcj.convert.Output_" + canonicalize (encoding);
|
1999-04-07 22:42:40 +08:00
|
|
|
Class encodingClass;
|
|
|
|
try
|
|
|
|
{
|
|
|
|
encodingClass = Class.forName(className);
|
|
|
|
return (UnicodeToBytes) encodingClass.newInstance();
|
|
|
|
}
|
|
|
|
catch (Throwable ex)
|
|
|
|
{
|
2000-01-31 12:53:47 +08:00
|
|
|
try
|
|
|
|
{
|
2000-08-03 03:56:53 +08:00
|
|
|
// We pass the original name to iconv and let it handle
|
|
|
|
// its own aliasing.
|
2000-01-31 12:53:47 +08:00
|
|
|
return new Output_iconv (encoding);
|
|
|
|
}
|
|
|
|
catch (Throwable _)
|
|
|
|
{
|
|
|
|
// Put the original exception in the throwable.
|
|
|
|
throw new java.io.UnsupportedEncodingException(encoding + " ("
|
|
|
|
+ ex + ')');
|
|
|
|
}
|
1999-04-07 22:42:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public final void setOutput(byte[] buffer, int count)
|
|
|
|
{
|
|
|
|
this.buf = buffer;
|
|
|
|
this.count = count;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Convert chars to bytes.
|
|
|
|
* Converted bytes are written to buf, starting at count.
|
UnicodeToBytes.java (write(String,int,int,char[])): New overloading, allows greater efficiency.
�
* gnu/gcj/convert/UnicodeToBytes.java (write(String,int,int,char[])):
New overloading, allows greater efficiency.
* gnu/gcj/convert/Output_8859_1.java (write(String,int,int,char[])):
New overloading (for efficiency - avoids copying).
* gnu/gcj/convert/Output_UTF8.java: Fix typo: 0xC0 -> 0c3F.
* gnu/gcj/convert/Input_UTF8.java: Fix typos in bit masks.
From-SVN: r26494
1999-04-17 01:22:02 +08:00
|
|
|
* @param inbuffer source of characters to convert
|
|
|
|
* @param inpos index of initial character in inbuffer to convert
|
1999-04-07 22:42:40 +08:00
|
|
|
* @param inlength number of characters to convert
|
|
|
|
* @return number of chars converted
|
|
|
|
* Also, this.count is increment by the number of bytes converted.
|
|
|
|
*/
|
|
|
|
public abstract int write (char[] inbuffer, int inpos, int inlength);
|
UnicodeToBytes.java (write(String,int,int,char[])): New overloading, allows greater efficiency.
�
* gnu/gcj/convert/UnicodeToBytes.java (write(String,int,int,char[])):
New overloading, allows greater efficiency.
* gnu/gcj/convert/Output_8859_1.java (write(String,int,int,char[])):
New overloading (for efficiency - avoids copying).
* gnu/gcj/convert/Output_UTF8.java: Fix typo: 0xC0 -> 0c3F.
* gnu/gcj/convert/Input_UTF8.java: Fix typos in bit masks.
From-SVN: r26494
1999-04-17 01:22:02 +08:00
|
|
|
|
|
|
|
/** Convert chars to bytes.
|
|
|
|
* Converted bytes are written to buf, starting at count.
|
|
|
|
* @param str source of characters to convert
|
|
|
|
* @param inpos index of initial character in str to convert
|
|
|
|
* @param inlength number of characters to convert
|
|
|
|
* @param work if non-null, a buffer than can be used
|
|
|
|
* @return number of chars converted
|
|
|
|
* Also, this.count is increment by the number of bytes converted.
|
|
|
|
*/
|
|
|
|
public int write (String str, int inpos, int inlength, char[] work)
|
|
|
|
{
|
|
|
|
if (work == null)
|
|
|
|
work = new char[inlength];
|
|
|
|
int srcEnd = inpos + (inlength > work.length ? work.length : inlength);
|
|
|
|
str.getChars(inpos, srcEnd, work, 0);
|
|
|
|
return write(work, inpos, inlength);
|
|
|
|
}
|
1999-04-07 22:42:40 +08:00
|
|
|
}
|