summaryrefslogtreecommitdiff
path: root/src/fakejvm/jvm.c
diff options
context:
space:
mode:
authorJari Vetoniemi <mailroxas@gmail.com>2018-02-19 11:56:51 +0200
committerJari Vetoniemi <mailroxas@gmail.com>2018-02-19 12:00:35 +0200
commita7a253f9d4cc82794c5a5360f3a017fd9b63de9b (patch)
tree540f1dfc6ef3671e710a05cb94e0fd194fee05c8 /src/fakejvm/jvm.c
parent12d58ade2732e7ce0a644371ca10a1dd234c5bc1 (diff)
jvm: rename fakejvm to jvm
Diffstat (limited to 'src/fakejvm/jvm.c')
-rw-r--r--src/fakejvm/jvm.c2355
1 files changed, 0 insertions, 2355 deletions
diff --git a/src/fakejvm/jvm.c b/src/fakejvm/jvm.c
deleted file mode 100644
index db4e3ed..0000000
--- a/src/fakejvm/jvm.c
+++ /dev/null
@@ -1,2355 +0,0 @@
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-#include <stddef.h>
-#include <stdint.h>
-#include <assert.h>
-#include "jvm.h"
-
-#define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0]))
-#define container_of(ptr, type, member) ((type *)((char *)(1 ? (ptr) : &((type *)0)->member) - offsetof(type, member)))
-
-static inline char*
-ccopy(const char *str, const size_t len, const bool null_terminate)
-{
- assert(str);
- char *cpy = calloc(1, len + null_terminate);
- return (cpy ? memcpy(cpy, str, len) : NULL);
-}
-
-static void
-jvm_string_release(struct jvm_string *string)
-{
- if (!string)
- return;
-
- if (string->heap)
- free((char*)string->data);
-
- *string = (struct jvm_string){0};
-}
-
-static bool
-jvm_string_set_cstr_with_length(struct jvm_string *string, const char *data, const size_t len, const bool heap)
-{
- assert(string);
-
- char *copy = (char*)data;
- if (heap && data && len > 0 && !(copy = ccopy(data, len, true)))
- return false;
-
- jvm_string_release(string);
- string->heap = heap;
- string->data = (len > 0 ? copy : NULL);
- string->size = len;
- return true;
-}
-
-static bool
-jvm_string_set_cstr(struct jvm_string *string, const char *data, const bool heap)
-{
- assert(string);
- return jvm_string_set_cstr_with_length(string, data, (data ? strlen(data) : 0), heap);
-}
-
-static inline bool
-jvm_string_eq(const struct jvm_string *a, const struct jvm_string *b)
-{
- return (a->data == b->data) || (a->size == b->size && !memcmp(a->data, b->data, a->size));
-}
-
-static void
-release_array(struct jvm_object *o)
-{
- assert(o);
- free(o->array.data);
-}
-
-static void
-release_method(struct jvm_object *o)
-{
- assert(o);
- jvm_string_release(&o->method.name);
- jvm_string_release(&o->method.signature);
-}
-
-static void
-release_class(struct jvm_object *o)
-{
- assert(o);
- jvm_string_release(&o->klass.name);
-}
-
-static void
-release_string(struct jvm_object *o)
-{
- assert(o);
- jvm_string_release(&o->string);
-}
-
-static void
-jvm_object_release(struct jvm_object *o)
-{
- if (!o || o->type == JVM_OBJECT_NONE)
- return;
-
- void (*destructor[])(struct jvm_object *o) = {
- NULL,
- release_array,
- release_method,
- release_class,
- release_string,
- };
-
- assert(o->type < JVM_OBJECT_LAST);
- destructor[o->type](o);
- *o = (struct jvm_object){0};
-}
-
-static bool
-compare_array(const struct jvm_object *a, const struct jvm_object *b)
-{
- assert(a && b);
- const size_t a_sz = a->array.size * a->array.element_sz;
- const size_t b_sz = b->array.size * b->array.element_sz;
- return (a_sz == b_sz && !memcmp(a->array.data, b->array.data, a_sz));
-}
-
-static bool
-compare_method(const struct jvm_object *a, const struct jvm_object *b)
-{
- assert(a && b);
- return a->method.klass == b->method.klass &&
- jvm_string_eq(&a->method.name, &b->method.name) &&
- jvm_string_eq(&a->method.signature, &b->method.signature);
-}
-
-static bool
-compare_class(const struct jvm_object *a, const struct jvm_object *b)
-{
- assert(a && b);
- return jvm_string_eq(&a->klass.name, &b->klass.name);
-}
-
-static bool
-compare_string(const struct jvm_object *a, const struct jvm_object *b)
-{
- assert(a && b);
- return jvm_string_eq(&a->string, &b->string);
-}
-
-static jobject
-jvm_find_object(struct jvm *jvm, const struct jvm_object *o)
-{
- assert(jvm && o && o->type != JVM_OBJECT_NONE);
-
- bool (*comparator[])(const struct jvm_object *a, const struct jvm_object *b) = {
- NULL,
- compare_array,
- compare_method,
- compare_class,
- compare_string,
- };
-
- for (uintptr_t i = 0; i < ARRAY_SIZE(jvm->objects); ++i) {
- if (o->type != jvm->objects[i].type)
- continue;
-
- assert(o->type < JVM_OBJECT_LAST);
- if (comparator[o->type](o, &jvm->objects[i]))
- return (jobject)(i + 1);
- }
-
- return 0;
-}
-
-static jclass
-jvm_make_class(struct jvm *jvm, const char *name);
-
-static void
-jvm_assing_default_class(struct jvm *jvm, struct jvm_object *o)
-{
- assert(jvm && o);
-
- switch (o->type) {
- case JVM_OBJECT_METHOD:
- o->this_klass = jvm_make_class(jvm, "java.lang.reflect.Method");
- break;
-
- case JVM_OBJECT_STRING:
- o->this_klass = jvm_make_class(jvm, "java.lang.String");
- break;
-
- case JVM_OBJECT_NONE:
- case JVM_OBJECT_ARRAY:
- case JVM_OBJECT_CLASS:
- // arrays have unique classes which is handled on `jvm_new_array`
- // `jvm_make_class` points class's `this_class` to first object, which is class definition for a class
- assert(0 && "epic failure");
- break;
- }
-}
-
-static jobject
-jvm_add_object(struct jvm *jvm, const struct jvm_object *o)
-{
- assert(jvm && o);
-
- uintptr_t i;
- for (i = 0; i < ARRAY_SIZE(jvm->objects) && jvm->objects[i].type != JVM_OBJECT_NONE; ++i);
- assert(i < ARRAY_SIZE(jvm->objects) && "jvm object limit reached!");
- jvm->objects[i] = *o;
-
- if (!jvm->objects[i].this_klass)
- jvm_assing_default_class(jvm, &jvm->objects[i]);
-
- return (jobject)(i + 1);
-}
-
-static jobject
-jvm_add_object_if_not_there(struct jvm *jvm, struct jvm_object *needle)
-{
- assert(jvm && needle);
- jobject o;
- if ((o = jvm_find_object(jvm, needle))) {
- jvm_object_release(needle);
- return o;
- }
-
- return jvm_add_object(jvm, needle);
-}
-
-static struct jvm_object*
-jvm_get_object(struct jvm *jvm, const jobject o)
-{
- assert(jvm && (uintptr_t)o <= ARRAY_SIZE(jvm->objects));
- return (o ? &jvm->objects[(uintptr_t)o - 1] : NULL);
-}
-
-static struct jvm*
-jnienv_get_jvm(JNIEnv *env)
-{
- return container_of(env, struct jvm, env);
-}
-
-static struct jvm*
-javavm_get_jvm(JavaVM *vm)
-{
- return container_of(vm, struct jvm, vm);
-}
-
-static jint
-JNIEnv_GetVersion(JNIEnv * p0)
-{
- return 0;
-}
-
-static jclass
-JNIEnv_DefineClass(JNIEnv* p0, const char* p1, jobject p2, const jbyte* p3, jsize p4)
-{
- return NULL;
-}
-
-static jclass
-jvm_make_class(struct jvm *jvm, const char *name)
-{
- assert(jvm && name);
- struct jvm_object o = { .this_klass = (jclass)1, .type = JVM_OBJECT_CLASS };
- jvm_string_set_cstr(&o.klass.name, name, true);
- return jvm_add_object_if_not_there(jvm, &o);
-}
-
-static jclass
-JNIEnv_FindClass(JNIEnv* p0, const char* p1)
-{
- assert(p0 && p1);
- printf("%s\n", p1);
- return jvm_make_class(jnienv_get_jvm(p0), p1);
-}
-
-static jmethodID
-JNIEnv_FromReflectedMethod(JNIEnv* p0, jobject p1)
-{
- return NULL;
-}
-
-static jfieldID
-JNIEnv_FromReflectedField(JNIEnv* p0, jobject p1)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_ToReflectedMethod(JNIEnv* p0, jclass p1, jmethodID p2, jboolean p3)
-{
- return NULL;
-}
-
-static jclass
-JNIEnv_GetSuperclass(JNIEnv* p0, jclass p1)
-{
- return NULL;
-}
-
-static jboolean
-JNIEnv_IsAssignableFrom(JNIEnv* p0, jclass p1, jclass p2)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_ToReflectedField(JNIEnv* p0, jclass p1, jfieldID p2, jboolean p3)
-{
- return NULL;
-}
-
-static jint
-JNIEnv_Throw(JNIEnv* p0, jthrowable p1)
-{
- return 0;
-}
-
-static jint
-JNIEnv_ThrowNew(JNIEnv * p0, jclass p1, const char * p2)
-{
- return 0;
-}
-
-static jthrowable
-JNIEnv_ExceptionOccurred(JNIEnv* p0)
-{
- return NULL;
-}
-
-static void
-JNIEnv_ExceptionDescribe(JNIEnv* p0)
-{
-}
-
-static void
-JNIEnv_ExceptionClear(JNIEnv* p0)
-{
-}
-
-static void
-JNIEnv_FatalError(JNIEnv* p0, const char* p1)
-{
-}
-
-static jint
-JNIEnv_PushLocalFrame(JNIEnv* p0, jint p1)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_PopLocalFrame(JNIEnv* p0, jobject p1)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_NewGlobalRef(JNIEnv* p0, jobject p1)
-{
- // FIXME: add ref counting
- return p1;
-}
-
-static void
-JNIEnv_DeleteGlobalRef(JNIEnv* p0, jobject p1)
-{
-}
-
-static void
-JNIEnv_DeleteLocalRef(JNIEnv* p0, jobject p1)
-{
-}
-
-static jboolean
-JNIEnv_IsSameObject(JNIEnv* p0, jobject p1, jobject p2)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_NewLocalRef(JNIEnv* p0, jobject p1)
-{
- // FIXME: add ref counting
- return NULL;
-}
-
-static jint
-JNIEnv_EnsureLocalCapacity(JNIEnv* p0, jint p1)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_AllocObject(JNIEnv* p0, jclass p1)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_NewObject(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_NewObjectV(JNIEnv *env, jclass p1, jmethodID p2, va_list p3)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_NewObjectA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- return NULL;
-}
-
-static jclass
-JNIEnv_GetObjectClass(JNIEnv* env, jobject p1)
-{
- assert(env && p1);
- return jvm_get_object(jnienv_get_jvm(env), p1)->this_klass;
-}
-
-static jboolean
-JNIEnv_IsInstanceOf(JNIEnv* p0, jobject p1, jclass p2)
-{
- return 0;
-}
-
-static jmethodID
-jvm_make_method(struct jvm *jvm, jclass klass, const char *name, const char *sig)
-{
- struct jvm_object o = { .method.klass = klass, .type = JVM_OBJECT_METHOD };
- jvm_string_set_cstr(&o.method.name, name, true);
- jvm_string_set_cstr(&o.method.signature, sig, true);
- return jvm_add_object_if_not_there(jvm, &o);
-}
-
-static jmethodID
-JNIEnv_GetMethodID(JNIEnv* p0, jclass klass, const char* name, const char* sig)
-{
- printf("%s::%s\n", name, sig);
- return jvm_make_method(jnienv_get_jvm(p0), klass, name, sig);
-}
-
-static jobject
-JNIEnv_CallObjectMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_CallObjectMethodV(JNIEnv *p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jobject
-JNIEnv_CallObjectMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jboolean
-JNIEnv_CallBooleanMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallBooleanMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallBooleanMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallByteMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallByteMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallByteMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallCharMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallCharMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallCharMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallShortMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallShortMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallShortMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallIntMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallIntMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallIntMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallLongMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallLongMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallLongMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallFloatMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallFloatMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallFloatMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallDoubleMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallDoubleMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallDoubleMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static void
-JNIEnv_CallVoidMethod(JNIEnv* p0, jobject p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallVoidMethodV(JNIEnv* p0, jobject p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallVoidMethodA(JNIEnv* p0, jobject p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static jobject
-JNIEnv_CallNonvirtualObjectMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jobject
-JNIEnv_CallNonvirtualObjectMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jobject
-JNIEnv_CallNonvirtualObjectMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jboolean
-JNIEnv_CallNonvirtualBooleanMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallNonvirtualBooleanMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallNonvirtualBooleanMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallNonvirtualByteMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallNonvirtualByteMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallNonvirtualByteMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallNonvirtualCharMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallNonvirtualCharMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallNonvirtualCharMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallNonvirtualShortMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallNonvirtualShortMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallNonvirtualShortMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallNonvirtualIntMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallNonvirtualIntMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallNonvirtualIntMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallNonvirtualLongMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallNonvirtualLongMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallNonvirtualLongMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallNonvirtualFloatMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallNonvirtualFloatMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallNonvirtualFloatMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallNonvirtualDoubleMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallNonvirtualDoubleMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallNonvirtualDoubleMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static void
-JNIEnv_CallNonvirtualVoidMethod(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallNonvirtualVoidMethodV(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, va_list p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallNonvirtualVoidMethodA(JNIEnv* p0, jobject p1, jclass p2, jmethodID p3, jvalue* p4)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static jfieldID
-jvm_make_fieldid(struct jvm *jvm, const jclass klass, const char *name, const char *sig)
-{
- return (jfieldID)jvm_make_method(jvm, klass, name, sig);
-}
-
-static jfieldID
-JNIEnv_GetFieldID(JNIEnv* p0, jclass klass, const char* name, const char* sig)
-{
- return jvm_make_fieldid(jnienv_get_jvm(p0), klass, name, sig);
-}
-
-static jobject
-JNIEnv_GetObjectField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return NULL;
-}
-
-static jboolean
-JNIEnv_GetBooleanField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jbyte
-JNIEnv_GetByteField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jchar
-JNIEnv_GetCharField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jshort
-JNIEnv_GetShortField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jint
-JNIEnv_GetIntField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jlong
-JNIEnv_GetLongField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jfloat
-JNIEnv_GetFloatField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static jdouble
-JNIEnv_GetDoubleField(JNIEnv* p0, jobject p1, jfieldID p2)
-{
- return 0;
-}
-
-static void
-JNIEnv_SetObjectField(JNIEnv* p0, jobject p1, jfieldID p2, jobject p3)
-{
-}
-
-static void
-JNIEnv_SetBooleanField(JNIEnv* p0, jobject p1, jfieldID p2, jboolean p3)
-{
-}
-
-static void
-JNIEnv_SetByteField(JNIEnv* p0, jobject p1, jfieldID p2, jbyte p3)
-{
-}
-
-static void
-JNIEnv_SetCharField(JNIEnv* p0, jobject p1, jfieldID p2, jchar p3)
-{
-}
-
-static void
-JNIEnv_SetShortField(JNIEnv* p0, jobject p1, jfieldID p2, jshort p3)
-{
-}
-
-static void
-JNIEnv_SetIntField(JNIEnv* p0, jobject p1, jfieldID p2, jint p3)
-{
-}
-
-static void
-JNIEnv_SetLongField(JNIEnv* p0, jobject p1, jfieldID p2, jlong p3)
-{
-}
-
-static void
-JNIEnv_SetFloatField(JNIEnv* p0, jobject p1, jfieldID p2, jfloat p3)
-{
-}
-
-static void
-JNIEnv_SetDoubleField(JNIEnv* p0, jobject p1, jfieldID p2, jdouble p3)
-{
-}
-
-static jmethodID
-JNIEnv_GetStaticMethodID(JNIEnv* p0, jclass klass, const char* name, const char* sig)
-{
- assert(p0 && klass && name && sig);
- printf("%s::%s\n", name, sig);
- return jvm_make_method(jnienv_get_jvm(p0), klass, name, sig);
-}
-
-static jobject
-JNIEnv_CallStaticObjectMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_CallStaticObjectMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jobject
-JNIEnv_CallStaticObjectMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return NULL;
-}
-
-static jboolean
-JNIEnv_CallStaticBooleanMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallStaticBooleanMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jboolean
-JNIEnv_CallStaticBooleanMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallStaticByteMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallStaticByteMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jbyte
-JNIEnv_CallStaticByteMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallStaticCharMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallStaticCharMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jchar
-JNIEnv_CallStaticCharMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallStaticShortMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallStaticShortMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jshort
-JNIEnv_CallStaticShortMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallStaticIntMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallStaticIntMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jint
-JNIEnv_CallStaticIntMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallStaticLongMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallStaticLongMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jlong
-JNIEnv_CallStaticLongMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallStaticFloatMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallStaticFloatMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jfloat
-JNIEnv_CallStaticFloatMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallStaticDoubleMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallStaticDoubleMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static jdouble
-JNIEnv_CallStaticDoubleMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
- return 0;
-}
-
-static void
-JNIEnv_CallStaticVoidMethod(JNIEnv* p0, jclass p1, jmethodID p2, ...)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallStaticVoidMethodV(JNIEnv* p0, jclass p1, jmethodID p2, va_list p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static void
-JNIEnv_CallStaticVoidMethodA(JNIEnv* p0, jclass p1, jmethodID p2, jvalue* p3)
-{
- assert(p0 && p1 && p2);
- struct jvm *jvm = jnienv_get_jvm(p0);
- struct jvm_method *method = &jvm_get_object(jvm, p2)->method;
- printf("%s::%s\n", jvm_get_object(jvm, method->klass)->klass.name.data, method->name.data);
-}
-
-static jfieldID
-JNIEnv_GetStaticFieldID(JNIEnv* p0, jclass klass, const char* name, const char* sig)
-{
- return jvm_make_fieldid(jnienv_get_jvm(p0), klass, name, sig);
-}
-
-static jobject
-JNIEnv_GetStaticObjectField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return NULL;
-}
-
-static jboolean
-JNIEnv_GetStaticBooleanField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jbyte
-JNIEnv_GetStaticByteField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jchar
-JNIEnv_GetStaticCharField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jshort
-JNIEnv_GetStaticShortField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jint
-JNIEnv_GetStaticIntField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jlong
-JNIEnv_GetStaticLongField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jfloat
-JNIEnv_GetStaticFloatField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static jdouble
-JNIEnv_GetStaticDoubleField(JNIEnv* p0, jclass p1, jfieldID p2)
-{
- return 0;
-}
-
-static void
-JNIEnv_SetStaticObjectField(JNIEnv* p0, jclass p1, jfieldID p2, jobject p3)
-{
-}
-
-static void
-JNIEnv_SetStaticBooleanField(JNIEnv* p0, jclass p1, jfieldID p2, jboolean p3)
-{
-}
-
-static void
-JNIEnv_SetStaticByteField(JNIEnv* p0, jclass p1, jfieldID p2, jbyte p3)
-{
-}
-
-static void
-JNIEnv_SetStaticCharField(JNIEnv* p0, jclass p1, jfieldID p2, jchar p3)
-{
-}
-
-static void
-JNIEnv_SetStaticShortField(JNIEnv* p0, jclass p1, jfieldID p2, jshort p3)
-{
-}
-
-static void
-JNIEnv_SetStaticIntField(JNIEnv* p0, jclass p1, jfieldID p2, jint p3)
-{
-}
-
-static void
-JNIEnv_SetStaticLongField(JNIEnv* p0, jclass p1, jfieldID p2, jlong p3)
-{
-}
-
-static void
-JNIEnv_SetStaticFloatField(JNIEnv* p0, jclass p1, jfieldID p2, jfloat p3)
-{
-}
-
-static void
-JNIEnv_SetStaticDoubleField(JNIEnv* p0, jclass p1, jfieldID p2, jdouble p3)
-{
-}
-
-static jstring
-JNIEnv_NewString(JNIEnv* p0, const jchar* p1, jsize p2)
-{
- assert(p0);
- struct jvm_object o = { .type = JVM_OBJECT_STRING };
- jvm_string_set_cstr_with_length(&o.string, (const char*)p1, p2, true);
- return jvm_add_object_if_not_there(jnienv_get_jvm(p0), &o);
-}
-
-static jsize
-JNIEnv_GetStringLength(JNIEnv* p0, jstring p1)
-{
- return 0;
-}
-
-const jchar*
-JNIEnv_GetStringChars(JNIEnv* p0, jstring p1, jboolean* p2)
-{
- return NULL;
-}
-
-static void
-JNIEnv_ReleaseStringChars(JNIEnv* p0, jstring p1, const jchar* p2)
-{
-}
-
-static jstring
-JNIEnv_NewStringUTF(JNIEnv* p0, const char* p1)
-{
- assert(p0);
- struct jvm_object o = { .type = JVM_OBJECT_STRING };
- jvm_string_set_cstr(&o.string, p1, true);
- return jvm_add_object_if_not_there(jnienv_get_jvm(p0), &o);
-}
-
-static jsize
-JNIEnv_GetStringUTFLength(JNIEnv* p0, jstring p1)
-{
- assert(p0 && p1);
- return jvm_get_object(jnienv_get_jvm(p0), p1)->string.size;
-}
-
-static jsize
-JNIEnv_GetArrayLength(JNIEnv* p0, jarray p1)
-{
- assert(p0 && p1);
- return jvm_get_object(jnienv_get_jvm(p0), p1)->array.size;
-}
-
-static jobjectArray
-JNIEnv_NewObjectArray(JNIEnv* p0, jsize p1, jclass p2, jobject p3)
-{
- return NULL;
-}
-
-static jobject
-JNIEnv_GetObjectArrayElement(JNIEnv* p0, jobjectArray p1, jsize p2)
-{
- return NULL;
-}
-
-static void
-JNIEnv_SetObjectArrayElement(JNIEnv* p0, jobjectArray p1, jsize p2, jobject p3)
-{
-}
-
-static jobject
-jvm_new_array(struct jvm *jvm, const size_t size, const size_t element_sz, const char *klass)
-{
- struct jvm_object o = { .array = { .size = size, .element_sz = element_sz }, .type = JVM_OBJECT_ARRAY };
- o.this_klass = jvm_make_class(jvm, klass);
- o.array.data = calloc(size, element_sz);
- assert(o.array.data);
- return jvm_add_object_if_not_there(jvm, &o);
-}
-
-static jbooleanArray
-JNIEnv_NewBooleanArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jboolean), "[Z");
-}
-
-
-static jbyteArray
-JNIEnv_NewByteArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jbyte), "[B");
-}
-
-static jcharArray
-JNIEnv_NewCharArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jchar), "[C");
-}
-
-static jshortArray
-JNIEnv_NewShortArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jshort), "[S");
-}
-
-static jintArray
-JNIEnv_NewIntArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jint), "[I");
-}
-
-static jlongArray
-JNIEnv_NewLongArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jlong), "[J");
-}
-
-static jfloatArray
-JNIEnv_NewFloatArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jfloat), "[F");
-}
-
-static jdoubleArray
-JNIEnv_NewDoubleArray(JNIEnv* p0, jsize p1)
-{
- return jvm_new_array(jnienv_get_jvm(p0), p1, sizeof(jdouble), "[D");
-}
-
-static void*
-jvm_get_array_elements(struct jvm *jvm, jobject array, jboolean *is_copy)
-{
- assert(jvm && array);
-
- if (is_copy)
- *is_copy = JNI_FALSE;
-
- return jvm_get_object(jvm, array)->array.data;
-}
-
-static jboolean*
-JNIEnv_GetBooleanArrayElements(JNIEnv* p0, jbooleanArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jbyte*
-JNIEnv_GetByteArrayElements(JNIEnv* p0, jbyteArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jchar*
-JNIEnv_GetCharArrayElements(JNIEnv* p0, jcharArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jshort*
-JNIEnv_GetShortArrayElements(JNIEnv* p0, jshortArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jint*
-JNIEnv_GetIntArrayElements(JNIEnv* p0, jintArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jlong*
-JNIEnv_GetLongArrayElements(JNIEnv* p0, jlongArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jfloat*
-JNIEnv_GetFloatArrayElements(JNIEnv* p0, jfloatArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static jdouble*
-JNIEnv_GetDoubleArrayElements(JNIEnv* p0, jdoubleArray p1, jboolean* p2)
-{
- return jvm_get_array_elements(jnienv_get_jvm(p0), p1, p2);
-}
-
-static void
-JNIEnv_ReleaseBooleanArrayElements(JNIEnv* p0, jbooleanArray p1, jboolean* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseByteArrayElements(JNIEnv* p0, jbyteArray p1, jbyte* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseCharArrayElements(JNIEnv* p0, jcharArray p1, jchar* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseShortArrayElements(JNIEnv* p0, jshortArray p1, jshort* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseIntArrayElements(JNIEnv* p0, jintArray p1, jint* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseLongArrayElements(JNIEnv* p0, jlongArray p1, jlong* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseFloatArrayElements(JNIEnv* p0, jfloatArray p1, jfloat* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_ReleaseDoubleArrayElements(JNIEnv* p0, jdoubleArray p1, jdouble* p2, jint p3)
-{
-}
-
-static void
-JNIEnv_GetBooleanArrayRegion(JNIEnv* p0, jbooleanArray p1, jsize p2, jsize p3, jboolean* p4)
-{
-}
-
-static void
-jvm_get_array_region(struct jvm *jvm, jobject obj, const size_t offset, const size_t size, void *buf)
-{
- assert(jvm && obj);
- const struct jvm_array *array = &jvm_get_object(jvm, obj)->array;
- assert(offset + size <= array->size);
- memcpy(buf, (char*)array->data + offset * array->element_sz, size * array->element_sz);
-}
-
-static void
-JNIEnv_GetByteArrayRegion(JNIEnv *p0, jbyteArray p1, jsize p2, jsize p3, jbyte* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetCharArrayRegion(JNIEnv* p0, jcharArray p1, jsize p2, jsize p3, jchar* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetShortArrayRegion(JNIEnv* p0, jshortArray p1, jsize p2, jsize p3, jshort* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetIntArrayRegion(JNIEnv* p0, jintArray p1, jsize p2, jsize p3, jint* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetLongArrayRegion(JNIEnv* p0, jlongArray p1, jsize p2, jsize p3, jlong* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetFloatArrayRegion(JNIEnv* p0, jfloatArray p1, jsize p2, jsize p3, jfloat* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_GetDoubleArrayRegion(JNIEnv* p0, jdoubleArray p1, jsize p2, jsize p3, jdouble* p4)
-{
- jvm_get_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-jvm_set_array_region(struct jvm *jvm, jobject obj, const size_t offset, const size_t size, const void *buf)
-{
- assert(jvm && obj);
- struct jvm_array *array = &jvm_get_object(jvm, obj)->array;
- assert(offset + size <= array->size);
- memcpy((char*)array->data + offset * array->element_sz, buf, size * array->element_sz);
-}
-
-static void
-JNIEnv_SetBooleanArrayRegion(JNIEnv* p0, jbooleanArray p1, jsize p2, jsize p3, const jboolean* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetByteArrayRegion(JNIEnv* p0, jbyteArray p1, jsize p2, jsize p3, const jbyte* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetCharArrayRegion(JNIEnv* p0, jcharArray p1, jsize p2, jsize p3, const jchar* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetShortArrayRegion(JNIEnv* p0, jshortArray p1, jsize p2, jsize p3, const jshort* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetIntArrayRegion(JNIEnv* p0, jintArray p1, jsize p2, jsize p3, const jint* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetLongArrayRegion(JNIEnv* p0, jlongArray p1, jsize p2, jsize p3, const jlong* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-JNIEnv_SetFloatArrayRegion(JNIEnv* p0, jfloatArray p1, jsize p2, jsize p3, const jfloat* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-
-static void
-JNIEnv_SetDoubleArrayRegion(JNIEnv* p0, jdoubleArray p1, jsize p2, jsize p3, const jdouble* p4)
-{
- jvm_set_array_region(jnienv_get_jvm(p0), p1, p2, p3, p4);
-}
-
-static void
-jvm_register_native_method(struct jvm *jvm, const jclass klass, const JNINativeMethod *method)
-{
- assert(jvm && klass && method);
- size_t i;
- for (i = 0; i < ARRAY_SIZE(jvm->methods) && jvm->methods[i].function; ++i);
- assert(i < ARRAY_SIZE(jvm->methods) && "native method limit reached!");
- jvm->methods[i].method.klass = klass;
- jvm_string_set_cstr(&jvm->methods[i].method.name, method->name, true);
- jvm_string_set_cstr(&jvm->methods[i].method.signature, method->signature, true);
- jvm->methods[i].function = method->fnPtr;
- printf("%s::%s\n", jvm_get_object(jvm, klass)->klass.name.data, method->name);
-}
-
-static jint
-JNIEnv_RegisterNatives(JNIEnv* p0, jclass p1, const JNINativeMethod* p2, jint p3)
-{
- assert(p0 && p1);
- const JNINativeMethod *method = p2;
- for (jint i = 0; i < p3; ++i, ++method)
- jvm_register_native_method(jnienv_get_jvm(p0), p1, method);
- return 0;
-}
-
-static jint
-JNIEnv_UnregisterNatives(JNIEnv* p0, jclass p1)
-{
- assert(p0 && p1);
- struct jvm *jvm = jnienv_get_jvm(p0);
- for (size_t i = 0; i < ARRAY_SIZE(jvm->methods) && jvm->methods[i].function; ++i) {
- if (jvm->methods[i].method.klass != p1)
- continue;
- jvm->methods[i] = (struct jvm_native_method){0};
- }
- return 0;
-}
-
-static jint
-JNIEnv_MonitorEnter(JNIEnv* p0, jobject p1)
-{
- return 0;
-}
-
-static jint
-JNIEnv_MonitorExit(JNIEnv* p0, jobject p1)
-{
- return 0;
-}
-
-static jint
-JNIEnv_GetJavaVM(JNIEnv* env, JavaVM** vm)
-{
- struct jvm *jvm = jnienv_get_jvm(env);
- *vm = (JavaVM*)&jvm->vm;
- return 0;
-}
-
-static void
-JNIEnv_GetStringRegion(JNIEnv* p0, jstring p1, jsize p2, jsize p3, jchar* p4)
-{
-}
-
-static void
-JNIEnv_GetStringUTFRegion(JNIEnv* p0, jstring p1, jsize p2, jsize p3, char* p4)
-{
-}
-
-static void*
-JNIEnv_GetPrimitiveArrayCritical(JNIEnv *env, jarray array, jboolean *isCopy)
-{
- return jvm_get_array_elements(jnienv_get_jvm(env), array, isCopy);
-}
-
-static void
-JNIEnv_ReleasePrimitiveArrayCritical(JNIEnv *env, jarray array, void *carray, jint mode)
-{
-}
-
-const jchar*
-JNIEnv_GetStringCritical(JNIEnv* p0, jstring p1, jboolean* p2)
-{
- return NULL;
-}
-
-static void
-JNIEnv_ReleaseStringCritical(JNIEnv* p0, jstring p1, const jchar* p2)
-{
-}
-
-static jweak
-JNIEnv_NewWeakGlobalRef(JNIEnv* p0, jobject p1)
-{
- return NULL;
-}
-
-static void
-JNIEnv_DeleteWeakGlobalRef(JNIEnv* p0, jweak p1)
-{
-}
-
-static jboolean
-JNIEnv_ExceptionCheck(JNIEnv* p0)
-{
- return 0;
-}
-
-static jobject
-JNIEnv_NewDirectByteBuffer(JNIEnv* p0, void* p1, jlong p2)
-{
- return NULL;
-}
-
-static void*
-JNIEnv_GetDirectBufferAddress(JNIEnv* p0, jobject p1)
-{
- return NULL;
-}
-
-static jlong
-JNIEnv_GetDirectBufferCapacity(JNIEnv* p0, jobject p1)
-{
- return 0;
-}
-
-const char*
-JNIEnv_GetStringUTFChars(JNIEnv *env, jstring string, jboolean *isCopy)
-{
- assert(env && string);
-
- if (isCopy)
- *isCopy = JNI_FALSE;
-
- return jvm_get_object(jnienv_get_jvm(env), string)->string.data;
-}
-
-static void
-JNIEnv_ReleaseStringUTFChars(JNIEnv *env, jstring string, const char *utf)
-{
- assert(env && string && utf);
-}
-
-static void
-trace(const char *const symbol)
-{
- printf("trace: %s\n", symbol);
-}
-
-extern void* create_wrapper(const char *const symbol, void *function);
-#define WRAP(x) create_wrapper(#x, x)
-
-static void
-env_init(JNIEnv *env, struct JNINativeInterface *native)
-{
- assert(env && native);
- native->GetStringUTFChars = WRAP(JNIEnv_GetStringUTFChars);
- native->ReleaseStringUTFChars = WRAP(JNIEnv_ReleaseStringUTFChars);
- native->GetVersion = WRAP(JNIEnv_GetVersion);
- native->DefineClass = WRAP(JNIEnv_DefineClass);
- native->FindClass = WRAP(JNIEnv_FindClass);
- native->FromReflectedMethod = WRAP(JNIEnv_FromReflectedMethod);
- native->FromReflectedField = WRAP(JNIEnv_FromReflectedField);
- native->ToReflectedMethod = WRAP(JNIEnv_ToReflectedMethod);
- native->GetSuperclass = WRAP(JNIEnv_GetSuperclass);
- native->IsAssignableFrom = WRAP(JNIEnv_IsAssignableFrom);
- native->ToReflectedField = WRAP(JNIEnv_ToReflectedField);
- native->Throw = WRAP(JNIEnv_Throw);
- native->ThrowNew = WRAP(JNIEnv_ThrowNew);
- native->ExceptionOccurred = WRAP(JNIEnv_ExceptionOccurred);
- native->ExceptionDescribe = WRAP(JNIEnv_ExceptionDescribe);
- native->ExceptionClear = WRAP(JNIEnv_ExceptionClear);
- native->FatalError = WRAP(JNIEnv_FatalError);
- native->PushLocalFrame = WRAP(JNIEnv_PushLocalFrame);
- native->PopLocalFrame = WRAP(JNIEnv_PopLocalFrame);
- native->NewGlobalRef = WRAP(JNIEnv_NewGlobalRef);
- native->DeleteGlobalRef = WRAP(JNIEnv_DeleteGlobalRef);
- native->DeleteLocalRef = WRAP(JNIEnv_DeleteLocalRef);
- native->IsSameObject = WRAP(JNIEnv_IsSameObject);
- native->NewLocalRef = WRAP(JNIEnv_NewLocalRef);
- native->EnsureLocalCapacity = WRAP(JNIEnv_EnsureLocalCapacity);
- native->AllocObject = WRAP(JNIEnv_AllocObject);
- native->NewObject = WRAP(JNIEnv_NewObject);
- native->NewObjectV = WRAP(JNIEnv_NewObjectV);
- native->NewObjectA = WRAP(JNIEnv_NewObjectA);
- native->GetObjectClass = WRAP(JNIEnv_GetObjectClass);
- native->IsInstanceOf = WRAP(JNIEnv_IsInstanceOf);
- native->GetMethodID = WRAP(JNIEnv_GetMethodID);
- native->CallObjectMethod = WRAP(JNIEnv_CallObjectMethod);
- native->CallObjectMethodV = WRAP(JNIEnv_CallObjectMethodV);
- native->CallObjectMethodA = WRAP(JNIEnv_CallObjectMethodA);
- native->CallBooleanMethod = WRAP(JNIEnv_CallBooleanMethod);
- native->CallBooleanMethodV = WRAP(JNIEnv_CallBooleanMethodV);
- native->CallBooleanMethodA = WRAP(JNIEnv_CallBooleanMethodA);
- native->CallByteMethod = WRAP(JNIEnv_CallByteMethod);
- native->CallByteMethodV = WRAP(JNIEnv_CallByteMethodV);
- native->CallByteMethodA = WRAP(JNIEnv_CallByteMethodA);
- native->CallCharMethod = WRAP(JNIEnv_CallCharMethod);
- native->CallCharMethodV = WRAP(JNIEnv_CallCharMethodV);
- native->CallCharMethodA = WRAP(JNIEnv_CallCharMethodA);
- native->CallShortMethod = WRAP(JNIEnv_CallShortMethod);
- native->CallShortMethodV = WRAP(JNIEnv_CallShortMethodV);
- native->CallShortMethodA = WRAP(JNIEnv_CallShortMethodA);
- native->CallIntMethod = WRAP(JNIEnv_CallIntMethod);
- native->CallIntMethodV = WRAP(JNIEnv_CallIntMethodV);
- native->CallIntMethodA = WRAP(JNIEnv_CallIntMethodA);
- native->CallLongMethod = WRAP(JNIEnv_CallLongMethod);
- native->CallLongMethodV = WRAP(JNIEnv_CallLongMethodV);
- native->CallLongMethodA = WRAP(JNIEnv_CallLongMethodA);
- native->CallFloatMethod = WRAP(JNIEnv_CallFloatMethod);
- native->CallFloatMethodV = WRAP(JNIEnv_CallFloatMethodV);
- native->CallFloatMethodA = WRAP(JNIEnv_CallFloatMethodA);
- native->CallDoubleMethod = WRAP(JNIEnv_CallDoubleMethod);
- native->CallDoubleMethodV = WRAP(JNIEnv_CallDoubleMethodV);
- native->CallDoubleMethodA = WRAP(JNIEnv_CallDoubleMethodA);
- native->CallVoidMethod = WRAP(JNIEnv_CallVoidMethod);
- native->CallVoidMethodV = WRAP(JNIEnv_CallVoidMethodV);
- native->CallVoidMethodA = WRAP(JNIEnv_CallVoidMethodA);
- native->CallNonvirtualObjectMethod = WRAP(JNIEnv_CallNonvirtualObjectMethod);
- native->CallNonvirtualObjectMethodV = WRAP(JNIEnv_CallNonvirtualObjectMethodV);
- native->CallNonvirtualObjectMethodA = WRAP(JNIEnv_CallNonvirtualObjectMethodA);
- native->CallNonvirtualBooleanMethod = WRAP(JNIEnv_CallNonvirtualBooleanMethod);
- native->CallNonvirtualBooleanMethodV = WRAP(JNIEnv_CallNonvirtualBooleanMethodV);
- native->CallNonvirtualBooleanMethodA = WRAP(JNIEnv_CallNonvirtualBooleanMethodA);
- native->CallNonvirtualByteMethod = WRAP(JNIEnv_CallNonvirtualByteMethod);
- native->CallNonvirtualByteMethodV = WRAP(JNIEnv_CallNonvirtualByteMethodV);
- native->CallNonvirtualByteMethodA = WRAP(JNIEnv_CallNonvirtualByteMethodA);
- native->CallNonvirtualCharMethod = WRAP(JNIEnv_CallNonvirtualCharMethod);
- native->CallNonvirtualCharMethodV = WRAP(JNIEnv_CallNonvirtualCharMethodV);
- native->CallNonvirtualCharMethodA = WRAP(JNIEnv_CallNonvirtualCharMethodA);
- native->CallNonvirtualShortMethod = WRAP(JNIEnv_CallNonvirtualShortMethod);
- native->CallNonvirtualShortMethodV = WRAP(JNIEnv_CallNonvirtualShortMethodV);
- native->CallNonvirtualShortMethodA = WRAP(JNIEnv_CallNonvirtualShortMethodA);
- native->CallNonvirtualIntMethod = WRAP(JNIEnv_CallNonvirtualIntMethod);
- native->CallNonvirtualIntMethodV = WRAP(JNIEnv_CallNonvirtualIntMethodV);
- native->CallNonvirtualIntMethodA = WRAP(JNIEnv_CallNonvirtualIntMethodA);
- native->CallNonvirtualLongMethod = WRAP(JNIEnv_CallNonvirtualLongMethod);
- native->CallNonvirtualLongMethodV = WRAP(JNIEnv_CallNonvirtualLongMethodV);
- native->CallNonvirtualLongMethodA = WRAP(JNIEnv_CallNonvirtualLongMethodA);
- native->CallNonvirtualFloatMethod = WRAP(JNIEnv_CallNonvirtualFloatMethod);
- native->CallNonvirtualFloatMethodV = WRAP(JNIEnv_CallNonvirtualFloatMethodV);
- native->CallNonvirtualFloatMethodA = WRAP(JNIEnv_CallNonvirtualFloatMethodA);
- native->CallNonvirtualDoubleMethod = WRAP(JNIEnv_CallNonvirtualDoubleMethod);
- native->CallNonvirtualDoubleMethodV = WRAP(JNIEnv_CallNonvirtualDoubleMethodV);
- native->CallNonvirtualDoubleMethodA = WRAP(JNIEnv_CallNonvirtualDoubleMethodA);
- native->CallNonvirtualVoidMethod = WRAP(JNIEnv_CallNonvirtualVoidMethod);
- native->CallNonvirtualVoidMethodV = WRAP(JNIEnv_CallNonvirtualVoidMethodV);
- native->CallNonvirtualVoidMethodA = WRAP(JNIEnv_CallNonvirtualVoidMethodA);
- native->GetFieldID = WRAP(JNIEnv_GetFieldID);
- native->GetObjectField = WRAP(JNIEnv_GetObjectField);
- native->GetBooleanField = WRAP(JNIEnv_GetBooleanField);
- native->GetByteField = WRAP(JNIEnv_GetByteField);
- native->GetCharField = WRAP(JNIEnv_GetCharField);
- native->GetShortField = WRAP(JNIEnv_GetShortField);
- native->GetIntField = WRAP(JNIEnv_GetIntField);
- native->GetLongField = WRAP(JNIEnv_GetLongField);
- native->GetFloatField = WRAP(JNIEnv_GetFloatField);
- native->GetDoubleField = WRAP(JNIEnv_GetDoubleField);
- native->SetObjectField = WRAP(JNIEnv_SetObjectField);
- native->SetBooleanField = WRAP(JNIEnv_SetBooleanField);
- native->SetByteField = WRAP(JNIEnv_SetByteField);
- native->SetCharField = WRAP(JNIEnv_SetCharField);
- native->SetShortField = WRAP(JNIEnv_SetShortField);
- native->SetIntField = WRAP(JNIEnv_SetIntField);
- native->SetLongField = WRAP(JNIEnv_SetLongField);
- native->SetFloatField = WRAP(JNIEnv_SetFloatField);
- native->SetDoubleField = WRAP(JNIEnv_SetDoubleField);
- native->GetStaticMethodID = WRAP(JNIEnv_GetStaticMethodID);
- native->CallStaticObjectMethod = WRAP(JNIEnv_CallStaticObjectMethod);
- native->CallStaticObjectMethodV = WRAP(JNIEnv_CallStaticObjectMethodV);
- native->CallStaticObjectMethodA = WRAP(JNIEnv_CallStaticObjectMethodA);
- native->CallStaticBooleanMethod = WRAP(JNIEnv_CallStaticBooleanMethod);
- native->CallStaticBooleanMethodV = WRAP(JNIEnv_CallStaticBooleanMethodV);
- native->CallStaticBooleanMethodA = WRAP(JNIEnv_CallStaticBooleanMethodA);
- native->CallStaticByteMethod = WRAP(JNIEnv_CallStaticByteMethod);
- native->CallStaticByteMethodV = WRAP(JNIEnv_CallStaticByteMethodV);
- native->CallStaticByteMethodA = WRAP(JNIEnv_CallStaticByteMethodA);
- native->CallStaticCharMethod = WRAP(JNIEnv_CallStaticCharMethod);
- native->CallStaticCharMethodV = WRAP(JNIEnv_CallStaticCharMethodV);
- native->CallStaticCharMethodA = WRAP(JNIEnv_CallStaticCharMethodA);
- native->CallStaticShortMethod = WRAP(JNIEnv_CallStaticShortMethod);
- native->CallStaticShortMethodV = WRAP(JNIEnv_CallStaticShortMethodV);
- native->CallStaticShortMethodA = WRAP(JNIEnv_CallStaticShortMethodA);
- native->CallStaticIntMethod = WRAP(JNIEnv_CallStaticIntMethod);
- native->CallStaticIntMethodV = WRAP(JNIEnv_CallStaticIntMethodV);
- native->CallStaticIntMethodA = WRAP(JNIEnv_CallStaticIntMethodA);
- native->CallStaticLongMethod = WRAP(JNIEnv_CallStaticLongMethod);
- native->CallStaticLongMethodV = WRAP(JNIEnv_CallStaticLongMethodV);
- native->CallStaticLongMethodA = WRAP(JNIEnv_CallStaticLongMethodA);
- native->CallStaticFloatMethod = WRAP(JNIEnv_CallStaticFloatMethod);
- native->CallStaticFloatMethodV = WRAP(JNIEnv_CallStaticFloatMethodV);
- native->CallStaticFloatMethodA = WRAP(JNIEnv_CallStaticFloatMethodA);
- native->CallStaticDoubleMethod = WRAP(JNIEnv_CallStaticDoubleMethod);
- native->CallStaticDoubleMethodV = WRAP(JNIEnv_CallStaticDoubleMethodV);
- native->CallStaticDoubleMethodA = WRAP(JNIEnv_CallStaticDoubleMethodA);
- native->CallStaticVoidMethod = WRAP(JNIEnv_CallStaticVoidMethod);
- native->CallStaticVoidMethodV = WRAP(JNIEnv_CallStaticVoidMethodV);
- native->CallStaticVoidMethodA = WRAP(JNIEnv_CallStaticVoidMethodA);
- native->GetStaticFieldID = WRAP(JNIEnv_GetStaticFieldID);
- native->GetStaticObjectField = WRAP(JNIEnv_GetStaticObjectField);
- native->GetStaticBooleanField = WRAP(JNIEnv_GetStaticBooleanField);
- native->GetStaticByteField = WRAP(JNIEnv_GetStaticByteField);
- native->GetStaticCharField = WRAP(JNIEnv_GetStaticCharField);
- native->GetStaticShortField = WRAP(JNIEnv_GetStaticShortField);
- native->GetStaticIntField = WRAP(JNIEnv_GetStaticIntField);
- native->GetStaticLongField = WRAP(JNIEnv_GetStaticLongField);
- native->GetStaticFloatField = WRAP(JNIEnv_GetStaticFloatField);
- native->GetStaticDoubleField = WRAP(JNIEnv_GetStaticDoubleField);
- native->SetStaticObjectField = WRAP(JNIEnv_SetStaticObjectField);
- native->SetStaticBooleanField = WRAP(JNIEnv_SetStaticBooleanField);
- native->SetStaticByteField = WRAP(JNIEnv_SetStaticByteField);
- native->SetStaticCharField = WRAP(JNIEnv_SetStaticCharField);
- native->SetStaticShortField = WRAP(JNIEnv_SetStaticShortField);
- native->SetStaticIntField = WRAP(JNIEnv_SetStaticIntField);
- native->SetStaticLongField = WRAP(JNIEnv_SetStaticLongField);
- native->SetStaticFloatField = WRAP(JNIEnv_SetStaticFloatField);
- native->SetStaticDoubleField = WRAP(JNIEnv_SetStaticDoubleField);
- native->NewString = WRAP(JNIEnv_NewString);
- native->GetStringLength = WRAP(JNIEnv_GetStringLength);
- native->GetStringChars = WRAP(JNIEnv_GetStringChars);
- native->ReleaseStringChars = WRAP(JNIEnv_ReleaseStringChars);
- native->NewStringUTF = WRAP(JNIEnv_NewStringUTF);
- native->GetStringUTFLength = WRAP(JNIEnv_GetStringUTFLength);
- native->GetArrayLength = WRAP(JNIEnv_GetArrayLength);
- native->NewObjectArray = WRAP(JNIEnv_NewObjectArray);
- native->GetObjectArrayElement = WRAP(JNIEnv_GetObjectArrayElement);
- native->SetObjectArrayElement = WRAP(JNIEnv_SetObjectArrayElement);
- native->NewBooleanArray = WRAP(JNIEnv_NewBooleanArray);
- native->NewByteArray = WRAP(JNIEnv_NewByteArray);
- native->NewCharArray = WRAP(JNIEnv_NewCharArray);
- native->NewShortArray = WRAP(JNIEnv_NewShortArray);
- native->NewIntArray = WRAP(JNIEnv_NewIntArray);
- native->NewLongArray = WRAP(JNIEnv_NewLongArray);
- native->NewFloatArray = WRAP(JNIEnv_NewFloatArray);
- native->NewDoubleArray = WRAP(JNIEnv_NewDoubleArray);
- native->GetBooleanArrayElements = WRAP(JNIEnv_GetBooleanArrayElements);
- native->GetByteArrayElements = WRAP(JNIEnv_GetByteArrayElements);
- native->GetCharArrayElements = WRAP(JNIEnv_GetCharArrayElements);
- native->GetShortArrayElements = WRAP(JNIEnv_GetShortArrayElements);
- native->GetIntArrayElements = WRAP(JNIEnv_GetIntArrayElements);
- native->GetLongArrayElements = WRAP(JNIEnv_GetLongArrayElements);
- native->GetFloatArrayElements = WRAP(JNIEnv_GetFloatArrayElements);
- native->GetDoubleArrayElements = WRAP(JNIEnv_GetDoubleArrayElements);
- native->ReleaseBooleanArrayElements = WRAP(JNIEnv_ReleaseBooleanArrayElements);
- native->ReleaseByteArrayElements = WRAP(JNIEnv_ReleaseByteArrayElements);
- native->ReleaseCharArrayElements = WRAP(JNIEnv_ReleaseCharArrayElements);
- native->ReleaseShortArrayElements = WRAP(JNIEnv_ReleaseShortArrayElements);
- native->ReleaseIntArrayElements = WRAP(JNIEnv_ReleaseIntArrayElements);
- native->ReleaseLongArrayElements = WRAP(JNIEnv_ReleaseLongArrayElements);
- native->ReleaseFloatArrayElements = WRAP(JNIEnv_ReleaseFloatArrayElements);
- native->ReleaseDoubleArrayElements = WRAP(JNIEnv_ReleaseDoubleArrayElements);
- native->GetBooleanArrayRegion = WRAP(JNIEnv_GetBooleanArrayRegion);
- native->GetByteArrayRegion = WRAP(JNIEnv_GetByteArrayRegion);
- native->GetCharArrayRegion = WRAP(JNIEnv_GetCharArrayRegion);
- native->GetShortArrayRegion = WRAP(JNIEnv_GetShortArrayRegion);
- native->GetIntArrayRegion = WRAP(JNIEnv_GetIntArrayRegion);
- native->GetLongArrayRegion = WRAP(JNIEnv_GetLongArrayRegion);
- native->GetFloatArrayRegion = WRAP(JNIEnv_GetFloatArrayRegion);
- native->GetDoubleArrayRegion = WRAP(JNIEnv_GetDoubleArrayRegion);
- native->SetBooleanArrayRegion = WRAP(JNIEnv_SetBooleanArrayRegion);
- native->SetByteArrayRegion = WRAP(JNIEnv_SetByteArrayRegion);
- native->SetCharArrayRegion = WRAP(JNIEnv_SetCharArrayRegion);
- native->SetShortArrayRegion = WRAP(JNIEnv_SetShortArrayRegion);
- native->SetIntArrayRegion = WRAP(JNIEnv_SetIntArrayRegion);
- native->SetLongArrayRegion = WRAP(JNIEnv_SetLongArrayRegion);
- native->SetFloatArrayRegion = WRAP(JNIEnv_SetFloatArrayRegion);
- native->SetDoubleArrayRegion = WRAP(JNIEnv_SetDoubleArrayRegion);
- native->RegisterNatives = WRAP(JNIEnv_RegisterNatives);
- native->UnregisterNatives = WRAP(JNIEnv_UnregisterNatives);
- native->MonitorEnter = WRAP(JNIEnv_MonitorEnter);
- native->MonitorExit = WRAP(JNIEnv_MonitorExit);
- native->GetJavaVM = WRAP(JNIEnv_GetJavaVM);
- native->GetStringRegion = WRAP(JNIEnv_GetStringRegion);
- native->GetStringUTFRegion = WRAP(JNIEnv_GetStringUTFRegion);
- native->GetPrimitiveArrayCritical = WRAP(JNIEnv_GetPrimitiveArrayCritical);
- native->ReleasePrimitiveArrayCritical = WRAP(JNIEnv_ReleasePrimitiveArrayCritical);
- native->GetStringCritical = WRAP(JNIEnv_GetStringCritical);
- native->ReleaseStringCritical = WRAP(JNIEnv_ReleaseStringCritical);
- native->NewWeakGlobalRef = WRAP(JNIEnv_NewWeakGlobalRef);
- native->DeleteWeakGlobalRef = WRAP(JNIEnv_DeleteWeakGlobalRef);
- native->ExceptionCheck = WRAP(JNIEnv_ExceptionCheck);
- native->NewDirectByteBuffer = WRAP(JNIEnv_NewDirectByteBuffer);
- native->GetDirectBufferAddress = WRAP(JNIEnv_GetDirectBufferAddress);
- native->GetDirectBufferCapacity = WRAP(JNIEnv_GetDirectBufferCapacity);
- *env = native;
-}
-
-static jint
-JavaVM_DestroyJavaVM(JavaVM *vm)
-{
- assert(vm);
- return JNI_OK;
-}
-
-static jint
-JavaVM_AttachCurrentThread(JavaVM *vm, JNIEnv **env, void *args)
-{
- assert(vm && env);
- *env = &javavm_get_jvm(vm)->env;
- return JNI_OK;
-}
-
-static jint
-JavaVM_DetachCurrentThread(JavaVM *vm)
-{
- assert(vm);
- return JNI_OK;
-}
-
-static jint
-JavaVM_GetEnv(JavaVM *vm, void **env, jint version)
-{
- assert(vm && env);
- *env = &javavm_get_jvm(vm)->env;
- return JNI_OK;
-}
-
-static jint
-JavaVM_AttachCurrentThreadAsDaemon(JavaVM *vm, JNIEnv **env, void *args)
-{
- assert(vm && env);
- *env = &javavm_get_jvm(vm)->env;
- return JNI_OK;
-}
-
-static void
-vm_init(JavaVM *vm, struct JNIInvokeInterface *invoke)
-{
- assert(vm && invoke);
- invoke->DestroyJavaVM = WRAP(JavaVM_DestroyJavaVM);
- invoke->AttachCurrentThread = WRAP(JavaVM_AttachCurrentThread);
- invoke->DetachCurrentThread = WRAP(JavaVM_DetachCurrentThread);
- invoke->GetEnv = WRAP(JavaVM_GetEnv);
- invoke->AttachCurrentThreadAsDaemon = WRAP(JavaVM_AttachCurrentThreadAsDaemon);
- *vm = invoke;
-}
-
-void*
-jvm_get_native_method(struct jvm *jvm, const char *klass, const char *method)
-{
- for (size_t i = 0; i < ARRAY_SIZE(jvm->methods) && jvm->methods[i].function; ++i) {
- if (!strcmp(jvm_get_object(jvm, jvm->methods[i].method.klass)->klass.name.data, klass) &&
- !strcmp(jvm->methods[i].method.name.data, method))
- return create_wrapper(method, jvm->methods[i].function);
- }
- return NULL;
-}
-
-void
-jvm_release(struct jvm *jvm)
-{
- assert(jvm);
-
- for (size_t i = 0; i < ARRAY_SIZE(jvm->objects); ++i)
- jvm_object_release(&jvm->objects[i]);
-
- for (size_t i = 0; i < ARRAY_SIZE(jvm->methods); ++i) {
- jvm_string_release(&jvm->methods[i].method.name);
- jvm_string_release(&jvm->methods[i].method.signature);
- }
-
- *jvm = (struct jvm){0};
-}
-
-void
-jvm_init(struct jvm *jvm)
-{
- assert(jvm);
- *jvm = (struct jvm){0};
- vm_init(&jvm->vm, &jvm->invoke);
- env_init(&jvm->env, &jvm->native);
- jvm_make_class(jvm, "java.lang.Class");
-}