summaryrefslogtreecommitdiffstats
path: root/src/corelib/kernel/qjnihelpers.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/corelib/kernel/qjnihelpers.cpp')
-rw-r--r--src/corelib/kernel/qjnihelpers.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/corelib/kernel/qjnihelpers.cpp b/src/corelib/kernel/qjnihelpers.cpp
index 9ec491f6a9..74eb6f5b27 100644
--- a/src/corelib/kernel/qjnihelpers.cpp
+++ b/src/corelib/kernel/qjnihelpers.cpp
@@ -46,6 +46,7 @@ QT_BEGIN_NAMESPACE
static JavaVM *g_javaVM = Q_NULLPTR;
static jobject g_jActivity = Q_NULLPTR;
static jobject g_jClassLoader = Q_NULLPTR;
+static jint g_androidSdkVersion = 0;
static inline bool exceptionCheck(JNIEnv *env)
{
@@ -60,6 +61,19 @@ static inline bool exceptionCheck(JNIEnv *env)
return false;
}
+static void setAndroidSdkVersion(JNIEnv *env)
+{
+ jclass androidVersionClass = env->FindClass("android/os/Build$VERSION");
+ if (exceptionCheck(env))
+ return;
+
+ jfieldID androidSDKFieldID = env->GetStaticFieldID(androidVersionClass, "SDK_INT", "I");
+ if (exceptionCheck(env))
+ return;
+
+ g_androidSdkVersion = env->GetStaticIntField(androidVersionClass, androidSDKFieldID);
+}
+
jint QtAndroidPrivate::initJNI(JavaVM *vm, JNIEnv *env)
{
jclass jQtNative = env->FindClass("org/qtproject/qt5/android/QtNative");
@@ -93,6 +107,8 @@ jint QtAndroidPrivate::initJNI(JavaVM *vm, JNIEnv *env)
if (exceptionCheck(env))
return JNI_ERR;
+ setAndroidSdkVersion(env);
+
g_jClassLoader = env->NewGlobalRef(classLoader);
env->DeleteLocalRef(classLoader);
g_jActivity = env->NewGlobalRef(activity);
@@ -118,4 +134,9 @@ jobject QtAndroidPrivate::classLoader()
return g_jClassLoader;
}
+jint QtAndroidPrivate::androidSdkVersion()
+{
+ return g_androidSdkVersion;
+}
+
QT_END_NAMESPACE