diff options
Diffstat (limited to 'tests/nbody-java/java_lang_Object.c')
-rw-r--r-- | tests/nbody-java/java_lang_Object.c | 1079 |
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); + XMLVM_CHECK_NPE(3) + _r2.o = (*(JAVA_OBJECT (*)(JAVA_OBJECT, JAVA_INT)) *(((java_lang_Object*)_r3.o)->tib->itableBegin)[XMLVM_ITABLE_IDX_java_util_List_remove___int])(_r3.o, _r1.i); + _r2.o = _r2.o; + XMLVM_SOURCE_POSITION("Object.java", 663) + XMLVM_CHECK_NPE(2) + org_xmlvm_runtime_Condition_broadcast__(_r2.o); + label66:; + XMLVM_SOURCE_POSITION("Object.java", 665) + XMLVM_EXIT_METHOD() + return; + //XMLVM_END_WRAPPER +} + +void java_lang_Object_notifyAll2__(JAVA_OBJECT me) +{ + //XMLVM_BEGIN_WRAPPER[java_lang_Object_notifyAll2__] + XMLVM_ENTER_METHOD("java.lang.Object", "notifyAll2", "?") + XMLVMElem _r0; + XMLVMElem _r1; + XMLVMElem _r2; + XMLVMElem _r3; + XMLVMElem _r4; + XMLVMElem _r5; + XMLVMElem _r6; + _r6.o = me; + XMLVM_SOURCE_POSITION("Object.java", 668) + _r0.o = java_lang_Thread_currentThread__(); + XMLVM_SOURCE_POSITION("Object. |