Issue #2270 OpenCV Manager fails with JNI error fixed.
Local reference table overflow in JNI code fixed. (cherry picked from commit 457c8785383c89c766f613d8b581ec00ddd2a4d7)
This commit is contained in:
parent
0efa9d4c06
commit
0ab954a3c4
@ -46,6 +46,7 @@ bool JavaBasedPackageManager::InstallPackage(const PackageInfo& package)
|
|||||||
LOGD("Calling java package manager with package name %s\n", package.GetFullName().c_str());
|
LOGD("Calling java package manager with package name %s\n", package.GetFullName().c_str());
|
||||||
jobject jpkgname = jenv->NewStringUTF(package.GetFullName().c_str());
|
jobject jpkgname = jenv->NewStringUTF(package.GetFullName().c_str());
|
||||||
bool result = jenv->CallNonvirtualBooleanMethod(JavaPackageManager, jclazz, jmethod, jpkgname);
|
bool result = jenv->CallNonvirtualBooleanMethod(JavaPackageManager, jclazz, jmethod, jpkgname);
|
||||||
|
jenv->DeleteLocalRef(jpkgname);
|
||||||
|
|
||||||
if (self_attached)
|
if (self_attached)
|
||||||
{
|
{
|
||||||
@ -99,10 +100,14 @@ vector<PackageInfo> JavaBasedPackageManager::GetInstalledPackages()
|
|||||||
{
|
{
|
||||||
jobject jtmp = jenv->GetObjectArrayElement(jpkgs, i);
|
jobject jtmp = jenv->GetObjectArrayElement(jpkgs, i);
|
||||||
PackageInfo tmp = ConvertPackageFromJava(jtmp, jenv);
|
PackageInfo tmp = ConvertPackageFromJava(jtmp, jenv);
|
||||||
|
jenv->DeleteLocalRef(jtmp);
|
||||||
|
|
||||||
if (tmp.IsValid())
|
if (tmp.IsValid())
|
||||||
result.push_back(tmp);
|
result.push_back(tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
jenv->DeleteLocalRef(jpkgs);
|
||||||
|
|
||||||
if (self_attached)
|
if (self_attached)
|
||||||
{
|
{
|
||||||
JavaContext->DetachCurrentThread();
|
JavaContext->DetachCurrentThread();
|
||||||
@ -113,6 +118,7 @@ vector<PackageInfo> JavaBasedPackageManager::GetInstalledPackages()
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IMPORTANT: This method can be called only if thread is attached to Dalvik
|
||||||
PackageInfo JavaBasedPackageManager::ConvertPackageFromJava(jobject package, JNIEnv* jenv)
|
PackageInfo JavaBasedPackageManager::ConvertPackageFromJava(jobject package, JNIEnv* jenv)
|
||||||
{
|
{
|
||||||
jclass jclazz = jenv->GetObjectClass(package);
|
jclass jclazz = jenv->GetObjectClass(package);
|
||||||
@ -120,11 +126,13 @@ PackageInfo JavaBasedPackageManager::ConvertPackageFromJava(jobject package, JNI
|
|||||||
jstring jnameobj = static_cast<jstring>(jenv->GetObjectField(package, jfield));
|
jstring jnameobj = static_cast<jstring>(jenv->GetObjectField(package, jfield));
|
||||||
const char* jnamestr = jenv->GetStringUTFChars(jnameobj, NULL);
|
const char* jnamestr = jenv->GetStringUTFChars(jnameobj, NULL);
|
||||||
string name(jnamestr);
|
string name(jnamestr);
|
||||||
|
jenv->DeleteLocalRef(jnameobj);
|
||||||
|
|
||||||
jfield = jenv->GetFieldID(jclazz, "versionName", "Ljava/lang/String;");
|
jfield = jenv->GetFieldID(jclazz, "versionName", "Ljava/lang/String;");
|
||||||
jstring jversionobj = static_cast<jstring>(jenv->GetObjectField(package, jfield));
|
jstring jversionobj = static_cast<jstring>(jenv->GetObjectField(package, jfield));
|
||||||
const char* jversionstr = jenv->GetStringUTFChars(jversionobj, NULL);
|
const char* jversionstr = jenv->GetStringUTFChars(jversionobj, NULL);
|
||||||
string verison(jversionstr);
|
string verison(jversionstr);
|
||||||
|
jenv->DeleteLocalRef(jversionobj);
|
||||||
|
|
||||||
string path;
|
string path;
|
||||||
jclazz = jenv->FindClass("android/os/Build$VERSION");
|
jclazz = jenv->FindClass("android/os/Build$VERSION");
|
||||||
@ -134,15 +142,14 @@ PackageInfo JavaBasedPackageManager::ConvertPackageFromJava(jobject package, JNI
|
|||||||
{
|
{
|
||||||
jclazz = jenv->GetObjectClass(package);
|
jclazz = jenv->GetObjectClass(package);
|
||||||
jfield = jenv->GetFieldID(jclazz, "applicationInfo", "Landroid/content/pm/ApplicationInfo;");
|
jfield = jenv->GetFieldID(jclazz, "applicationInfo", "Landroid/content/pm/ApplicationInfo;");
|
||||||
|
|
||||||
jobject japp_info = jenv->GetObjectField(package, jfield);
|
jobject japp_info = jenv->GetObjectField(package, jfield);
|
||||||
jclazz = jenv->GetObjectClass(japp_info);
|
jclazz = jenv->GetObjectClass(japp_info);
|
||||||
jfield = jenv->GetFieldID(jclazz, "nativeLibraryDir", "Ljava/lang/String;");
|
jfield = jenv->GetFieldID(jclazz, "nativeLibraryDir", "Ljava/lang/String;");
|
||||||
jstring jpathobj = static_cast<jstring>(jenv->GetObjectField(japp_info, jfield));
|
jstring jpathobj = static_cast<jstring>(jenv->GetObjectField(japp_info, jfield));
|
||||||
|
|
||||||
const char* jpathstr = jenv->GetStringUTFChars(jpathobj, NULL);
|
const char* jpathstr = jenv->GetStringUTFChars(jpathobj, NULL);
|
||||||
path = string(jpathstr);
|
path = string(jpathstr);
|
||||||
jenv->ReleaseStringUTFChars(jpathobj, jpathstr);
|
jenv->ReleaseStringUTFChars(jpathobj, jpathstr);
|
||||||
|
jenv->DeleteLocalRef(jpathobj);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -39,7 +39,7 @@ LOCAL_LDFLAGS = -Wl,-allow-shlib-undefined
|
|||||||
|
|
||||||
LOCAL_MODULE := OpenCVEngineTestApp
|
LOCAL_MODULE := OpenCVEngineTestApp
|
||||||
|
|
||||||
LOCAL_LDLIBS += -lz -lbinder -llog
|
LOCAL_LDLIBS += -lz -lbinder -llog -lutils
|
||||||
|
|
||||||
LOCAL_SHARED_LIBRARIES += libOpenCVEngine
|
LOCAL_SHARED_LIBRARIES += libOpenCVEngine
|
||||||
|
|
||||||
|
0
android/service/push_native.py
Normal file → Executable file
0
android/service/push_native.py
Normal file → Executable file
0
android/service/test_native.py
Normal file → Executable file
0
android/service/test_native.py
Normal file → Executable file
Loading…
x
Reference in New Issue
Block a user