summaryrefslogtreecommitdiff
path: root/stoc/source/javavm
diff options
context:
space:
mode:
Diffstat (limited to 'stoc/source/javavm')
-rw-r--r--stoc/source/javavm/jvmargs.cxx54
-rw-r--r--stoc/source/javavm/jvmargs.hxx15
2 files changed, 50 insertions, 19 deletions
diff --git a/stoc/source/javavm/jvmargs.cxx b/stoc/source/javavm/jvmargs.cxx
index 647be9a00d27..55e2e8afca13 100644
--- a/stoc/source/javavm/jvmargs.cxx
+++ b/stoc/source/javavm/jvmargs.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: jvmargs.cxx,v $
*
- * $Revision: 1.6 $
+ * $Revision: 1.7 $
*
- * last change: $Author: hr $ $Date: 2002-02-21 12:14:56 $
+ * last change: $Author: jbu $ $Date: 2002-04-29 14:12:14 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -73,8 +73,10 @@
#include "jvmargs.hxx"
#include <osl/diagnose.h>
+#include <osl/thread.h>
#include <rtl/ustring.hxx>
+#include <rtl/ustrbuf.hxx>
using namespace rtl;
@@ -126,10 +128,10 @@ namespace stoc_javavm {
_vmtype = right;
else if(left.equals(OUString(RTL_CONSTASCII_USTRINGPARAM("SystemClasspath"))))
- setSystemClasspath(right);
+ addSystemClasspath(right);
else if(left.equals(OUString(RTL_CONSTASCII_USTRINGPARAM("UserClasspath"))))
- setUserClasspath(right);
+ addUserClasspath(right);
else if(left.equals(OUString(RTL_CONSTASCII_USTRINGPARAM("DisableAsyncGC"))))
setDisableAsyncGC(right.toInt32());
@@ -232,18 +234,37 @@ namespace stoc_javavm {
_debugPort = jiValue;
}
- void JVM::setSystemClasspath(const OUString & classpath) throw() {
- OString tmp = OUStringToOString(classpath, RTL_TEXTENCODING_ASCII_US);
- OSL_TRACE("JVM::setSystemClasspath: %s", tmp.getStr());
-
- _systemClasspath = classpath;
+ void JVM::addSystemClasspath(const OUString & classpath) throw() {
+ if( classpath.getLength() )
+ {
+ OString tmp = OUStringToOString(classpath, RTL_TEXTENCODING_ASCII_US);
+ OSL_TRACE("JVM::addSystemClasspath: %s", tmp.getStr());
+
+ OUStringBuffer buf(_systemClasspath.getLength() +1 + classpath.getLength());
+ if( _systemClasspath.getLength() )
+ {
+ buf.append( _systemClasspath );
+ buf.appendAscii( CLASSPATH_DELIMETER );
+ }
+ buf.append( classpath );
+ _systemClasspath = buf.makeStringAndClear();
+ }
}
- void JVM::setUserClasspath(const OUString & classpath) throw() {
- OString tmp = OUStringToOString(classpath, RTL_TEXTENCODING_ASCII_US);
- OSL_TRACE("JVM::setUserClasspath: %s", tmp.getStr());
-
- _userClasspath = classpath;
+ void JVM::addUserClasspath(const OUString & classpath) throw() {
+ if( classpath.getLength() )
+ {
+ OString tmp = OUStringToOString(classpath, RTL_TEXTENCODING_ASCII_US);
+ OSL_TRACE("JVM::addUserClasspath: %s", tmp.getStr());
+ OUStringBuffer buf( _userClasspath.getLength() + 1 + classpath.getLength() );
+ if( _userClasspath.getLength() )
+ {
+ buf.append( _userClasspath );
+ buf.appendAscii( CLASSPATH_DELIMETER );
+ }
+ buf.append( classpath );
+ _userClasspath = buf.makeStringAndClear();
+ }
}
void JVM::setPrint(JNIvfprintf vfprintf) throw() {
@@ -266,7 +287,10 @@ namespace stoc_javavm {
classpath += OUString(RTL_CONSTASCII_USTRINGPARAM(CLASSPATH_DELIMETER));
classpath += _userClasspath;
- pargs->classpath = strdup(OUStringToOString(classpath, RTL_TEXTENCODING_ASCII_US));
+#ifdef DEBUG
+ fprintf( stderr, "JavaVM: using classpath %s\n" , OUStringToOString(classpath, osl_getThreadTextEncoding()).getStr());
+#endif
+ pargs->classpath = strdup(OUStringToOString(classpath, osl_getThreadTextEncoding()));
if(_is_debugPort) {
pargs->debugging = JNI_TRUE;
diff --git a/stoc/source/javavm/jvmargs.hxx b/stoc/source/javavm/jvmargs.hxx
index 88a3fc12dba1..747ee4bbff60 100644
--- a/stoc/source/javavm/jvmargs.hxx
+++ b/stoc/source/javavm/jvmargs.hxx
@@ -2,9 +2,9 @@
*
* $RCSfile: jvmargs.hxx,v $
*
- * $Revision: 1.5 $
+ * $Revision: 1.6 $
*
- * last change: $Author: cp $ $Date: 2002-01-20 20:11:04 $
+ * last change: $Author: jbu $ $Date: 2002-04-29 14:12:14 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -62,6 +62,13 @@
#ifndef __JVM_HXX
#define __JVM_HXX
+#ifdef UNIX
+#define CLASSPATH_DELIMETER ":"
+
+#else
+#define CLASSPATH_DELIMETER ";"
+
+#endif
#include <cstdarg>
#include <vector>
@@ -149,8 +156,8 @@ namespace stoc_javavm {
void setMinHeapSize(jint jiSize) throw();
void setMaxHeapSize(jint jiSize) throw();
void setDebugPort(jint jiDebugPort) throw();
- void setSystemClasspath(const ::rtl::OUString & str) throw();
- void setUserClasspath(const ::rtl::OUString & str) throw();
+ void addSystemClasspath(const ::rtl::OUString & str) throw();
+ void addUserClasspath(const ::rtl::OUString & str) throw();
void setPrint(JNIvfprintf vfprintf) throw();
void setExit(JNIexit exit) throw();
void setAbort(JNIabort abort) throw();