config.h.in: Rebuilt.
* include/config.h.in: Rebuilt. * acconfig.h (HAVE_ICONV): Define. * configure: Rebuilt. * configure.in: Check for `iconv' function. * gnu/gcj/convert/BytesToUnicode.java (getDecoder): Try iconv if no specific encoder exists. * gnu/gcj/convert/UnicodeToBytes.java (getEncoder): Try iconv if no specific encoder exists. * Makefile.in: Rebuilt. * Makefile.am (convert_source_files): Mention Input_iconv.java and Output_iconv.java. (nat_source_files): Added natIconv.cc. * gnu/gcj/convert/natIconv.cc: New file. * gnu/gcj/convert/Input_iconv.java: New file. * gnu/gcj/convert/Output_iconv.java: New file. From-SVN: r31708
This commit is contained in:
parent
28531dd03e
commit
946efde181
12 changed files with 295 additions and 55 deletions
|
@ -1,4 +1,4 @@
|
|||
/* Copyright (C) 1999 Red Hat, Inc.
|
||||
/* Copyright (C) 1999, 2000 Red Hat, Inc.
|
||||
|
||||
This file is part of libgcj.
|
||||
|
||||
|
@ -69,8 +69,15 @@ public abstract class BytesToUnicode
|
|||
}
|
||||
catch (Throwable ex)
|
||||
{
|
||||
throw new java.io.UnsupportedEncodingException(encoding
|
||||
+ " (" + ex + ')');
|
||||
try
|
||||
{
|
||||
return new Input_iconv (encoding);
|
||||
}
|
||||
catch (Throwable _)
|
||||
{
|
||||
throw new java.io.UnsupportedEncodingException(encoding
|
||||
+ " (" + ex + ')');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
42
libjava/gnu/gcj/convert/Input_iconv.java
Normal file
42
libjava/gnu/gcj/convert/Input_iconv.java
Normal file
|
@ -0,0 +1,42 @@
|
|||
// Input_iconv.java -- Java side of iconv() reader.
|
||||
|
||||
/* Copyright (C) 2000 Red Hat, Inc.
|
||||
|
||||
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;
|
||||
import gnu.gcj.RawData;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
|
||||
/**
|
||||
* Convert bytes in some iconv-supported encoding to Unicode.
|
||||
* @author Tom Tromey <tromey@redhat.com>
|
||||
* @date January 30, 2000
|
||||
*/
|
||||
|
||||
public class Input_iconv extends BytesToUnicode
|
||||
{
|
||||
public Input_iconv (String encoding) throws UnsupportedEncodingException
|
||||
{
|
||||
this.encoding = encoding;
|
||||
this.handle = null;
|
||||
init (encoding);
|
||||
}
|
||||
|
||||
public String getName() { return encoding; }
|
||||
|
||||
public native void finalize ();
|
||||
private native void init (String encoding)
|
||||
throws UnsupportedEncodingException;
|
||||
public native int read (char[] outbuffer, int outpos, int count);
|
||||
|
||||
// The encoding we're using.
|
||||
private String encoding;
|
||||
|
||||
// The iconv handle.
|
||||
private RawData handle;
|
||||
}
|
42
libjava/gnu/gcj/convert/Output_iconv.java
Normal file
42
libjava/gnu/gcj/convert/Output_iconv.java
Normal file
|
@ -0,0 +1,42 @@
|
|||
// Output_iconv.java -- Java side of iconv() writer.
|
||||
|
||||
/* Copyright (C) 2000 Red Hat, Inc.
|
||||
|
||||
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;
|
||||
import gnu.gcj.RawData;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
|
||||
/**
|
||||
* Convert Unicode to bytes in some iconv-supported encoding.
|
||||
* @author Tom Tromey <tromey@redhat.com>
|
||||
* @date January 30, 2000
|
||||
*/
|
||||
|
||||
public class Output_iconv extends UnicodeToBytes
|
||||
{
|
||||
public Output_iconv (String encoding) throws UnsupportedEncodingException
|
||||
{
|
||||
this.encoding = encoding;
|
||||
this.handle = null;
|
||||
init (encoding);
|
||||
}
|
||||
|
||||
public String getName() { return encoding; }
|
||||
|
||||
public native void finalize ();
|
||||
private native void init (String encoding)
|
||||
throws UnsupportedEncodingException;
|
||||
public native int write (char[] inbuffer, int inpos, int count);
|
||||
|
||||
// The encoding we're using.
|
||||
private String encoding;
|
||||
|
||||
// The iconv handle.
|
||||
private RawData handle;
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
/* Copyright (C) 1999 Red Hat, Inc.
|
||||
/* Copyright (C) 1999, 2000 Red Hat, Inc.
|
||||
|
||||
This file is part of libgcj.
|
||||
|
||||
|
@ -67,8 +67,16 @@ public abstract class UnicodeToBytes
|
|||
}
|
||||
catch (Throwable ex)
|
||||
{
|
||||
throw new java.io.UnsupportedEncodingException(encoding + " ("
|
||||
+ ex + ')');
|
||||
try
|
||||
{
|
||||
return new Output_iconv (encoding);
|
||||
}
|
||||
catch (Throwable _)
|
||||
{
|
||||
// Put the original exception in the throwable.
|
||||
throw new java.io.UnsupportedEncodingException(encoding + " ("
|
||||
+ ex + ')');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -105,5 +113,4 @@ public abstract class UnicodeToBytes
|
|||
str.getChars(inpos, srcEnd, work, 0);
|
||||
return write(work, inpos, inlength);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
142
libjava/gnu/gcj/convert/natIconv.cc
Normal file
142
libjava/gnu/gcj/convert/natIconv.cc
Normal file
|
@ -0,0 +1,142 @@
|
|||
// Input_iconv.java -- Java side of iconv() reader.
|
||||
|
||||
/* Copyright (C) 2000 Red Hat, Inc.
|
||||
|
||||
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. */
|
||||
|
||||
/* Author: Tom Tromey <tromey@redhat.com>. */
|
||||
|
||||
#include <config.h>
|
||||
|
||||
#include <gcj/cni.h>
|
||||
#include <jvm.h>
|
||||
|
||||
#include <gnu/gcj/convert/Input_iconv.h>
|
||||
#include <gnu/gcj/convert/Output_iconv.h>
|
||||
#include <java/io/UnsupportedEncodingException.h>
|
||||
|
||||
#ifdef HAVE_ICONV
|
||||
#include <iconv.h>
|
||||
#endif
|
||||
|
||||
void
|
||||
gnu::gcj::convert::Input_iconv::init (jstring encoding)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
jsize len = _Jv_GetStringUTFLength (encoding);
|
||||
char buffer[len];
|
||||
_Jv_GetStringUTFRegion (encoding, 0, len, buffer);
|
||||
|
||||
iconv_t h = iconv_open ("UCS-2", buffer);
|
||||
if (h == (iconv_t) -1)
|
||||
JvThrow (new java::io::UnsupportedEncodingException);
|
||||
|
||||
JvAssert (h != NULL);
|
||||
handle = reinterpret_cast<gnu::gcj::RawData *> (h);
|
||||
#else /* HAVE_ICONV */
|
||||
// If no iconv, just throw an exception.
|
||||
JvThrow (new java::io::UnsupportedEncodingException);
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
||||
|
||||
void
|
||||
gnu::gcj::convert::Input_iconv::finalize (void)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
if (handle == NULL)
|
||||
{
|
||||
iconv_close ((iconv_t) handle);
|
||||
handle = NULL;
|
||||
}
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
||||
|
||||
jint
|
||||
gnu::gcj::convert::Input_iconv::read (jcharArray outbuffer,
|
||||
jint outpos, jint count)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
jint origpos = outpos;
|
||||
|
||||
jbyte *bytes = elements (inbuffer);
|
||||
jchar *out = elements (outbuffer);
|
||||
size_t inavail = inlength - inpos;
|
||||
size_t old_in = inavail;
|
||||
size_t outavail = count;
|
||||
size_t old_out = outavail;
|
||||
|
||||
size_t r = iconv ((iconv_t) handle,
|
||||
&bytes[inpos], &inavail,
|
||||
&out[outpos], &outavail);
|
||||
// FIXME: what if R==-1?
|
||||
|
||||
inpos += old_in - inavail;
|
||||
return old_out - outavail;
|
||||
#else /* HAVE_ICONV */
|
||||
return -1;
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
||||
|
||||
void
|
||||
gnu::gcj::convert::Output_iconv::init (jstring encoding)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
jsize len = _Jv_GetStringUTFLength (encoding);
|
||||
char buffer[len];
|
||||
_Jv_GetStringUTFRegion (encoding, 0, len, buffer);
|
||||
|
||||
iconv_t h = iconv_open (buffer, "UCS-2");
|
||||
if (h == (iconv_t) -1)
|
||||
JvThrow (new java::io::UnsupportedEncodingException);
|
||||
|
||||
JvAssert (h != NULL);
|
||||
handle = reinterpret_cast<gnu::gcj::RawData *> (h);
|
||||
#else /* HAVE_ICONV */
|
||||
// If no iconv, just throw an exception.
|
||||
JvThrow (new java::io::UnsupportedEncodingException);
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
||||
|
||||
void
|
||||
gnu::gcj::convert::Output_iconv::finalize (void)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
if (handle == NULL)
|
||||
{
|
||||
iconv_close ((iconv_t) handle);
|
||||
handle = NULL;
|
||||
}
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
||||
|
||||
jint
|
||||
gnu::gcj::convert::Output_iconv::write (jcharArray inbuffer,
|
||||
jint inpos, jint count)
|
||||
{
|
||||
#ifdef HAVE_ICONV
|
||||
jint origpos = outpos;
|
||||
|
||||
jchar *chars = elements (inbuffer);
|
||||
jbyte *out = elements (buf);
|
||||
|
||||
size_t inavail = count;
|
||||
size_t old_in = count;
|
||||
|
||||
size_t outavail = buf->length - count;
|
||||
size_t old_out = outavail;
|
||||
|
||||
size_t r = iconv ((iconv_t) handle,
|
||||
&chars[inpos], &inavail,
|
||||
&out[count], &outavail);
|
||||
// FIXME: what if R==-1?
|
||||
|
||||
count += old_out - outavail;
|
||||
return old_in - inavail;
|
||||
#else /* HAVE_ICONV */
|
||||
return -1;
|
||||
#endif /* HAVE_ICONV */
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue