Skip to content

Commit

Permalink
Revert "jpy vararg leak (deephaven#2105)" (deephaven#2111)
Browse files Browse the repository at this point in the history
This reverts commit 73cdcb8.
  • Loading branch information
niloc132 authored Mar 22, 2022
1 parent 574baff commit e8252bc
Show file tree
Hide file tree
Showing 8 changed files with 103 additions and 144 deletions.
13 changes: 8 additions & 5 deletions py/jpy/src/main/c/jni/org_jpy_PyLib.c
Original file line number Diff line number Diff line change
Expand Up @@ -1856,19 +1856,22 @@ JNIEXPORT jobjectArray JNICALL Java_org_jpy_PyLib_getObjectArrayValue
for (i = 0; i < length; i++) {
pyItem = PySequence_GetItem(pyObject, i);
if (pyItem == NULL) {
JPy_DELETE_LOCAL_REF(jObject);
(*jenv)->DeleteLocalRef(jenv, jObject);
jObject = NULL;
goto error;
}
if (JPy_AsJObject(jenv, pyItem, &jItem, JNI_FALSE) < 0) {
JPy_DELETE_LOCAL_REF(jObject);
(*jenv)->DeleteLocalRef(jenv, jObject);
jObject = NULL;
JPy_DIAG_PRINT(JPy_DIAG_F_ALL, "Java_org_jpy_PyLib_getObjectArrayValue: error: failed to convert Python item to Java Object\n");
PyLib_HandlePythonException(jenv);
goto error;
}
Py_XDECREF(pyItem);
(*jenv)->SetObjectArrayElement(jenv, jObject, i, jItem);
if ((*jenv)->ExceptionCheck(jenv)) {
JPy_DELETE_LOCAL_REF(jObject);
(*jenv)->DeleteLocalRef(jenv, jObject);
jObject = NULL;
goto error;
}
}
Expand Down Expand Up @@ -2347,9 +2350,9 @@ PyObject* PyLib_CallAndReturnObject(JNIEnv *jenv, PyObject* pyObject, jboolean i
}
pyArg = PyLib_FromJObjectForTuple(jenv, jArg, jParamClass, nameChars, i);
if (jParamClass != NULL) {
JPy_DELETE_LOCAL_REF(jParamClass);
(*jenv)->DeleteLocalRef(jenv, jParamClass);
jParamClass = NULL;
}
JPy_DELETE_LOCAL_REF(jArg);
if (pyArg == NULL) {
JPy_DIAG_PRINT(JPy_DIAG_F_ALL, "PyLib_CallAndReturnObject: error: callable '%s': argument %d: failed to convert Java into Python object\n", nameChars, i);
PyLib_HandlePythonException(jenv);
Expand Down
4 changes: 2 additions & 2 deletions py/jpy/src/main/c/jpy_conv.c
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,7 @@ char* JPy_GetTypeName(JNIEnv* jenv, jclass classRef)
typeNameCopy = JPy_CopyUTFString(jTypeNameChars);
(*jenv)->ReleaseStringUTFChars(jenv, jTypeName, jTypeNameChars);
}
JPy_DELETE_LOCAL_REF(jTypeName);
(*jenv)->DeleteLocalRef(jenv, jTypeName);
return typeNameCopy;
}

Expand All @@ -190,7 +190,7 @@ PyObject* JPy_FromTypeName(JNIEnv* jenv, jclass classRef)
pyTypeName = Py_BuildValue("s", jTypeNameChars);
(*jenv)->ReleaseStringUTFChars(jenv, jTypeName, jTypeNameChars);
}
JPy_DELETE_LOCAL_REF(jTypeName);
(*jenv)->DeleteLocalRef(jenv, jTypeName);
return pyTypeName;
}

Expand Down
8 changes: 4 additions & 4 deletions py/jpy/src/main/c/jpy_jmethod.c
Original file line number Diff line number Diff line change
Expand Up @@ -307,12 +307,12 @@ PyObject* JMethod_InvokeMethod(JNIEnv* jenv, JPy_JMethod* method, PyObject* pyAr
jstring v = (*jenv)->CallStaticObjectMethodA(jenv, classRef, method->mid, jArgs);
JPy_ON_JAVA_EXCEPTION_GOTO(error);
returnValue = JPy_FromJString(jenv, v);
JPy_DELETE_LOCAL_REF(v);
(*jenv)->DeleteLocalRef(jenv, v);
} else {
jobject v = (*jenv)->CallStaticObjectMethodA(jenv, classRef, method->mid, jArgs);
JPy_ON_JAVA_EXCEPTION_GOTO(error);
returnValue = JMethod_FromJObject(jenv, method, pyArgs, jArgs, 0, returnType, v);
JPy_DELETE_LOCAL_REF(v);
(*jenv)->DeleteLocalRef(jenv, v);
}

} else {
Expand Down Expand Up @@ -365,12 +365,12 @@ PyObject* JMethod_InvokeMethod(JNIEnv* jenv, JPy_JMethod* method, PyObject* pyAr
jstring v = (*jenv)->CallObjectMethodA(jenv, objectRef, method->mid, jArgs);
JPy_ON_JAVA_EXCEPTION_GOTO(error);
returnValue = JPy_FromJString(jenv, v);
JPy_DELETE_LOCAL_REF(v);
(*jenv)->DeleteLocalRef(jenv, v);
} else {
jobject v = (*jenv)->CallObjectMethodA(jenv, objectRef, method->mid, jArgs);
JPy_ON_JAVA_EXCEPTION_GOTO(error);
returnValue = JMethod_FromJObject(jenv, method, pyArgs, jArgs, 1, returnType, v);
JPy_DELETE_LOCAL_REF(v);
(*jenv)->DeleteLocalRef(jenv, v);
}
}

