mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
progress towards Android classpath support
It now builds and links, but fails at runtime because register_libcore_icu_ICU can't find the file it wants. We'll probably need to replace register_libcore_icu_ICU with a better-behaved version.
This commit is contained in:
parent
0f524fcf16
commit
f45b95e1b5
19
makefile
19
makefile
@ -166,7 +166,16 @@ ifneq ($(android),)
|
|||||||
-fpermissive \
|
-fpermissive \
|
||||||
-fno-exceptions \
|
-fno-exceptions \
|
||||||
-DHAVE_SYS_UIO_H \
|
-DHAVE_SYS_UIO_H \
|
||||||
-D_FILE_OFFSET_BITS=64
|
-D_FILE_OFFSET_BITS=64 \
|
||||||
|
-g3
|
||||||
|
classpath-lflags := $(android)/icu4c/lib/libicuuc.a \
|
||||||
|
$(android)/icu4c/lib/libicui18n.a \
|
||||||
|
$(android)/icu4c/lib/libicudata.a \
|
||||||
|
$(android)/fdlibm/libfdm.a \
|
||||||
|
$(android)/expat/.libs/libexpat.a \
|
||||||
|
$(android)/openssl-1.0.1e/libssl.a \
|
||||||
|
$(android)/openssl-1.0.1e/libcrypto.a \
|
||||||
|
-lstdc++
|
||||||
luni-cpps := $(shell find $(luni-native) -name '*.cpp')
|
luni-cpps := $(shell find $(luni-native) -name '*.cpp')
|
||||||
classpath-objects = \
|
classpath-objects = \
|
||||||
$(call cpp-objects,$(luni-cpps),$(luni-native),$(build))
|
$(call cpp-objects,$(luni-cpps),$(luni-native),$(build))
|
||||||
@ -279,7 +288,7 @@ common-lflags = -lm -lz $(classpath-lflags)
|
|||||||
|
|
||||||
build-lflags = -lz -lpthread -ldl
|
build-lflags = -lz -lpthread -ldl
|
||||||
|
|
||||||
lflags = $(common-lflags) -lpthread -ldl
|
lflags = $(common-lflags) $(classpath-lflags) -lpthread -ldl
|
||||||
|
|
||||||
soname-flag = -Wl,-soname -Wl,$(so-prefix)jvm$(so-suffix)
|
soname-flag = -Wl,-soname -Wl,$(so-prefix)jvm$(so-suffix)
|
||||||
version-script-flag = -Wl,--version-script=openjdk.ld
|
version-script-flag = -Wl,--version-script=openjdk.ld
|
||||||
@ -1217,7 +1226,10 @@ ifneq ($(classpath),avian)
|
|||||||
classpath-sources := $(classpath-sources) \
|
classpath-sources := $(classpath-sources) \
|
||||||
$(classpath-src)/sun/reflect/ConstantPool.java \
|
$(classpath-src)/sun/reflect/ConstantPool.java \
|
||||||
$(classpath-src)/java/lang/ReflectiveOperationException.java \
|
$(classpath-src)/java/lang/ReflectiveOperationException.java \
|
||||||
$(classpath-src)/sun/misc/Cleaner.java
|
$(classpath-src)/java/net/ProtocolFamily.java \
|
||||||
|
$(classpath-src)/java/net/StandardProtocolFamily.java \
|
||||||
|
$(classpath-src)/sun/misc/Cleaner.java \
|
||||||
|
$(classpath-src)/sun/misc/Unsafe.java
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
classpath-sources := $(shell find $(classpath-src) -name '*.java')
|
classpath-sources := $(shell find $(classpath-src) -name '*.java')
|
||||||
@ -1413,6 +1425,7 @@ $(build)/android.dep: $(luni-javas) $(dalvik-javas) $(xml-javas)
|
|||||||
find $(build)/android-src -name '*.java' > $(build)/android.txt
|
find $(build)/android-src -name '*.java' > $(build)/android.txt
|
||||||
$(javac) -Xmaxerrs 1000 -d $(build)/android -sourcepath $(luni-java) \
|
$(javac) -Xmaxerrs 1000 -d $(build)/android -sourcepath $(luni-java) \
|
||||||
@$(build)/android.txt
|
@$(build)/android.txt
|
||||||
|
rm $(build)/android/sun/misc/Unsafe*
|
||||||
cp -r $(build)/android/* $(classpath-build)
|
cp -r $(build)/android/* $(classpath-build)
|
||||||
@touch $(@)
|
@touch $(@)
|
||||||
|
|
||||||
|
@ -8,6 +8,12 @@
|
|||||||
There is NO WARRANTY for this software. See license.txt for
|
There is NO WARRANTY for this software. See license.txt for
|
||||||
details. */
|
details. */
|
||||||
|
|
||||||
|
struct JavaVM;
|
||||||
|
|
||||||
|
extern "C" int JNI_OnLoad(JavaVM*, void*);
|
||||||
|
|
||||||
|
#define _POSIX_C_SOURCE 200112L
|
||||||
|
#undef _GNU_SOURCE
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
#include "classpath-common.h"
|
#include "classpath-common.h"
|
||||||
#include "process.h"
|
#include "process.h"
|
||||||
@ -130,9 +136,9 @@ class MyClasspath : public Classpath {
|
|||||||
}
|
}
|
||||||
|
|
||||||
virtual void
|
virtual void
|
||||||
boot(Thread*)
|
boot(Thread* t)
|
||||||
{
|
{
|
||||||
// ignore
|
JNI_OnLoad(reinterpret_cast< ::JavaVM*>(t->m), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual const char*
|
virtual const char*
|
||||||
@ -170,3 +176,126 @@ makeClasspath(System*, Allocator* allocator, const char*, const char*)
|
|||||||
}
|
}
|
||||||
|
|
||||||
} // namespace vm
|
} // namespace vm
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniRegisterNativeMethods(JNIEnv* e, const char* className,
|
||||||
|
const JNINativeMethod* methods, int methodCount)
|
||||||
|
{
|
||||||
|
jclass c = e->vtable->FindClass(e, className);
|
||||||
|
|
||||||
|
if (c) {
|
||||||
|
e->vtable->RegisterNatives(e, c, methods, methodCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
jniLogException(JNIEnv*, int, const char*, jthrowable)
|
||||||
|
{
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniThrowException(JNIEnv* e, const char* className, const char* message)
|
||||||
|
{
|
||||||
|
jclass c = e->vtable->FindClass(e, className);
|
||||||
|
|
||||||
|
if (c) {
|
||||||
|
e->vtable->ThrowNew(e, c, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniThrowExceptionFmt(JNIEnv* e, const char* className, const char* format,
|
||||||
|
va_list args)
|
||||||
|
{
|
||||||
|
const unsigned size = 4096;
|
||||||
|
char buffer[size];
|
||||||
|
::vsnprintf(buffer, size, format, args);
|
||||||
|
return jniThrowException(e, className, buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniThrowNullPointerException(JNIEnv* e, const char* message)
|
||||||
|
{
|
||||||
|
return jniThrowException(e, "java/lang/NullPointerException", message);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniThrowRuntimeException(JNIEnv* e, const char* message)
|
||||||
|
{
|
||||||
|
return jniThrowException(e, "java/lang/RuntimeException", message);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniThrowIOException(JNIEnv* e, const char* message)
|
||||||
|
{
|
||||||
|
return jniThrowException(e, "java/lang/IOException", message);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" const char*
|
||||||
|
jniStrError(int error, char* buffer, size_t length)
|
||||||
|
{
|
||||||
|
if (static_cast<int>(strerror_r(error, buffer, length)) == 0) {
|
||||||
|
return buffer;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
__android_log_print(int priority, const char* tag, const char* format, ...)
|
||||||
|
{
|
||||||
|
va_list a;
|
||||||
|
const unsigned size = 4096;
|
||||||
|
char buffer[size];
|
||||||
|
|
||||||
|
va_start(a, format);
|
||||||
|
::vsnprintf(buffer, size, format, a);
|
||||||
|
va_end(a);
|
||||||
|
|
||||||
|
return fprintf(stderr, "%d %s %s\n", priority, tag, buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" int
|
||||||
|
jniGetFDFromFileDescriptor(JNIEnv* e, jobject descriptor)
|
||||||
|
{
|
||||||
|
return e->vtable->GetIntField
|
||||||
|
(e, descriptor, e->vtable->GetFieldID
|
||||||
|
(e, e->vtable->FindClass
|
||||||
|
(e, "java/io/FileDescriptor"), "descriptor", "I"));
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" void
|
||||||
|
jniSetFileDescriptorOfFD(JNIEnv* e, jobject descriptor, int value)
|
||||||
|
{
|
||||||
|
e->vtable->SetIntField
|
||||||
|
(e, descriptor, e->vtable->GetFieldID
|
||||||
|
(e, e->vtable->FindClass
|
||||||
|
(e, "java/io/FileDescriptor"), "descriptor", "I"), value);
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" jobject
|
||||||
|
jniCreateFileDescriptor(JNIEnv* e, int fd)
|
||||||
|
{
|
||||||
|
jobject descriptor = e->vtable->NewObject
|
||||||
|
(e, e->vtable->FindClass(e, "java/io/FileDescriptor"),
|
||||||
|
e->vtable->GetMethodID
|
||||||
|
(e, e->vtable->FindClass(e, "java/io/FileDescriptor"), "<init>", "()V"));
|
||||||
|
|
||||||
|
jniSetFileDescriptorOfFD(e, descriptor, fd);
|
||||||
|
|
||||||
|
return descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" struct _JNIEnv;
|
||||||
|
|
||||||
|
int
|
||||||
|
register_org_apache_harmony_dalvik_NativeTestTarget(_JNIEnv*)
|
||||||
|
{
|
||||||
|
// ignore
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -104,7 +104,7 @@ GetEnv(Machine* m, Thread** t, jint version)
|
|||||||
{
|
{
|
||||||
*t = static_cast<Thread*>(m->localThread->get());
|
*t = static_cast<Thread*>(m->localThread->get());
|
||||||
if (*t) {
|
if (*t) {
|
||||||
if (version <= JNI_VERSION_1_4) {
|
if (version <= JNI_VERSION_1_6) {
|
||||||
return JNI_OK;
|
return JNI_OK;
|
||||||
} else {
|
} else {
|
||||||
return JNI_EVERSION;
|
return JNI_EVERSION;
|
||||||
|
Loading…
Reference in New Issue
Block a user