summaryrefslogtreecommitdiffstats
path: root/src/corelib/kernel
diff options
context:
space:
mode:
authorChristian Strømme <christian.stromme@digia.com>2014-02-28 17:09:27 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-04-03 00:28:10 +0200
commit5f6cbfb0701d0f4e87ac3656ffcbebdcd1577bde (patch)
tree44b944ae70fdefb7157fba596d8bad4cd9b87753 /src/corelib/kernel
parentb94493e6c86d9744f9fe224bedd79daa188286c1 (diff)
Android: Stop ART from complaining about missing thread names.
The new Android jvm (ART) complains loudly if we attach without supplying a thread name. Task-number: QTBUG-35441 Change-Id: I962d613be0db50f3ca9a4c786b36003f31c9db14 Reviewed-by: Eskil Abrahamsen Blomfeldt <eskil.abrahamsen-blomfeldt@digia.com>
Diffstat (limited to 'src/corelib/kernel')
-rw-r--r--src/corelib/kernel/qjni.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/corelib/kernel/qjni.cpp b/src/corelib/kernel/qjni.cpp
index 623662a628..437205bf92 100644
--- a/src/corelib/kernel/qjni.cpp
+++ b/src/corelib/kernel/qjni.cpp
@@ -44,6 +44,7 @@
#include <QtCore/qthreadstorage.h>
#include <QtCore/qhash.h>
#include <QtCore/qstring.h>
+#include <QtCore/QThread>
QT_BEGIN_NAMESPACE
@@ -52,6 +53,11 @@ static inline QString keyBase()
return QStringLiteral("%1%2%3");
}
+static inline QByteArray threadBaseName()
+{
+ return QByteArrayLiteral("QtThread-");
+}
+
static QString qt_convertJString(jstring string)
{
QJNIEnvironmentPrivate env;
@@ -179,7 +185,10 @@ QJNIEnvironmentPrivate::QJNIEnvironmentPrivate()
{
JavaVM *vm = QtAndroidPrivate::javaVM();
if (vm->GetEnv((void**)&jniEnv, JNI_VERSION_1_6) == JNI_EDETACHED) {
- if (vm->AttachCurrentThread(&jniEnv, 0) != JNI_OK)
+ const qulonglong id = reinterpret_cast<qulonglong>(QThread::currentThreadId());
+ const QByteArray threadName = threadBaseName() + QByteArray::number(id);
+ JavaVMAttachArgs args = { JNI_VERSION_1_6, threadName, Q_NULLPTR };
+ if (vm->AttachCurrentThread(&jniEnv, &args) != JNI_OK)
return;
}