Expand Down
20 changes: 9 additions & 11 deletions py/jpy/src/main/c/jpy_jobj.c
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,7 @@ int JObj_init_internal(JNIEnv* jenv, JPy_JObj* self, PyObject* args, PyObject* k
JPy_JType* jType;
PyObject* constructor;
JPy_JMethod* jMethod;
jobject localObjectRef;
jobject globalObjectRef;
jobject objectRef;
jvalue* jArgs;
JPy_ArgDisposer* jDisposers;
int isVarArgsArray;
Expand Down Expand Up @@ -124,10 +123,10 @@ int JObj_init_internal(JNIEnv* jenv, JPy_JObj* self, PyObject* args, PyObject* k

JPy_DIAG_PRINT(JPy_DIAG_F_MEM, "JObj_init: calling Java constructor %s\n", jType->javaName);

localObjectRef = (*jenv)->NewObjectA(jenv, jType->classRef, jMethod->mid, jArgs);
objectRef = (*jenv)->NewObjectA(jenv, jType->classRef, jMethod->mid, jArgs);
JPy_ON_JAVA_EXCEPTION_RETURN(-1);

if (localObjectRef == NULL) {
if (objectRef == NULL) {
PyErr_NoMemory();
return -1;
}
Expand All @@ -136,19 +135,18 @@ int JObj_init_internal(JNIEnv* jenv, JPy_JObj* self, PyObject* args, PyObject* k
JMethod_DisposeJArgs(jenv, jMethod->paramCount, jArgs, jDisposers);
}

globalObjectRef = (*jenv)->NewGlobalRef(jenv, localObjectRef);
if (globalObjectRef == NULL) {
objectRef = (*jenv)->NewGlobalRef(jenv, objectRef);
if (objectRef == NULL) {
PyErr_NoMemory();
return -1;
}
JPy_DELETE_LOCAL_REF(localObjectRef);

// Note: __init__ may be called multiple times, so we have to release the old objectRef
if (self->objectRef != NULL) {
(*jenv)->DeleteGlobalRef(jenv, self->objectRef);
}

self->objectRef = globalObjectRef;
self->objectRef = objectRef;

JPy_DIAG_PRINT(JPy_DIAG_F_MEM, "JObj_init: self->objectRef=%p\n", self->objectRef);

Expand Down Expand Up @@ -351,7 +349,7 @@ PyObject* JObj_str(JPy_JObj* self)
returnValue = JPy_FromJString(jenv, stringRef);

error:
JPy_DELETE_LOCAL_REF(stringRef);
(*jenv)->DeleteLocalRef(jenv, stringRef);

return returnValue;
}
Expand Down Expand Up @@ -511,7 +509,7 @@ PyObject* JObj_getattro(JPy_JObj* self, PyObject* name)
jobject item = (*jenv)->GetObjectField(jenv, self->objectRef, field->fid);
JPy_ON_JAVA_EXCEPTION_RETURN(NULL);
returnValue = JPy_FromJObjectWithType(jenv, item, field->type);
JPy_DELETE_LOCAL_REF(item);
(*jenv)->DeleteLocalRef(jenv, item);
return returnValue;
}
} else {
Expand Down Expand Up @@ -610,7 +608,7 @@ PyObject* JObj_sq_item(JPy_JObj* self, Py_ssize_t index)
jobject item = (*jenv)->GetObjectArrayElement(jenv, self->objectRef, (jsize) index);
JPy_ON_JAVA_EXCEPTION_RETURN(NULL);
returnValue = JPy_FromJObjectWithType(jenv, item, type->componentType);
JPy_DELETE_LOCAL_REF(item);
(*jenv)->DeleteLocalRef(jenv, item);
return returnValue;
}
}
Expand Down
Loading

0 comments on commit e8252bc

Please sign in to comment.