123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- #pragma once
- #include <jni.h>
- namespace AKPLATFORM
- {
-
- class CAkJNIThread
- {
- public:
-
- CAkJNIThread(JavaVM* jvm) : m_jvm(jvm), m_jEnv(NULL), m_mustDetachExplicitely(false), m_mustPopLocalFrame(false)
- {
- AcquireEnv(jvm, 0);
- }
- CAkJNIThread(JavaVM* jvm, int numLocalRefs) : m_jvm(jvm), m_jEnv(NULL), m_mustDetachExplicitely(false), m_mustPopLocalFrame(false)
- {
- AcquireEnv(jvm, numLocalRefs);
- }
- ~CAkJNIThread()
- {
- if (m_mustPopLocalFrame)
- {
- m_jEnv->PopLocalFrame(NULL);
- m_mustPopLocalFrame = false;
- }
- if (m_jvm != NULL && m_jEnv != NULL && m_mustDetachExplicitely)
- {
- m_jvm->DetachCurrentThread();
- m_mustDetachExplicitely = false;
- }
- }
- JNIEnv *getEnv()
- {
- return m_jEnv;
- }
- bool isAttached()
- {
- return m_jEnv != NULL;
- }
- private:
- void AcquireEnv(JavaVM* jvm, int numLocalRefs)
- {
- if (!jvm)
- return;
- jvm->GetEnv((void**)&m_jEnv, JNI_VERSION_1_6);
- if (m_jEnv == NULL)
- {
- JavaVMAttachArgs lJavaVMAttachArgs;
- lJavaVMAttachArgs.version = JNI_VERSION_1_6;
- lJavaVMAttachArgs.name = "NativeThread";
- lJavaVMAttachArgs.group = NULL;
- jvm->AttachCurrentThread(&m_jEnv, &lJavaVMAttachArgs);
- m_mustDetachExplicitely = true;
- }
- if (m_jEnv && numLocalRefs > 0)
- {
- m_mustPopLocalFrame = 0 == m_jEnv->PushLocalFrame(numLocalRefs);
- }
- }
- JavaVM * m_jvm;
- JNIEnv * m_jEnv;
- bool m_mustDetachExplicitely: 1;
- bool m_mustPopLocalFrame: 1;
- };
- }
|