diff options
author | Tom Tromey <tromey@redhat.com> | 2001-12-11 04:03:57 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2001-12-11 04:03:57 +0000 |
commit | 1ca1c91bd9800301188e167d169dfde8947b4f54 (patch) | |
tree | f0bd1b8b42ebddf95297eedc5da2982e2d850812 /libjava/prims.cc | |
parent | d12a187337e82450144973ddd957287408318050 (diff) | |
download | gcc-1ca1c91bd9800301188e167d169dfde8947b4f54.zip gcc-1ca1c91bd9800301188e167d169dfde8947b4f54.tar.gz gcc-1ca1c91bd9800301188e167d169dfde8947b4f54.tar.bz2 |
For PR libgcj/1147:
* prims.cc (JvConvertArgv): Convert using current locale's
encoding.
From-SVN: r47862
Diffstat (limited to 'libjava/prims.cc')
-rw-r--r-- | libjava/prims.cc | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/libjava/prims.cc b/libjava/prims.cc index f2f2d65..5a4c3a6 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -657,12 +657,20 @@ JvConvertArgv (int argc, const char **argv) if (argc < 0) argc = 0; jobjectArray ar = JvNewObjectArray(argc, &StringClass, NULL); - jobject* ptr = elements(ar); + jobject *ptr = elements(ar); + jbyteArray bytes = NULL; for (int i = 0; i < argc; i++) { const char *arg = argv[i]; - // FIXME - should probably use JvNewStringUTF. - *ptr++ = JvNewStringLatin1(arg, strlen(arg)); + int len = strlen (arg); + if (bytes == NULL || bytes->length < len) + bytes = JvNewByteArray (len); + jbyte *bytePtr = elements (bytes); + // We assume jbyte == char. + memcpy (bytePtr, arg, len); + + // Now convert using the default encoding. + *ptr++ = new java::lang::String (bytes, 0, len); } return (JArray<jstring>*) ar; } @@ -993,7 +1001,7 @@ _Jv_RunMain (jclass klass, const char *name, int argc, const char **argv, runtime = java::lang::Runtime::getRuntime (); arg_vec = JvConvertArgv (argc - 1, argv + 1); - + if (klass) main_thread = new gnu::gcj::runtime::FirstThread (klass, arg_vec); else |