aboutsummaryrefslogtreecommitdiff
path: root/tests/nbody-java/java_lang_Object.c
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2013-05-08 16:06:26 -0700
committerAlon Zakai <alonzakai@gmail.com>2013-05-08 16:06:26 -0700
commit693682fc225e60c9c335ee910fb3c8bb5cf85470 (patch)
treeb2c1285adf65b68a7b20aa231c4c5665966b2c18 /tests/nbody-java/java_lang_Object.c
parentb41b535aeac53740dec416f617378ec4e4e382ce (diff)
add nbody-java code
Diffstat (limited to 'tests/nbody-java/java_lang_Object.c')
-rw-r--r--tests/nbody-java/java_lang_Object.c1079
1 files changed, 1079 insertions, 0 deletions
diff --git a/tests/nbody-java/java_lang_Object.c b/tests/nbody-java/java_lang_Object.c
new file mode 100644
index 00000000..fcc876e7
--- /dev/null
+++ b/tests/nbody-java/java_lang_Object.c
@@ -0,0 +1,1079 @@
+#include "xmlvm.h"
+#include "java_lang_Class.h"
+#include "java_lang_Integer.h"
+#include "java_lang_Math.h"
+#include "java_lang_Object_AddedMembers.h"
+#include "java_lang_String.h"
+#include "java_lang_StringBuilder.h"
+#include "java_lang_Thread.h"
+#include "java_util_List.h"
+#include "org_xmlvm_runtime_Condition.h"
+#include "org_xmlvm_runtime_Mutex.h"
+
+#include "java_lang_Object.h"
+
+#define XMLVM_CURRENT_CLASS_NAME Object
+#define XMLVM_CURRENT_PKG_CLASS_NAME java_lang_Object
+
+__TIB_DEFINITION_java_lang_Object __TIB_java_lang_Object = {
+ 0, // classInitializationBegan
+ 0, // classInitialized
+ -1, // initializerThreadId
+ __INIT_java_lang_Object, // classInitializer
+ "java.lang.Object", // className
+ "java.lang", // package
+ JAVA_NULL, // enclosingClassName
+ JAVA_NULL, // enclosingMethodName
+ JAVA_NULL, // signature
+ (__TIB_DEFINITION_TEMPLATE*) JAVA_NULL, // extends
+ sizeof(java_lang_Object), // sizeInstance
+ XMLVM_TYPE_CLASS};
+
+JAVA_OBJECT __CLASS_java_lang_Object;
+JAVA_OBJECT __CLASS_java_lang_Object_1ARRAY;
+JAVA_OBJECT __CLASS_java_lang_Object_2ARRAY;
+JAVA_OBJECT __CLASS_java_lang_Object_3ARRAY;
+//XMLVM_BEGIN_IMPLEMENTATION
+//XMLVM_END_IMPLEMENTATION
+
+static JAVA_OBJECT _STATIC_java_lang_Object_staticMutex;
+
+#include "xmlvm-reflection.h"
+
+static XMLVM_FIELD_REFLECTION_DATA __field_reflection_data[] = {
+};
+
+static XMLVM_CONSTRUCTOR_REFLECTION_DATA __constructor_reflection_data[] = {
+};
+
+static JAVA_OBJECT constructor_dispatcher(JAVA_OBJECT constructor, JAVA_OBJECT arguments)
+{
+ XMLVM_NOT_IMPLEMENTED();
+}
+
+static XMLVM_METHOD_REFLECTION_DATA __method_reflection_data[] = {
+};
+
+static JAVA_OBJECT method_dispatcher(JAVA_OBJECT method, JAVA_OBJECT receiver, JAVA_OBJECT arguments)
+{
+ XMLVM_NOT_IMPLEMENTED();
+}
+
+void __INIT_java_lang_Object()
+{
+ staticInitializerLock(&__TIB_java_lang_Object);
+
+ // While the static initializer mutex is locked, locally store the value of
+ // whether class initialization began or not
+ int initBegan = __TIB_java_lang_Object.classInitializationBegan;
+
+ // Whether or not class initialization had already began, it has begun now
+ __TIB_java_lang_Object.classInitializationBegan = 1;
+
+ staticInitializerUnlock(&__TIB_java_lang_Object);
+
+ JAVA_LONG curThreadId = (JAVA_LONG)pthread_self();
+ if (initBegan) {
+ if (__TIB_java_lang_Object.initializerThreadId != curThreadId) {
+ // Busy wait until the other thread finishes initializing this class
+ while (!__TIB_java_lang_Object.classInitialized) {
+ // do nothing
+ }
+ }
+ } else {
+ __TIB_java_lang_Object.initializerThreadId = curThreadId;
+ XMLVM_CLASS_USED("java.lang.Object")
+ __INIT_IMPL_java_lang_Object();
+ }
+}
+
+void __INIT_IMPL_java_lang_Object()
+{
+ // Initialize vtable for this class
+ __TIB_java_lang_Object.vtable[0] = (VTABLE_PTR) &xmlvm_unimplemented_native_method;
+ __TIB_java_lang_Object.vtable[1] = (VTABLE_PTR) &xmlvm_unimplemented_native_method;
+ __TIB_java_lang_Object.vtable[2] = (VTABLE_PTR) &xmlvm_unimplemented_native_method;
+ __TIB_java_lang_Object.vtable[3] = (VTABLE_PTR) &xmlvm_unimplemented_native_method;
+ __TIB_java_lang_Object.vtable[4] = (VTABLE_PTR) &xmlvm_unimplemented_native_method;
+ __TIB_java_lang_Object.vtable[5] = (VTABLE_PTR) &java_lang_Object_toString__;
+ xmlvm_init_native_java_lang_Object();
+ // Initialize interface information
+ __TIB_java_lang_Object.numImplementedInterfaces = 0;
+ __TIB_java_lang_Object.implementedInterfaces = (__TIB_DEFINITION_TEMPLATE* (*)[1]) XMLVM_MALLOC(sizeof(__TIB_DEFINITION_TEMPLATE*) * 0);
+
+ // Initialize interfaces if necessary and assign tib to implementedInterfaces
+ _STATIC_java_lang_Object_staticMutex = (org_xmlvm_runtime_Mutex*) JAVA_NULL;
+
+ __TIB_java_lang_Object.declaredFields = &__field_reflection_data[0];
+ __TIB_java_lang_Object.numDeclaredFields = sizeof(__field_reflection_data) / sizeof(XMLVM_FIELD_REFLECTION_DATA);
+ __TIB_java_lang_Object.constructorDispatcherFunc = constructor_dispatcher;
+ __TIB_java_lang_Object.declaredConstructors = &__constructor_reflection_data[0];
+ __TIB_java_lang_Object.numDeclaredConstructors = sizeof(__constructor_reflection_data) / sizeof(XMLVM_CONSTRUCTOR_REFLECTION_DATA);
+ __TIB_java_lang_Object.methodDispatcherFunc = method_dispatcher;
+ __TIB_java_lang_Object.declaredMethods = &__method_reflection_data[0];
+ __TIB_java_lang_Object.numDeclaredMethods = sizeof(__method_reflection_data) / sizeof(XMLVM_METHOD_REFLECTION_DATA);
+ __CLASS_java_lang_Object = XMLVM_CREATE_CLASS_OBJECT(&__TIB_java_lang_Object);
+ __TIB_java_lang_Object.clazz = __CLASS_java_lang_Object;
+ __TIB_java_lang_Object.baseType = JAVA_NULL;
+ __CLASS_java_lang_Object_1ARRAY = XMLVM_CREATE_ARRAY_CLASS_OBJECT(__CLASS_java_lang_Object);
+ __CLASS_java_lang_Object_2ARRAY = XMLVM_CREATE_ARRAY_CLASS_OBJECT(__CLASS_java_lang_Object_1ARRAY);
+ __CLASS_java_lang_Object_3ARRAY = XMLVM_CREATE_ARRAY_CLASS_OBJECT(__CLASS_java_lang_Object_2ARRAY);
+ java_lang_Object___CLINIT_();
+ //XMLVM_BEGIN_WRAPPER[__INIT_java_lang_Object]
+ //XMLVM_END_WRAPPER
+
+ __TIB_java_lang_Object.classInitialized = 1;
+}
+
+void __DELETE_java_lang_Object(void* me, void* client_data)
+{
+ //XMLVM_BEGIN_WRAPPER[__DELETE_java_lang_Object]
+ //XMLVM_END_WRAPPER
+ // Call the finalizer
+ (*(void (*)(JAVA_OBJECT)) ((java_lang_Object*) me)->tib->vtable[XMLVM_VTABLE_IDX_java_lang_Object_finalize_java_lang_Object__])(me);
+}
+
+void __INIT_INSTANCE_MEMBERS_java_lang_Object(JAVA_OBJECT me, int derivedClassWillRegisterFinalizer)
+{
+ ((java_lang_Object*) me)->fields.java_lang_Object.addedMembers_ = (java_lang_Object_AddedMembers*) JAVA_NULL;
+ //XMLVM_BEGIN_WRAPPER[__INIT_INSTANCE_MEMBERS_java_lang_Object]
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_OBJECT __NEW_java_lang_Object()
+{ XMLVM_CLASS_INIT(java_lang_Object)
+java_lang_Object* me = (java_lang_Object*) XMLVM_MALLOC(sizeof(java_lang_Object));
+ me->tib = &__TIB_java_lang_Object;
+ __INIT_INSTANCE_MEMBERS_java_lang_Object(me, 0);
+ //XMLVM_BEGIN_WRAPPER[__NEW_java_lang_Object]
+ //XMLVM_END_WRAPPER
+ return me;
+}
+
+JAVA_OBJECT __NEW_INSTANCE_java_lang_Object()
+{
+ JAVA_OBJECT me = JAVA_NULL;
+ me = __NEW_java_lang_Object();
+ java_lang_Object___INIT___(me);
+ return me;
+}
+
+JAVA_OBJECT java_lang_Object_GET_staticMutex()
+{
+ XMLVM_CLASS_INIT(java_lang_Object)
+ return _STATIC_java_lang_Object_staticMutex;
+}
+
+void java_lang_Object_PUT_staticMutex(JAVA_OBJECT v)
+{
+ XMLVM_CLASS_INIT(java_lang_Object)
+_STATIC_java_lang_Object_staticMutex = v;
+}
+
+//XMLVM_NATIVE[void java_lang_Object_initNativeLayer__()]
+
+void java_lang_Object___INIT___(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object___INIT___]
+ XMLVM_ENTER_METHOD("java.lang.Object", "<init>", "?")
+ XMLVMElem _r0;
+ _r0.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 58)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+//XMLVM_NATIVE[JAVA_OBJECT java_lang_Object_clone__(JAVA_OBJECT me)]
+
+//XMLVM_NATIVE[JAVA_BOOLEAN java_lang_Object_equals___java_lang_Object(JAVA_OBJECT me, JAVA_OBJECT n1)]
+
+//XMLVM_NATIVE[void java_lang_Object_finalize_java_lang_Object__(JAVA_OBJECT me)]
+
+//XMLVM_NATIVE[JAVA_OBJECT java_lang_Object_getClass__(JAVA_OBJECT me)]
+
+//XMLVM_NATIVE[JAVA_INT java_lang_Object_hashCode__(JAVA_OBJECT me)]
+
+void java_lang_Object_notify__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_notify__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "notify", "?")
+ XMLVMElem _r0;
+ _r0.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 185)
+ XMLVM_CHECK_NPE(0)
+ java_lang_Object_notify2__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 186)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_notifyAll__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_notifyAll__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "notifyAll", "?")
+ XMLVMElem _r0;
+ _r0.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 216)
+ XMLVM_CHECK_NPE(0)
+ java_lang_Object_notifyAll2__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 217)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_OBJECT java_lang_Object_toString__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_toString__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "toString", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r2.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 234)
+ _r0.o = __NEW_java_lang_StringBuilder();
+ XMLVM_CHECK_NPE(0)
+ java_lang_StringBuilder___INIT___(_r0.o);
+ //java_lang_Object_getClass__[3]
+ XMLVM_CHECK_NPE(2)
+ _r1.o = (*(JAVA_OBJECT (*)(JAVA_OBJECT)) ((java_lang_Object*) _r2.o)->tib->vtable[3])(_r2.o);
+ XMLVM_CHECK_NPE(1)
+ _r1.o = java_lang_Class_getName__(_r1.o);
+ XMLVM_CHECK_NPE(0)
+ _r0.o = java_lang_StringBuilder_append___java_lang_String(_r0.o, _r1.o);
+ _r1.i = 64;
+ //java_lang_StringBuilder_append___char[6]
+ XMLVM_CHECK_NPE(0)
+ _r0.o = (*(JAVA_OBJECT (*)(JAVA_OBJECT, JAVA_CHAR)) ((java_lang_StringBuilder*) _r0.o)->tib->vtable[6])(_r0.o, _r1.i);
+ //java_lang_Object_hashCode__[4]
+ XMLVM_CHECK_NPE(2)
+ _r1.i = (*(JAVA_INT (*)(JAVA_OBJECT)) ((java_lang_Object*) _r2.o)->tib->vtable[4])(_r2.o);
+ _r1.o = java_lang_Integer_toHexString___int(_r1.i);
+ XMLVM_CHECK_NPE(0)
+ _r0.o = java_lang_StringBuilder_append___java_lang_String(_r0.o, _r1.o);
+ //java_lang_StringBuilder_toString__[5]
+ XMLVM_CHECK_NPE(0)
+ _r0.o = (*(JAVA_OBJECT (*)(JAVA_OBJECT)) ((java_lang_StringBuilder*) _r0.o)->tib->vtable[5])(_r0.o);
+ XMLVM_EXIT_METHOD()
+ return _r0.o;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_wait__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_wait__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "wait", "?")
+ XMLVMElem _r0;
+ _r0.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 266)
+ XMLVM_CHECK_NPE(0)
+ java_lang_Object_wait2__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 267)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_wait___long(JAVA_OBJECT me, JAVA_LONG n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_wait___long]
+ XMLVM_ENTER_METHOD("java.lang.Object", "wait", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r0.o = me;
+ _r1.l = n1;
+ XMLVM_SOURCE_POSITION("Object.java", 303)
+ XMLVM_CHECK_NPE(0)
+ java_lang_Object_wait2___long(_r0.o, _r1.l);
+ XMLVM_SOURCE_POSITION("Object.java", 304)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+//XMLVM_NATIVE[void java_lang_Object_wait___long_int(JAVA_OBJECT me, JAVA_LONG n1, JAVA_INT n2)]
+
+void java_lang_Object_establishLock___java_lang_Thread(JAVA_OBJECT me, JAVA_OBJECT n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_establishLock___java_lang_Thread]
+ XMLVM_ENTER_METHOD("java.lang.Object", "establishLock", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r1.o = me;
+ _r2.o = n1;
+ XMLVM_SOURCE_POSITION("Object.java", 382)
+ _r0.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_lock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 384)
+ XMLVM_CHECK_NPE(1)
+ _r0.o = ((java_lang_Object*) _r1.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(0)
+ ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.owningThread_ = _r2.o;
+ XMLVM_SOURCE_POSITION("Object.java", 386)
+ _r0.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_unlock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 387)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_prepareForUnlock__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_prepareForUnlock__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "prepareForUnlock", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r2.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 393)
+ _r0.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_lock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 395)
+ XMLVM_CHECK_NPE(2)
+ _r0.o = ((java_lang_Object*) _r2.o)->fields.java_lang_Object.addedMembers_;
+ _r1.o = JAVA_NULL;
+ XMLVM_CHECK_NPE(0)
+ ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.owningThread_ = _r1.o;
+ XMLVM_SOURCE_POSITION("Object.java", 397)
+ _r0.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_unlock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 398)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_syncLock___java_lang_Thread(JAVA_OBJECT me, JAVA_OBJECT n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_syncLock___java_lang_Thread]
+ XMLVM_ENTER_METHOD("java.lang.Object", "syncLock", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r1.o = me;
+ _r2.o = n1;
+ XMLVM_SOURCE_POSITION("Object.java", 401)
+ XMLVM_CHECK_NPE(1)
+ _r0.o = ((java_lang_Object*) _r1.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(0)
+ _r0.o = ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.instanceMutex_;
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_lock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 402)
+ XMLVM_CHECK_NPE(1)
+ java_lang_Object_establishLock___java_lang_Thread(_r1.o, _r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 403)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_syncUnlock__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_syncUnlock__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "syncUnlock", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ _r1.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 406)
+ XMLVM_CHECK_NPE(1)
+ java_lang_Object_prepareForUnlock__(_r1.o);
+ XMLVM_SOURCE_POSITION("Object.java", 407)
+ XMLVM_CHECK_NPE(1)
+ _r0.o = ((java_lang_Object*) _r1.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(0)
+ _r0.o = ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.instanceMutex_;
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Mutex_unlock__(_r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 408)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_BOOLEAN java_lang_Object_acquireLockRecursive__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_acquireLockRecursive__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "acquireLockRecursive", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ _r4.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 417)
+ _r0.i = 0;
+ XMLVM_SOURCE_POSITION("Object.java", 419)
+ _r1.o = java_lang_Thread_currentThread__();
+ XMLVM_SOURCE_POSITION("Object.java", 420)
+ _r2.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(2)
+ org_xmlvm_runtime_Mutex_lock__(_r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 422)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ if (_r2.o != JAVA_NULL) goto label21;
+ XMLVM_SOURCE_POSITION("Object.java", 423)
+ _r2.o = __NEW_java_lang_Object_AddedMembers();
+ XMLVM_CHECK_NPE(2)
+ java_lang_Object_AddedMembers___INIT___(_r2.o);
+ XMLVM_CHECK_NPE(4)
+ ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_ = _r2.o;
+ label21:;
+ XMLVM_SOURCE_POSITION("Object.java", 425)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(2)
+ _r2.o = ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.owningThread_;
+ //java_lang_Thread_equals___java_lang_Object[1]
+ XMLVM_CHECK_NPE(1)
+ _r2.i = (*(JAVA_BOOLEAN (*)(JAVA_OBJECT, JAVA_OBJECT)) ((java_lang_Thread*) _r1.o)->tib->vtable[1])(_r1.o, _r2.o);
+ if (_r2.i != 0) goto label52;
+ _r2.i = 1;
+ _r0 = _r2;
+ label33:;
+ XMLVM_SOURCE_POSITION("Object.java", 427)
+ _r2.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(2)
+ org_xmlvm_runtime_Mutex_unlock__(_r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 429)
+ if (_r0.i == 0) goto label43;
+ XMLVM_SOURCE_POSITION("Object.java", 430)
+ XMLVM_CHECK_NPE(4)
+ java_lang_Object_syncLock___java_lang_Thread(_r4.o, _r1.o);
+ label43:;
+ XMLVM_SOURCE_POSITION("Object.java", 432)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(2)
+ _r3.i = ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_;
+ _r3.i = _r3.i + 1;
+ XMLVM_CHECK_NPE(2)
+ ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_ = _r3.i;
+ XMLVM_SOURCE_POSITION("Object.java", 435)
+ XMLVM_EXIT_METHOD()
+ return _r0.i;
+ label52:;
+ _r2.i = 0;
+ _r0 = _r2;
+ goto label33;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_releaseLockRecursive__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_releaseLockRecursive__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "releaseLockRecursive", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ _r3.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 443)
+ XMLVM_CHECK_NPE(3)
+ _r0.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(0)
+ _r1.i = ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_;
+ _r2.i = 1;
+ _r1.i = _r1.i - _r2.i;
+ XMLVM_CHECK_NPE(0)
+ ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_ = _r1.i;
+ XMLVM_SOURCE_POSITION("Object.java", 445)
+ XMLVM_CHECK_NPE(3)
+ _r0.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(0)
+ _r0.i = ((java_lang_Object_AddedMembers*) _r0.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_;
+ if (_r0.i != 0) goto label17;
+ XMLVM_SOURCE_POSITION("Object.java", 446)
+ XMLVM_CHECK_NPE(3)
+ java_lang_Object_syncUnlock__(_r3.o);
+ label17:;
+ XMLVM_SOURCE_POSITION("Object.java", 448)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_OBJECT java_lang_Object_enqueueNewCondition__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_enqueueNewCondition__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "enqueueNewCondition", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ _r2.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 462)
+ _r0.o = __NEW_org_xmlvm_runtime_Condition();
+ XMLVM_CHECK_NPE(0)
+ org_xmlvm_runtime_Condition___INIT____java_lang_Object(_r0.o, _r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 463)
+ XMLVM_CHECK_NPE(2)
+ _r1.o = ((java_lang_Object*) _r2.o)->fields.java_lang_Object.addedMembers_;
+ _r1.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r1.o);
+ XMLVM_CHECK_NPE(1)
+ (*(JAVA_BOOLEAN (*)(JAVA_OBJECT, JAVA_OBJECT)) *(((java_lang_Object*)_r1.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_add___java_lang_Object])(_r1.o, _r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 464)
+ XMLVM_EXIT_METHOD()
+ return _r0.o;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_checkSynchronized___java_lang_Thread(JAVA_OBJECT me, JAVA_OBJECT n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_checkSynchronized___java_lang_Thread]
+ XMLVM_ENTER_METHOD("java.lang.Object", "checkSynchronized", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ _r4.o = me;
+ _r5.o = n1;
+ XMLVM_SOURCE_POSITION("Object.java", 475)
+ _r1.i = 0;
+ _r0.o = JAVA_NULL;
+ XMLVM_SOURCE_POSITION("Object.java", 478)
+ _r2.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(2)
+ org_xmlvm_runtime_Mutex_lock__(_r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 480)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ if (_r2.o == JAVA_NULL) goto label15;
+ XMLVM_SOURCE_POSITION("Object.java", 481)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(2)
+ _r0.o = ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.owningThread_;
+ label15:;
+ XMLVM_SOURCE_POSITION("Object.java", 484)
+ _r2.o = java_lang_Object_GET_staticMutex();
+ XMLVM_CHECK_NPE(2)
+ org_xmlvm_runtime_Mutex_unlock__(_r2.o);
+ XMLVM_SOURCE_POSITION("Object.java", 486)
+ //java_lang_Thread_equals___java_lang_Object[1]
+ XMLVM_CHECK_NPE(5)
+ _r1.i = (*(JAVA_BOOLEAN (*)(JAVA_OBJECT, JAVA_OBJECT)) ((java_lang_Thread*) _r5.o)->tib->vtable[1])(_r5.o, _r0.o);
+ if (_r1.i != 0) goto label34;
+ XMLVM_SOURCE_POSITION("Object.java", 487)
+ XMLVM_SOURCE_POSITION("Object.java", 488)
+
+
+ // Red class access removed: java.lang.IllegalMonitorStateException::new-instance
+ XMLVM_RED_CLASS_DEPENDENCY();
+ // "the current thread is not the owner of the object's monitor"
+ _r3.o = xmlvm_create_java_string_from_pool(67);
+
+
+ // Red class access removed: java.lang.IllegalMonitorStateException::<init>
+ XMLVM_RED_CLASS_DEPENDENCY();
+ XMLVM_THROW_CUSTOM(_r2.o)
+ label34:;
+ XMLVM_SOURCE_POSITION("Object.java", 490)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_BOOLEAN java_lang_Object_removeThreadNotification___org_xmlvm_runtime_Condition(JAVA_OBJECT me, JAVA_OBJECT n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_removeThreadNotification___org_xmlvm_runtime_Condition]
+ XMLVM_ENTER_METHOD("java.lang.Object", "removeThreadNotification", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ _r3.o = me;
+ _r4.o = n1;
+ XMLVM_SOURCE_POSITION("Object.java", 500)
+ _r1.i = 0;
+ _r0.i = 0;
+ label2:;
+ XMLVM_SOURCE_POSITION("Object.java", 501)
+ XMLVM_SOURCE_POSITION("Object.java", 502)
+ if (_r0.i != 0) goto label55;
+ XMLVM_CHECK_NPE(3)
+ _r2.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ _r2.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r2.o);
+ XMLVM_CHECK_NPE(2)
+ _r2.i = (*(JAVA_INT (*)(JAVA_OBJECT)) *(((java_lang_Object*)_r2.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_size__])(_r2.o);
+ if (_r1.i >= _r2.i) goto label55;
+ XMLVM_SOURCE_POSITION("Object.java", 503)
+ XMLVM_CHECK_NPE(3)
+ _r2.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ _r2.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r2.o);
+ XMLVM_CHECK_NPE(2)
+ _r2.o = (*(JAVA_OBJECT (*)(JAVA_OBJECT, JAVA_INT)) *(((java_lang_Object*)_r2.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_get___int])(_r2.o, _r1.i);
+ if (_r2.o != _r4.o) goto label52;
+ XMLVM_SOURCE_POSITION("Object.java", 504)
+ _r0.i = 1;
+ XMLVM_SOURCE_POSITION("Object.java", 506)
+ XMLVM_CHECK_NPE(3)
+ _r2.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ _r2.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r2.o);
+ XMLVM_CHECK_NPE(2)
+ (*(JAVA_OBJECT (*)(JAVA_OBJECT, JAVA_INT)) *(((java_lang_Object*)_r2.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_remove___int])(_r2.o, _r1.i);
+ XMLVM_SOURCE_POSITION("Object.java", 507)
+ XMLVM_CHECK_NPE(3)
+ _r2.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ _r2.i = java_lang_Object_AddedMembers_access$100___java_lang_Object_AddedMembers(_r2.o);
+ if (_r1.i > _r2.i) goto label2;
+ XMLVM_SOURCE_POSITION("Object.java", 508)
+ XMLVM_CHECK_NPE(3)
+ _r2.o = ((java_lang_Object*) _r3.o)->fields.java_lang_Object.addedMembers_;
+ java_lang_Object_AddedMembers_access$110___java_lang_Object_AddedMembers(_r2.o);
+ goto label2;
+ label52:;
+ XMLVM_SOURCE_POSITION("Object.java", 511)
+ _r1.i = _r1.i + 1;
+ goto label2;
+ label55:;
+ XMLVM_SOURCE_POSITION("Object.java", 514)
+ XMLVM_EXIT_METHOD()
+ return _r0.i;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_INT java_lang_Object_getRandInclusive___int_int(JAVA_INT n1, JAVA_INT n2)
+{
+ XMLVM_CLASS_INIT(java_lang_Object)
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_getRandInclusive___int_int]
+ XMLVM_ENTER_METHOD("java.lang.Object", "getRandInclusive", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ _r4.i = n1;
+ _r5.i = n2;
+ XMLVM_SOURCE_POSITION("Object.java", 518)
+ _r0.d = java_lang_Math_random__();
+ _r2.i = _r5.i - _r4.i;
+ _r2.i = _r2.i + 1;
+ _r2.d = (JAVA_DOUBLE) _r2.i;
+ _r0.d = _r0.d * _r2.d;
+ _r0.i = (JAVA_INT) _r0.d;
+ _r0.i = _r0.i + _r4.i;
+ XMLVM_EXIT_METHOD()
+ return _r0.i;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_INT java_lang_Object_preWait___java_lang_Thread_org_xmlvm_runtime_Condition(JAVA_OBJECT me, JAVA_OBJECT n1, JAVA_OBJECT n2)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_preWait___java_lang_Thread_org_xmlvm_runtime_Condition]
+ XMLVM_ENTER_METHOD("java.lang.Object", "preWait", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ XMLVMElem _r6;
+ _r4.o = me;
+ _r5.o = n1;
+ _r6.o = n2;
+ XMLVM_SOURCE_POSITION("Object.java", 529)
+ XMLVM_CHECK_NPE(5)
+ java_lang_Thread_setWaitingCondition___org_xmlvm_runtime_Condition(_r5.o, _r6.o);
+ XMLVM_SOURCE_POSITION("Object.java", 531)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(2)
+ _r1.i = ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_;
+ XMLVM_SOURCE_POSITION("Object.java", 532)
+ XMLVM_CHECK_NPE(4)
+ _r2.o = ((java_lang_Object*) _r4.o)->fields.java_lang_Object.addedMembers_;
+ _r3.i = 0;
+ XMLVM_CHECK_NPE(2)
+ ((java_lang_Object_AddedMembers*) _r2.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_ = _r3.i;
+ XMLVM_SOURCE_POSITION("Object.java", 536)
+ _r0.i = java_lang_Thread_interrupted__();
+ XMLVM_SOURCE_POSITION("Object.java", 540)
+ XMLVM_CHECK_NPE(4)
+ java_lang_Object_prepareForUnlock__(_r4.o);
+ XMLVM_SOURCE_POSITION("Object.java", 542)
+ if (_r0.i == 0) goto label23;
+ _r2.i = -_r1.i;
+ label22:;
+ XMLVM_EXIT_METHOD()
+ return _r2.i;
+ label23:;
+ _r2 = _r1;
+ goto label22;
+ //XMLVM_END_WRAPPER
+}
+
+JAVA_BOOLEAN java_lang_Object_postWait___java_lang_Thread_int(JAVA_OBJECT me, JAVA_OBJECT n1, JAVA_INT n2)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_postWait___java_lang_Thread_int]
+ XMLVM_ENTER_METHOD("java.lang.Object", "postWait", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ _r2.o = me;
+ _r3.o = n1;
+ _r4.i = n2;
+ XMLVM_SOURCE_POSITION("Object.java", 556)
+ _r0.i = 0;
+ XMLVM_SOURCE_POSITION("Object.java", 560)
+ XMLVM_CHECK_NPE(2)
+ java_lang_Object_establishLock___java_lang_Thread(_r2.o, _r3.o);
+ XMLVM_SOURCE_POSITION("Object.java", 562)
+ _r1.o = JAVA_NULL;
+ XMLVM_CHECK_NPE(3)
+ java_lang_Thread_setWaitingCondition___org_xmlvm_runtime_Condition(_r3.o, _r1.o);
+ XMLVM_SOURCE_POSITION("Object.java", 566)
+ _r1.i = java_lang_Thread_interrupted__();
+ if (_r1.i == 0) goto label15;
+ XMLVM_SOURCE_POSITION("Object.java", 567)
+ _r0.i = 1;
+ label15:;
+ XMLVM_SOURCE_POSITION("Object.java", 570)
+ if (_r4.i >= 0) goto label19;
+ XMLVM_SOURCE_POSITION("Object.java", 572)
+ _r4.i = -_r4.i;
+ _r0.i = 1;
+ label19:;
+ XMLVM_SOURCE_POSITION("Object.java", 573)
+ XMLVM_SOURCE_POSITION("Object.java", 577)
+ XMLVM_CHECK_NPE(2)
+ _r1.o = ((java_lang_Object*) _r2.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(1)
+ ((java_lang_Object_AddedMembers*) _r1.o)->fields.java_lang_Object_AddedMembers.recursiveLocks_ = _r4.i;
+ XMLVM_SOURCE_POSITION("Object.java", 579)
+ XMLVM_EXIT_METHOD()
+ return _r0.i;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_wait2__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_wait2__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "wait2", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ _r5.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 583)
+ _r0.o = java_lang_Thread_currentThread__();
+ XMLVM_SOURCE_POSITION("Object.java", 584)
+ XMLVM_CHECK_NPE(5)
+ java_lang_Object_checkSynchronized___java_lang_Thread(_r5.o, _r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 586)
+ XMLVM_CHECK_NPE(5)
+ _r2.o = java_lang_Object_enqueueNewCondition__(_r5.o);
+ XMLVM_SOURCE_POSITION("Object.java", 588)
+ XMLVM_CHECK_NPE(5)
+ _r1.i = java_lang_Object_preWait___java_lang_Thread_org_xmlvm_runtime_Condition(_r5.o, _r0.o, _r2.o);
+ if (_r1.i >= 0) goto label29;
+ label17:;
+ XMLVM_SOURCE_POSITION("Object.java", 590)
+ XMLVM_SOURCE_POSITION("Object.java", 601)
+ XMLVM_CHECK_NPE(5)
+ _r3.i = java_lang_Object_postWait___java_lang_Thread_int(_r5.o, _r0.o, _r1.i);
+ if (_r3.i == 0) goto label37;
+ XMLVM_SOURCE_POSITION("Object.java", 602)
+ XMLVM_SOURCE_POSITION("Object.java", 603)
+
+
+ // Red class access removed: java.lang.InterruptedException::new-instance
+ XMLVM_RED_CLASS_DEPENDENCY();
+
+
+ // Red class access removed: java.lang.InterruptedException::<init>
+ XMLVM_RED_CLASS_DEPENDENCY();
+ XMLVM_THROW_CUSTOM(_r4.o)
+ label29:;
+ XMLVM_SOURCE_POSITION("Object.java", 599)
+ XMLVM_CHECK_NPE(5)
+ _r4.o = ((java_lang_Object*) _r5.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(4)
+ _r4.o = ((java_lang_Object_AddedMembers*) _r4.o)->fields.java_lang_Object_AddedMembers.instanceMutex_;
+ XMLVM_CHECK_NPE(2)
+ org_xmlvm_runtime_Condition_wait___org_xmlvm_runtime_Mutex(_r2.o, _r4.o);
+ goto label17;
+ label37:;
+ XMLVM_SOURCE_POSITION("Object.java", 605)
+ XMLVM_EXIT_METHOD()
+ return;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_wait2___long(JAVA_OBJECT me, JAVA_LONG n1)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_wait2___long]
+ XMLVM_ENTER_METHOD("java.lang.Object", "wait2", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ XMLVMElem _r6;
+ XMLVMElem _r7;
+ XMLVMElem _r8;
+ XMLVMElem _r9;
+ XMLVMElem _r10;
+ _r8.o = me;
+ _r9.l = n1;
+ _r6.l = 0;
+ XMLVM_SOURCE_POSITION("Object.java", 609)
+ _r5.i = _r9.l > _r6.l ? 1 : (_r9.l == _r6.l ? 0 : -1);
+ if (_r5.i >= 0) goto label14;
+ XMLVM_SOURCE_POSITION("Object.java", 610)
+
+
+ // Red class access removed: java.lang.IllegalArgumentException::new-instance
+ XMLVM_RED_CLASS_DEPENDENCY();
+ // "the value of timeout is negative"
+ _r6.o = xmlvm_create_java_string_from_pool(68);
+
+
+ // Red class access removed: java.lang.IllegalArgumentException::<init>
+ XMLVM_RED_CLASS_DEPENDENCY();
+ XMLVM_THROW_CUSTOM(_r5.o)
+ label14:;
+ XMLVM_SOURCE_POSITION("Object.java", 611)
+ _r5.i = _r9.l > _r6.l ? 1 : (_r9.l == _r6.l ? 0 : -1);
+ if (_r5.i != 0) goto label22;
+ XMLVM_SOURCE_POSITION("Object.java", 612)
+ XMLVM_CHECK_NPE(8)
+ java_lang_Object_wait2__(_r8.o);
+ label21:;
+ XMLVM_SOURCE_POSITION("Object.java", 645)
+ XMLVM_EXIT_METHOD()
+ return;
+ label22:;
+ XMLVM_SOURCE_POSITION("Object.java", 614)
+ _r0.o = java_lang_Thread_currentThread__();
+ XMLVM_SOURCE_POSITION("Object.java", 615)
+ XMLVM_CHECK_NPE(8)
+ java_lang_Object_checkSynchronized___java_lang_Thread(_r8.o, _r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 617)
+ XMLVM_CHECK_NPE(8)
+ _r2.o = java_lang_Object_enqueueNewCondition__(_r8.o);
+ _r3.i = 0;
+ XMLVM_SOURCE_POSITION("Object.java", 620)
+ XMLVM_CHECK_NPE(8)
+ _r1.i = java_lang_Object_preWait___java_lang_Thread_org_xmlvm_runtime_Condition(_r8.o, _r0.o, _r2.o);
+ if (_r1.i >= 0) goto label57;
+ label40:;
+ XMLVM_SOURCE_POSITION("Object.java", 622)
+ XMLVM_SOURCE_POSITION("Object.java", 633)
+ XMLVM_CHECK_NPE(8)
+ _r4.i = java_lang_Object_postWait___java_lang_Thread_int(_r8.o, _r0.o, _r1.i);
+ if (_r3.i == 0) goto label49;
+ XMLVM_SOURCE_POSITION("Object.java", 636)
+ XMLVM_SOURCE_POSITION("Object.java", 638)
+ XMLVM_CHECK_NPE(8)
+ java_lang_Object_removeThreadNotification___org_xmlvm_runtime_Condition(_r8.o, _r2.o);
+ label49:;
+ XMLVM_SOURCE_POSITION("Object.java", 641)
+ if (_r4.i == 0) goto label21;
+ XMLVM_SOURCE_POSITION("Object.java", 642)
+
+
+ // Red class access removed: java.lang.InterruptedException::new-instance
+ XMLVM_RED_CLASS_DEPENDENCY();
+
+
+ // Red class access removed: java.lang.InterruptedException::<init>
+ XMLVM_RED_CLASS_DEPENDENCY();
+ XMLVM_THROW_CUSTOM(_r5.o)
+ label57:;
+ XMLVM_SOURCE_POSITION("Object.java", 631)
+ XMLVM_CHECK_NPE(8)
+ _r5.o = ((java_lang_Object*) _r8.o)->fields.java_lang_Object.addedMembers_;
+ XMLVM_CHECK_NPE(5)
+ _r5.o = ((java_lang_Object_AddedMembers*) _r5.o)->fields.java_lang_Object_AddedMembers.instanceMutex_;
+ XMLVM_CHECK_NPE(2)
+ _r3.i = org_xmlvm_runtime_Condition_waitOrTimeout___org_xmlvm_runtime_Mutex_long(_r2.o, _r5.o, _r9.l);
+ goto label40;
+ //XMLVM_END_WRAPPER
+}
+
+void java_lang_Object_notify2__(JAVA_OBJECT me)
+{
+ //XMLVM_BEGIN_WRAPPER[java_lang_Object_notify2__]
+ XMLVM_ENTER_METHOD("java.lang.Object", "notify2", "?")
+ XMLVMElem _r0;
+ XMLVMElem _r1;
+ XMLVMElem _r2;
+ XMLVMElem _r3;
+ XMLVMElem _r4;
+ XMLVMElem _r5;
+ XMLVMElem _r6;
+ _r6.o = me;
+ XMLVM_SOURCE_POSITION("Object.java", 648)
+ _r0.o = java_lang_Thread_currentThread__();
+ XMLVM_SOURCE_POSITION("Object.java", 649)
+ XMLVM_CHECK_NPE(6)
+ java_lang_Object_checkSynchronized___java_lang_Thread(_r6.o, _r0.o);
+ XMLVM_SOURCE_POSITION("Object.java", 653)
+ XMLVM_CHECK_NPE(6)
+ _r3.o = ((java_lang_Object*) _r6.o)->fields.java_lang_Object.addedMembers_;
+ _r3.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r3.o);
+ XMLVM_CHECK_NPE(3)
+ _r3.i = (*(JAVA_INT (*)(JAVA_OBJECT)) *(((java_lang_Object*)_r3.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_size__])(_r3.o);
+ XMLVM_CHECK_NPE(6)
+ _r4.o = ((java_lang_Object*) _r6.o)->fields.java_lang_Object.addedMembers_;
+ _r4.i = java_lang_Object_AddedMembers_access$100___java_lang_Object_AddedMembers(_r4.o);
+ _r4.i = _r4.i + 1;
+ if (_r3.i <= _r4.i) goto label66;
+ XMLVM_SOURCE_POSITION("Object.java", 655)
+ XMLVM_CHECK_NPE(6)
+ _r3.o = ((java_lang_Object*) _r6.o)->fields.java_lang_Object.addedMembers_;
+ _r3.i = java_lang_Object_AddedMembers_access$100___java_lang_Object_AddedMembers(_r3.o);
+ _r3.i = _r3.i + 1;
+ XMLVM_CHECK_NPE(6)
+ _r4.o = ((java_lang_Object*) _r6.o)->fields.java_lang_Object.addedMembers_;
+ _r4.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r4.o);
+ XMLVM_CHECK_NPE(4)
+ _r4.i = (*(JAVA_INT (*)(JAVA_OBJECT)) *(((java_lang_Object*)_r4.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_size__])(_r4.o);
+ _r5.i = 1;
+ _r4.i = _r4.i - _r5.i;
+ _r1.i = java_lang_Object_getRandInclusive___int_int(_r3.i, _r4.i);
+ XMLVM_SOURCE_POSITION("Object.java", 658)
+ XMLVM_CHECK_NPE(6)
+ _r3.o = ((java_lang_Object*) _r6.o)->fields.java_lang_Object.addedMembers_;
+ _r3.o = java_lang_Object_AddedMembers_access$000___java_lang_Object_AddedMembers(_r3.o);