add support for passing properties to the VM via JNI; use vm.builtins property to specify builtin libraries

This commit is contained in:
Joel Dice 2007-10-25 12:33:43 -06:00
parent 2de0decfe3
commit b12b779c7f
11 changed files with 45 additions and 20 deletions

View File

@ -4,9 +4,9 @@ public class File {
private static final String FileSeparator private static final String FileSeparator
= System.getProperty("file.separator"); = System.getProperty("file.separator");
static { // static {
System.loadLibrary("natives"); // System.loadLibrary("natives");
} // }
private final String path; private final String path;

View File

@ -1,9 +1,9 @@
package java.io; package java.io;
public class FileInputStream extends InputStream { public class FileInputStream extends InputStream {
static { // static {
System.loadLibrary("natives"); // System.loadLibrary("natives");
} // }
private int fd; private int fd;

View File

@ -1,9 +1,9 @@
package java.io; package java.io;
public class FileOutputStream extends OutputStream { public class FileOutputStream extends OutputStream {
static { // static {
System.loadLibrary("natives"); // System.loadLibrary("natives");
} // }
private int fd; private int fd;

View File

@ -19,9 +19,9 @@ public abstract class System {
private static Property properties; private static Property properties;
static { // static {
loadLibrary("natives"); // loadLibrary("natives");
} // }
public static final PrintStream out = new PrintStream public static final PrintStream out = new PrintStream
(new BufferedOutputStream(new FileOutputStream(FileDescriptor.out)), true); (new BufferedOutputStream(new FileOutputStream(FileDescriptor.out)), true);

View File

@ -5,9 +5,9 @@ public class Inflater {
private static final int Z_STREAM_END = 1; private static final int Z_STREAM_END = 1;
private static final int Z_NEED_DICT = 2; private static final int Z_NEED_DICT = 2;
static { // static {
System.loadLibrary("natives"); // System.loadLibrary("natives");
} // }
private long peer; private long peer;
private byte[] input; private byte[] input;

View File

@ -55,7 +55,7 @@ warnings = -Wall -Wextra -Werror -Wunused-parameter \
common-cflags = $(warnings) -fno-rtti -fno-exceptions \ common-cflags = $(warnings) -fno-rtti -fno-exceptions \
-I$(JAVA_HOME)/include -idirafter $(src) -I$(bld) -D__STDC_LIMIT_MACROS \ -I$(JAVA_HOME)/include -idirafter $(src) -I$(bld) -D__STDC_LIMIT_MACROS \
-DBUILTIN_LIBRARIES=\"natives,tlscontext,scaler\" -D_JNI_IMPLEMENTATION_ -D_JNI_IMPLEMENTATION_
system = posix system = posix
asm = x86 asm = x86

View File

@ -496,9 +496,8 @@ Java_java_lang_Runtime_load(Thread* t, jclass, jstring name, jboolean mapName)
char n[length + 1]; char n[length + 1];
stringChars(t, *name, n); stringChars(t, *name, n);
#ifdef BUILTIN_LIBRARIES if (mapName and t->m->builtins) {
if (mapName) { const char* s = t->m->builtins;
const char* s = BUILTIN_LIBRARIES;
while (*s) { while (*s) {
if (strncmp(s, n, length) == 0 if (strncmp(s, n, length) == 0
and (s[length] == ',' or s[length] == 0)) and (s[length] == ',' or s[length] == 0))
@ -511,7 +510,6 @@ Java_java_lang_Runtime_load(Thread* t, jclass, jstring name, jboolean mapName)
} }
} }
} }
#endif // BUILTIN_LIBRARIES
for (System::Library* lib = t->m->libraries; lib; lib = lib->next()) { for (System::Library* lib = t->m->libraries; lib; lib = lib->next()) {
if (lib->name() if (lib->name()

View File

@ -1837,9 +1837,12 @@ JNI_GetDefaultJavaVMInitArgs(void* args)
JDK1_1InitArgs* a = static_cast<JDK1_1InitArgs*>(args); JDK1_1InitArgs* a = static_cast<JDK1_1InitArgs*>(args);
a->maxHeapSize = 128 * 1024 * 1024; a->maxHeapSize = 128 * 1024 * 1024;
a->classpath = "."; a->classpath = ".";
a->properties = 0;
return 0; return 0;
} }
#define BUILTINS_PROPERTY "vm.builtins"
extern "C" JNIEXPORT jint JNICALL extern "C" JNIEXPORT jint JNICALL
JNI_CreateJavaVM(Machine** m, Thread** t, void* args) JNI_CreateJavaVM(Machine** m, Thread** t, void* args)
{ {
@ -1851,6 +1854,15 @@ JNI_CreateJavaVM(Machine** m, Thread** t, void* args)
Processor* p = makeProcessor(s); Processor* p = makeProcessor(s);
*m = new (s->allocate(sizeof(Machine))) Machine(s, h, f, p); *m = new (s->allocate(sizeof(Machine))) Machine(s, h, f, p);
if (a->properties) {
for (const char** p = a->properties; *p; ++p) {
if (strncmp(*p, BUILTINS_PROPERTY, sizeof(BUILTINS_PROPERTY)) == 0) {
(*m)->builtins = (*p) + sizeof(BUILTINS_PROPERTY);
}
}
}
*t = p->makeThread(*m, 0, 0); *t = p->makeThread(*m, 0, 0);
return 0; return 0;

View File

@ -1350,6 +1350,7 @@ Machine::Machine(System* system, Heap* heap, Finder* finder,
rootThread(0), rootThread(0),
exclusive(0), exclusive(0),
jniReferences(0), jniReferences(0),
builtins(0),
activeCount(0), activeCount(0),
liveCount(0), liveCount(0),
localThread(0), localThread(0),

View File

@ -1127,6 +1127,7 @@ class Machine {
Thread* rootThread; Thread* rootThread;
Thread* exclusive; Thread* exclusive;
Reference* jniReferences; Reference* jniReferences;
const char* builtins;
unsigned activeCount; unsigned activeCount;
unsigned liveCount; unsigned liveCount;
System::Local* localThread; System::Local* localThread;

View File

@ -28,12 +28,15 @@ main(int ac, const char** av)
const char* class_ = 0; const char* class_ = 0;
int argc = 0; int argc = 0;
const char** argv = 0; const char** argv = 0;
int propertyCount = 0;
for (int i = 1; i < ac; ++i) { for (int i = 1; i < ac; ++i) {
if (strcmp(av[i], "-cp") == 0) { if (strcmp(av[i], "-cp") == 0) {
vmArgs.classpath = const_cast<char*>(av[++i]); vmArgs.classpath = const_cast<char*>(av[++i]);
} else if (strncmp(av[i], "-Xmx", 4) == 0) { } else if (strncmp(av[i], "-Xmx", 4) == 0) {
vmArgs.maxHeapSize = atoi(av[i] + 4); vmArgs.maxHeapSize = atoi(av[i] + 4);
} else if (strncmp(av[i], "-D", 2) == 0) {
++ propertyCount;
} else { } else {
class_ = av[i++]; class_ = av[i++];
if (i < ac) { if (i < ac) {
@ -44,6 +47,16 @@ main(int ac, const char** av)
} }
} }
const char* properties[propertyCount + 1];
properties[propertyCount] = 0;
for (int i = 1; i < ac; ++i) {
if (strncmp(av[i], "-D", 2) == 0) {
properties[--propertyCount] = av[i] + 2;
}
}
vmArgs.properties = const_cast<char**>(properties);
if (class_ == 0) { if (class_ == 0) {
usageAndExit(av[0]); usageAndExit(av[0]);
} }