Skip to content

Commit 36dc818

Browse files
committed
Java: Move auxiliary methods into JObjectWrapper.
1 parent b58c554 commit 36dc818

File tree

1 file changed

+19
-14
lines changed

1 file changed

+19
-14
lines changed

Lib/java/director.swg

Lines changed: 19 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -53,18 +53,6 @@ SWIGINTERN int Swig::GetThreadName(char *name, size_t len) {
5353

5454
#if defined(SWIG_JAVA_DETACH_ON_THREAD_END)
5555
#include <pthread.h>
56-
namespace {
57-
58-
void detach(void* jvm) {
59-
static_cast<JavaVM*>(jvm)->DetachCurrentThread();
60-
}
61-
62-
pthread_key_t detachKey;
63-
void makeDetachKey() {
64-
pthread_key_create(&detachKey, detach);
65-
}
66-
67-
}
6856
#endif
6957

7058
namespace Swig {
@@ -149,13 +137,30 @@ namespace Swig {
149137
}
150138
}
151139

140+
#if defined(SWIG_JAVA_DETACH_ON_THREAD_END)
141+
static void detach(void* jvm) {
142+
static_cast<JavaVM*>(jvm)->DetachCurrentThread();
143+
}
144+
145+
static void makeDetachKey() {
146+
pthread_key_create(&detach_key_, detach);
147+
}
148+
149+
/* thread-local key to register a destructor */
150+
static pthread_key_t detach_key_;
151+
#endif
152+
152153
private:
153154
/* pointer to Java object */
154155
jobject jthis_;
155156
/* Local or global reference flag */
156157
bool weak_global_;
157158
};
158159

160+
#if defined(SWIG_JAVA_DETACH_ON_THREAD_END)
161+
pthread_key_t JObjectWrapper::detach_key_;
162+
#endif
163+
159164
/* Local JNI reference deleter */
160165
class LocalRefGuard {
161166
JNIEnv *jenv_;
@@ -224,8 +229,8 @@ namespace Swig {
224229
// See https://developer.android.com/training/articles/perf-jni#threads
225230
static pthread_once_t once = PTHREAD_ONCE_INIT;
226231

227-
pthread_once(&once, makeDetachKey);
228-
pthread_setspecific(detachKey, director->swig_jvm_);
232+
pthread_once(&once, JObjectWrapper::makeDetachKey);
233+
pthread_setspecific(JObjectWrapper::detach_key_, director->swig_jvm_);
229234
#endif
230235
}
231236
~JNIEnvWrapper() {

0 commit comments

Comments
 (0)