mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
add support for passing properties to the VM via JNI; use vm.builtins property to specify builtin libraries
This commit is contained in:
parent
2de0decfe3
commit
b12b779c7f
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
2
makefile
2
makefile
@ -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
|
||||||
|
@ -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()
|
||||||
|
@ -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;
|
||||||
|
@ -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),
|
||||||
|
@ -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;
|
||||||
|
13
src/main.cpp
13
src/main.cpp
@ -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]);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user