-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathJUCE-support-Android-thread-via-dalvik-juce6.patch
103 lines (95 loc) · 3.82 KB
/
JUCE-support-Android-thread-via-dalvik-juce6.patch
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
diff --git a/modules/juce_core/native/juce_android_JNIHelpers.h b/modules/juce_core/native/juce_android_JNIHelpers.h
index 4131d326f..2924baf0c 100644
--- a/modules/juce_core/native/juce_android_JNIHelpers.h
+++ b/modules/juce_core/native/juce_android_JNIHelpers.h
@@ -769,6 +769,14 @@ DECLARE_JNI_CLASS (AndroidBuildVersion, "android/os/Build$VERSION")
DECLARE_JNI_CLASS (AndroidSurfaceHolder, "android/view/SurfaceHolder")
#undef JNI_CLASS_MEMBERS
+#define JNI_CLASS_MEMBERS(METHOD, STATICMETHOD, FIELD, STATICFIELD, CALLBACK) \
+ METHOD (constructor1, "<init>", "(Ljava/lang/Runnable;)V") \
+ METHOD (constructor2, "<init>", "(Ljava/lang/Runnable;Ljava/lang/String;)V") \
+ METHOD (start, "start", "()V") \
+
+DECLARE_JNI_CLASS (JavaLangThread, "java/lang/Thread")
+#undef JNI_CLASS_MEMBERS
+
//==============================================================================
namespace
{
diff --git a/modules/juce_core/native/juce_posix_SharedCode.h b/modules/juce_core/native/juce_posix_SharedCode.h
index dbf06043a..c04ba9518 100644
--- a/modules/juce_core/native/juce_posix_SharedCode.h
+++ b/modules/juce_core/native/juce_posix_SharedCode.h
@@ -882,6 +882,32 @@ static void* threadEntryProc (void* userData)
extern pthread_t juce_createRealtimeAudioThread (void* (*entry) (void*), void* userPtr);
#endif
+#if ANDROID
+class ThreadTargetRunnable : public AndroidInterfaceImplementer
+{
+ Thread *juce_thread;
+public:
+ ThreadTargetRunnable(Thread *juceThread) : juce_thread(juceThread) {}
+
+ jobject invoke (jobject proxy, jobject method, jobjectArray args) override
+ {
+ auto* env = getEnv();
+
+ auto methodName = juceString ((jstring) env->CallObjectMethod (method, JavaMethod.getName));
+
+ if (methodName == "run")
+ {
+ juce_thread->threadHandle.set((void*) pthread_self());
+ juce_thread->threadId = (Thread::ThreadID) juce_thread->threadHandle.get();
+ threadEntryProc(juce_thread);
+ return nullptr;
+ }
+
+ return AndroidInterfaceImplementer::invoke (proxy, method, args);
+ }
+};
+#endif
+
void Thread::launchThread()
{
#if JUCE_ANDROID
@@ -903,6 +929,18 @@ void Thread::launchThread()
pthread_attr_t attr;
pthread_attr_t* attrPtr = nullptr;
+#if JUCE_ANDROID
+ auto env = getEnv();
+ auto runnableNative = new ThreadTargetRunnable(this);
+ auto runnable = CreateJavaInterface(runnableNative, "java/lang/Runnable");
+ GlobalRef threadRunnableGRef { runnable };
+ auto name = env->NewStringUTF("ThreadTargetRunnable");
+ auto threadObj = env->NewObject(JavaLangThread, JavaLangThread.constructor1, threadRunnableGRef.get(), name);
+ GlobalRef threadGRef { LocalRef<jobject>(threadObj) };
+ javaThreadPeer = threadGRef;
+ env->CallVoidMethod(threadGRef.get(), JavaLangThread.start);
+#else
+
if (pthread_attr_init (&attr) == 0)
{
attrPtr = &attr;
@@ -919,6 +957,7 @@ void Thread::launchThread()
if (attrPtr != nullptr)
pthread_attr_destroy (attrPtr);
+#endif
}
void Thread::closeThreadHandle()
diff --git a/modules/juce_core/threads/juce_Thread.h b/modules/juce_core/threads/juce_Thread.h
index 5db90efcb..ad70793e0 100644
--- a/modules/juce_core/threads/juce_Thread.h
+++ b/modules/juce_core/threads/juce_Thread.h
@@ -381,6 +381,7 @@ public:
#endif
private:
+ friend class ThreadTargetRunnable; // needs to access threadHandle
//==============================================================================
const String threadName;
Atomic<void*> threadHandle { nullptr };
@@ -396,6 +397,7 @@ private:
#if JUCE_ANDROID
bool isAndroidRealtimeThread = false;
+ /*GlobalRef*/ void* javaThreadPeer { nullptr };
#endif
#ifndef DOXYGEN